@libp2p/keychain 6.1.1-3574648c3 → 6.1.1-5b8813abc
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 +4 -4
- package/dist/index.min.js.map +4 -4
- package/dist/src/utils/export.d.ts.map +1 -1
- package/dist/src/utils/export.js +4 -3
- package/dist/src/utils/export.js.map +1 -1
- package/dist/src/utils/import.d.ts.map +1 -1
- package/dist/src/utils/import.js +4 -3
- package/dist/src/utils/import.js.map +1 -1
- package/package.json +7 -7
- package/src/utils/export.ts +4 -3
- package/src/utils/import.ts +4 -3
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PKeychain = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PKeychain=(()=>{var tf=Object.create;var pn=Object.defineProperty;var rf=Object.getOwnPropertyDescriptor;var nf=Object.getOwnPropertyNames;var sf=Object.getPrototypeOf,of=Object.prototype.hasOwnProperty;var wr=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),he=(r,e)=>{for(var t in e)pn(r,t,{get:e[t],enumerable:!0})},Fi=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of nf(e))!of.call(r,s)&&s!==t&&pn(r,s,{get:()=>e[s],enumerable:!(n=rf(e,s))||n.enumerable});return r};var Oi=(r,e,t)=>(t=r!=null?tf(sf(r)):{},Fi(e||!r||!r.__esModule?pn(t,"default",{value:r,enumerable:!0}):t,r)),af=r=>Fi(pn({},"__esModule",{value:!0}),r);var ru=wr((jy,tu)=>{"use strict";function Kh(r){return r>=55296&&r<=56319}function Vh(r){return r>=56320&&r<=57343}tu.exports=function(e,t,n){if(typeof t!="string")throw new Error("Input must be string");for(var s=t.length,o=0,i,a,c=0;c<s;c+=1){if(i=t.charCodeAt(c),a=t[c],Kh(i)&&Vh(t.charCodeAt(c+1))&&(c+=1,a+=t[c]),o+=e(a),o===n)return t.slice(0,c+1);if(o>n)return t.slice(0,c-a.length+1)}return t}});var su=wr((qy,nu)=>{"use strict";function Hh(r){return r>=55296&&r<=56319}function Mh(r){return r>=56320&&r<=57343}nu.exports=function(e){if(typeof e!="string")throw new Error("Input must be string");for(var t=e.length,n=0,s=null,o=null,i=0;i<t;i++)s=e.charCodeAt(i),Mh(s)?o!=null&&Hh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var iu=wr(($y,ou)=>{"use strict";var Ph=ru(),jh=su();ou.exports=Ph.bind(null,jh)});var uu=wr((zy,cu)=>{"use strict";var qh=iu(),$h=/[\/\?<>\\:\*\|"]/g,zh=/[\x00-\x1f\x80-\x9f]/g,Gh=/^\.+$/,Zh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i;function Yh(r,e){for(var t=r.length;t>0&&(r[t-1]==="."||r[t-1]===" ");)t--;return t<r.length?r.slice(0,t)+e:r}function au(r,e){if(typeof r!="string")throw new Error("Input must be string");var t=r.replace($h,e).replace(zh,e).replace(Gh,e).replace(Zh,e);return t=Yh(t,e),qh(t,255)}cu.exports=function(r,e){var t=e&&e.replacement||"",n=au(r,t);return t===""?n:au(n,"")}});var fu=wr(pr=>{"use strict";var Xh="[object ArrayBuffer]",Qe=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===Xh}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}},Si="string",Jh=/^[0-9a-f\s]+$/i,Qh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,ed=/^[a-zA-Z0-9-_]+$/,rs=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=Qe.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return decodeURIComponent(escape(n))}},Ce=class{static toString(e,t=!1){let n=Qe.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}},ns=class r{static isHex(e){return typeof e===Si&&Jh.test(e)}static isBase64(e){return typeof e===Si&&Qh.test(e)}static isBase64Url(e){return typeof e===Si&&ed.test(e)}static ToString(e,t="utf8"){let n=Qe.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 Ce.toString(n,!0);case"utf16":case"utf16be":return Ce.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 Ce.fromString(e,!0);case"utf16":case"utf16be":return Ce.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Qe.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 rs.fromString(e);case"utf16":case"utf16be":return Ce.fromString(e);case"utf16le":case"usc2":return Ce.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 rs.toString(e);case"utf16":case"utf16be":return Ce.toString(e);case"utf16le":case"usc2":return Ce.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=Qe.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=Qe.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 Ce.toString(e,t)}static FromUtf16String(e,t=!1){return Ce.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,"")||""}};ns.DEFAULT_UTF8_ENCODING="utf8";function td(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 rd(...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 nd(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}pr.BufferSourceConverter=Qe;pr.Convert=ns;pr.assign=td;pr.combine=rd;pr.isEqual=nd});var Nd={};he(Nd,{isKeychain:()=>Td,keychain:()=>Cd});var xr=class extends Error{constructor(e="An error occurred while signing a message"){super(e),this.name="SigningError"}},vr=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},gn=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var Ki={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new gn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return e}};var Q=Ki;var U=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},Pt=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}},Er=class extends Error{static name="InvalidPrivateKeyError";constructor(e="Invalid private key"){super(e),this.name="InvalidPrivateKeyError"}};var mn=class extends Error{static name="NotFoundError";constructor(e="Not found"){super(e),this.name="NotFoundError"}};var jt=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Vi=Symbol.for("@libp2p/service-capabilities");var Xs={};he(Xs,{base58btc:()=>ee,base58flickr:()=>pf});var u0=new Uint8Array(0);function Hi(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 ze(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 Mi(r){return new TextEncoder().encode(r)}function Pi(r){return new TextDecoder().decode(r)}function cf(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),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(m){if(m instanceof Uint8Array||(ArrayBuffer.isView(m)?m=new Uint8Array(m.buffer,m.byteOffset,m.byteLength):Array.isArray(m)&&(m=Uint8Array.from(m))),!(m instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(m.length===0)return"";for(var x=0,g=0,y=0,E=m.length;y!==E&&m[y]===0;)y++,x++;for(var A=(E-y)*l+1>>>0,N=new Uint8Array(A);y!==E;){for(var _=m[y],F=0,R=A-1;(_!==0||F<g)&&R!==-1;R--,F++)_+=256*N[R]>>>0,N[R]=_%a>>>0,_=_/a>>>0;if(_!==0)throw new Error("Non-zero carry");g=F,y++}for(var C=A-g;C!==A&&N[C]===0;)C++;for(var O=c.repeat(x);C<A;++C)O+=r.charAt(N[C]);return O}function h(m){if(typeof m!="string")throw new TypeError("Expected String");if(m.length===0)return new Uint8Array;var x=0;if(m[x]!==" "){for(var g=0,y=0;m[x]===c;)g++,x++;for(var E=(m.length-x)*u+1>>>0,A=new Uint8Array(E);m[x];){var N=t[m.charCodeAt(x)];if(N===255)return;for(var _=0,F=E-1;(N!==0||_<y)&&F!==-1;F--,_++)N+=a*A[F]>>>0,A[F]=N%256>>>0,N=N/256>>>0;if(N!==0)throw new Error("Non-zero carry");y=_,x++}if(m[x]!==" "){for(var R=E-y;R!==E&&A[R]===0;)R++;for(var C=new Uint8Array(g+(E-R)),O=g;R!==E;)C[O++]=A[R++];return C}}}function d(m){var x=h(m);if(x)return x;throw new Error(`Non-${e} character`)}return{encode:f,decodeUnsafe:h,decode:d}}var uf=cf,ff=uf,qi=ff;var Gs=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Zs=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let s=t.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,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 $i(this,e)}},Ys=class{decoders;constructor(e){this.decoders=e}or(e){return $i(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 $i(r,e){return new Ys({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Ws=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Gs(e,t,n),this.decoder=new Zs(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function qt({name:r,prefix:e,encode:t,decode:n}){return new Ws(r,e,t,n)}function it({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=qi(t,r);return qt({prefix:e,name:r,encode:n,decode:o=>ze(s(o))})}function lf(r,e,t,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*t/8|0),i=0,a=0,c=0;for(let u=0;u<s;++u){let l=e[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|l,i+=t,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function hf(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)!==0;)o+="=";return o}function df(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function Z({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let s=df(n);return qt({prefix:e,name:r,encode(o){return hf(o,n,t)},decode(o){return lf(o,s,t,r)}})}var ee=it({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pf=it({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Js={};he(Js,{base32:()=>$t,base32hex:()=>bf,base32hexpad:()=>xf,base32hexpadupper:()=>vf,base32hexupper:()=>wf,base32pad:()=>mf,base32padupper:()=>yf,base32upper:()=>gf,base32z:()=>Ef});var $t=Z({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),gf=Z({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),mf=Z({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),yf=Z({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),bf=Z({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),wf=Z({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),xf=Z({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),vf=Z({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ef=Z({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Qs={};he(Qs,{base36:()=>Br,base36upper:()=>Bf});var Br=it({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Bf=it({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Af=Zi,zi=128,Sf=127,kf=~Sf,If=Math.pow(2,31);function Zi(r,e,t){e=e||[],t=t||0;for(var n=t;r>=If;)e[t++]=r&255|zi,r/=128;for(;r&kf;)e[t++]=r&255|zi,r>>>=7;return e[t]=r|0,Zi.bytes=t-n+1,e}var Cf=eo,Tf=128,Gi=127;function eo(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw eo.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&Gi)<<s:(i&Gi)*Math.pow(2,s),s+=7}while(i>=Tf);return eo.bytes=o-n,t}var Nf=Math.pow(2,7),_f=Math.pow(2,14),Lf=Math.pow(2,21),Rf=Math.pow(2,28),Uf=Math.pow(2,35),Df=Math.pow(2,42),Ff=Math.pow(2,49),Of=Math.pow(2,56),Kf=Math.pow(2,63),Vf=function(r){return r<Nf?1:r<_f?2:r<Lf?3:r<Rf?4:r<Uf?5:r<Df?6:r<Ff?7:r<Of?8:r<Kf?9:10},Hf={encode:Af,decode:Cf,encodingLength:Vf},Mf=Hf,Ar=Mf;function Sr(r,e=0){return[Ar.decode(r,e),Ar.decode.bytes]}function zt(r,e,t=0){return Ar.encode(r,e,t),e}function Gt(r){return Ar.encodingLength(r)}function Oe(r,e){let t=e.byteLength,n=Gt(r),s=n+Gt(t),o=new Uint8Array(s+t);return zt(r,o,0),zt(t,o,n),o.set(e,s),new Zt(r,t,e,o)}function Yi(r){let e=ze(r),[t,n]=Sr(e),[s,o]=Sr(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Zt(t,s,i,e)}function Wi(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Hi(r.bytes,t.bytes)}}var Zt=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};function Xi(r,e){let{bytes:t,version:n}=r;return n===0?jf(t,to(r),e??ee.encoder):qf(t,to(r),e??$t.encoder)}var Ji=new WeakMap;function to(r){let e=Ji.get(r);if(e==null){let t=new Map;return Ji.set(r,t),t}return e}var Se=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!==Ir)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==$f)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&&Wi(e.multihash,n.multihash)}toString(e){return Xi(this,e)}toJSON(){return{"/":Xi(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??Qi(n,s,o.bytes))}else if(t[zf]===!0){let{version:n,multihash:s,code:o}=t,i=Yi(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!==Ir)throw new Error(`Version 0 CID must use dag-pb (code: ${Ir}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=Qi(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Ir,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=ze(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 Zt(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[f,h]=Sr(e.subarray(t));return t+=h,f},s=n(),o=Ir;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(),u=t+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(e,t){let[n,s]=Pf(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 to(o).set(n,e),o}};function Pf(r,e){switch(r[0]){case"Q":{let t=e??ee;return[ee.prefix,t.decode(`${ee.prefix}${r}`)]}case ee.prefix:{let t=e??ee;return[ee.prefix,t.decode(r)]}case $t.prefix:{let t=e??$t;return[$t.prefix,t.decode(r)]}case Br.prefix:{let t=e??Br;return[Br.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function jf(r,e,t){let{prefix:n}=t;if(n!==ee.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function qf(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 Ir=112,$f=18;function Qi(r,e,t){let n=Gt(r),s=n+Gt(e),o=new Uint8Array(s+t.byteLength);return zt(r,o,0),zt(e,o,n),o.set(t,s),o}var zf=Symbol.for("@ipld/js-cid/CID");var ro={};he(ro,{identity:()=>Et});var ea=0,Gf="identity",ta=ze;function Zf(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return Oe(ea,ta(r))}var Et={code:ea,name:Gf,encode:ta,digest:Zf};function be(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}var ra="1.2.840.10045.3.1.7",na="1.3.132.0.34",sa="1.3.132.0.35";async function oa(r,e,t){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);t?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function ia(r,e,t,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,e,t.subarray());return n?.signal?.throwIfAborted(),o}function Ge(r=0){return new Uint8Array(r)}function Be(r=0){return new Uint8Array(r)}function Yt(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=Be(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var ca=Symbol.for("@achingbrain/uint8arraylist");function aa(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 bn(r){return!!r?.[ca]}var de=class r{bufs;length;[ca]=!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(bn(n)){t+=n.byteLength;for(let s of n.bufs)this.bufs.push(s)}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(bn(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=aa(this.bufs,e);return t.buf[t.index]}set(e,t){let n=aa(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(bn(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 Yt(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Yt(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 u=e>=a&&e<c,l=t>a&&t<=c;if(u&&l){if(e===a&&t===c){n.push(i);break}let f=e-a;n.push(i.subarray(f,f+(t-e)));break}if(u){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(l){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(!bn(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 f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,l;for(let f=t;f<=c;f+=l){l=0;for(let h=u;h>=0;h--){let d=this.get(f+h);if(n[h]!==d){l=Math.max(1,h-a[d]);break}}if(l===0)return f}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=Be(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=Ge(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=Ge(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=Ge(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=Be(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=Ge(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=Ge(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=Ge(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=Ge(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=Ge(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(!be(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 no={};he(no,{base10:()=>Yf});var Yf=it({prefix:"9",name:"base10",alphabet:"0123456789"});var so={};he(so,{base16:()=>Wf,base16upper:()=>Xf});var Wf=Z({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Xf=Z({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var oo={};he(oo,{base2:()=>Jf});var Jf=Z({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var io={};he(io,{base256emoji:()=>nl});var ua=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}"),Qf=ua.reduce((r,e,t)=>(r[t]=e,r),[]),el=ua.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function tl(r){return r.reduce((e,t)=>(e+=Qf[t],e),"")}function rl(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=el[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var nl=qt({prefix:"\u{1F680}",name:"base256emoji",encode:tl,decode:rl});var ao={};he(ao,{base64:()=>Bt,base64pad:()=>sl,base64url:()=>ol,base64urlpad:()=>il});var Bt=Z({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),sl=Z({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),ol=Z({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),il=Z({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var co={};he(co,{base8:()=>al});var al=Z({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var uo={};he(uo,{identity:()=>cl});var cl=qt({prefix:"\0",name:"identity",encode:r=>Pi(r),decode:r=>Mi(r)});var G0=new TextEncoder,Z0=new TextDecoder;var ho={};he(ho,{sha256:()=>Wt,sha512:()=>hl});var ll=20;function lo({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:s}){return new fo(r,e,t,n,s)}var fo=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,s,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=s??ll,this.maxDigestLength=o}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?fa(n,this.code,t?.truncate):n.then(s=>fa(s,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function fa(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return Oe(e,r)}function ha(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Wt=lo({name:"sha2-256",code:18,encode:ha("SHA-256")}),hl=lo({name:"sha2-512",code:19,encode:ha("SHA-512")});var po={...uo,...oo,...co,...no,...so,...Js,...Qs,...Xs,...ao,...io},ip={...ho,...ro};function pa(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var da=pa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),go=pa("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=Be(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),dl={utf8:da,"utf-8":da,hex:po.base16,latin1:go,ascii:go,binary:go,...po},wn=dl;function H(r,e="utf8"){let t=wn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function j(r,e="utf8"){let t=wn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var pl=parseInt("11111",2),mo=parseInt("10000000",2),gl=parseInt("01111111",2),ga={0:Cr,1:Cr,2:ml,3:wl,4:xl,5:bl,6:yl,16:Cr,22:Cr,48:Cr};function Te(r,e={offset:0}){let t=r[e.offset]&pl;if(e.offset++,ga[t]!=null)return ga[t](r,e);throw new Error("No decoder for tag "+t)}function Tr(r,e){let t=0;if((r[e.offset]&mo)===mo){let n=r[e.offset]&gl,s="0x";e.offset++;for(let o=0;o<n;o++,e.offset++)s+=r[e.offset].toString(16).padStart(2,"0");t=parseInt(s,16)}else t=r[e.offset],e.offset++;return t}function Cr(r,e){Tr(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=Te(r,e);if(n===null)break;t.push(n)}return t}function ml(r,e){let t=Tr(r,e),n=e.offset,s=e.offset+t,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return e.offset+=t,Uint8Array.from(o)}function yl(r,e){let t=Tr(r,e),n=e.offset+t,s=r[e.offset];e.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;e.offset<n;){let u=r[e.offset];if(e.offset++,c.push(u&127),u<128){c.reverse();let l=0;for(let f=0;f<c.length;f++)l+=c[f]<<f*7;a+=`.${l}`,c=[]}}return a}function bl(r,e){return e.offset++,null}function wl(r,e){let t=Tr(r,e),n=r[e.offset];e.offset++;let s=r.subarray(e.offset,e.offset+t-1);if(e.offset+=t,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function xl(r,e){let t=Tr(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function vl(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new de;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function xn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=vl(r.byteLength);return new de(Uint8Array.from([e.byteLength|mo]),e)}function pe(r){let e=new de,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new de(Uint8Array.from([2]),xn(e),e)}function Nr(r){let e=Uint8Array.from([0]),t=new de(e,r);return new de(Uint8Array.from([3]),xn(t),t)}function ma(r){return new de(Uint8Array.from([4]),xn(r),r)}function Ne(r,e=48){let t=new de;for(let n of r)t.append(n);return new de(Uint8Array.from([e]),xn(t),t)}var El=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Bl=Uint8Array.from([6,5,43,129,4,0,34]),Al=Uint8Array.from([6,5,43,129,4,0,35]),Sl={ext:!0,kty:"EC",crv:"P-256"},kl={ext:!0,kty:"EC",crv:"P-384"},Il={ext:!0,kty:"EC",crv:"P-521"},yo=32,bo=48,wo=66;function ya(r){let e=Te(r);return xo(e)}function xo(r){let e=r[1],t=j(e,"base64url"),n=r[2][1][0],s=1,o,i;if(e.byteLength===yo)return o=j(n.subarray(s,s+yo),"base64url"),i=j(n.subarray(s+yo),"base64url"),new Xt({...Sl,key_ops:["sign"],d:t,x:o,y:i});if(e.byteLength===bo)return o=j(n.subarray(s,s+bo),"base64url"),i=j(n.subarray(s+bo),"base64url"),new Xt({...kl,key_ops:["sign"],d:t,x:o,y:i});if(e.byteLength===wo)return o=j(n.subarray(s,s+wo),"base64url"),i=j(n.subarray(s+wo),"base64url"),new Xt({...Il,key_ops:["sign"],d:t,x:o,y:i});throw new U(`Private key length was wrong length, got ${e.byteLength}, expected 32, 48 or 66`)}function ba(r){return Ne([pe(Uint8Array.from([1])),ma(H(r.d??"","base64url")),Ne([xa(r.crv)],160),Ne([Nr(new de(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function wa(r){return Ne([pe(Uint8Array.from([1])),Ne([xa(r.crv)],160),Ne([Nr(new de(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function xa(r){if(r==="P-256")return El;if(r==="P-384")return Bl;if(r==="P-521")return Al;throw new U(`Invalid curve ${r}`)}var vn=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=wa(this.jwk)),this._raw}toMultihash(){return Et.digest(Jt(this))}toCID(){return Se.createV1(114,this.toMultihash())}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}async verify(e,t,n){return ia(this.jwk,t,e,n)}},Xt=class{type="ECDSA";jwk;publicKey;_raw;constructor(e){this.jwk=e,this.publicKey=new vn({crv:e.crv,ext:e.ext,key_ops:["verify"],kty:"EC",x:e.x,y:e.y})}get raw(){return this._raw==null&&(this._raw=ba(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}async sign(e,t){return oa(this.jwk,e,t)}};function vo(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function ke(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(`${t}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new RangeError(`${t}expected integer >= 0, got ${r}`)}}function we(r,e,t=""){let n=vo(r),s=r?.length,o=e!==void 0;if(!n||o&&s!==e){let i=t&&`"${t}" `,a=o?` of length ${e}`:"",c=n?`length=${s}`:`type=${typeof r}`,u=i+"expected Uint8Array"+a+", got "+c;throw n?new RangeError(u):new TypeError(u)}return r}function Qt(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(ke(r.outputLen),ke(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function er(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 En(r,e){we(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new RangeError('"digestInto() output" expected to be of length >='+t)}function xe(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function At(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function _e(r,e){return r<<32-e|r>>>e}function Bn(r,e){return r<<e|r>>>32-e>>>0}var Ea=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Cl=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function An(r){if(we(r),Ea)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=Cl[r[t]];return e}var Ze={_0:48,_9:57,A:65,F:70,a:97,f:102};function va(r){if(r>=Ze._0&&r<=Ze._9)return r-Ze._0;if(r>=Ze.A&&r<=Ze.F)return r-(Ze.A-10);if(r>=Ze.a&&r<=Ze.f)return r-(Ze.a-10)}function _r(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(Ea)try{return Uint8Array.fromHex(r)}catch(s){throw s instanceof SyntaxError?new RangeError(s.message):s}let e=r.length,t=e/2;if(e%2)throw new RangeError("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=va(r.charCodeAt(o)),a=va(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new RangeError('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}var Tl=async()=>{};async function Ba(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 Tl(),n+=o)}}function Nl(r){if(typeof r!="string")throw new TypeError("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Eo(r,e=""){return typeof r=="string"?Nl(r):we(r,void 0,e)}function Bo(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];we(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 Aa(r,e){if(e!==void 0&&{}.toString.call(e)!=="[object Object]")throw new TypeError("options must be object or undefined");return Object.assign(r,e)}function Lr(r,e={}){let t=(s,o)=>r(o).update(s).digest(),n=r(void 0);return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.canXOF=n.canXOF,t.create=s=>r(s),Object.assign(t,e),Object.freeze(t)}function Sn(r=32){ke(r,"bytesLength");let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return e.getRandomValues(new Uint8Array(r))}var Ao=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function kn(r,e,t){return r&e^~r&t}function In(r,e,t){return r&e^r&t^e&t}var St=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,n,s){this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(e),this.view=At(this.buffer)}update(e){er(this),we(e);let{view:t,buffer:n,blockLen:s}=this,o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=At(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){er(this),En(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,xe(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)t[f]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let a=At(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(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.destroyed=i,e.finished=o,e.length=s,e.pos=a,s%t&&e.buffer.set(n),e}clone(){return this._cloneInto()}},Ye=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ae=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Cn=BigInt(4294967295),Sa=BigInt(32);function _l(r,e=!1){return e?{h:Number(r&Cn),l:Number(r>>Sa&Cn)}:{h:Number(r>>Sa&Cn)|0,l:Number(r&Cn)|0}}function ka(r,e=!1){let t=r.length,n=new Uint32Array(t),s=new Uint32Array(t);for(let o=0;o<t;o++){let{h:i,l:a}=_l(r[o],e);[n[o],s[o]]=[i,a]}return[n,s]}var So=(r,e,t)=>r>>>t,ko=(r,e,t)=>r<<32-t|e>>>t,kt=(r,e,t)=>r>>>t|e<<32-t,It=(r,e,t)=>r<<32-t|e>>>t,Rr=(r,e,t)=>r<<64-t|e>>>t-32,Ur=(r,e,t)=>r>>>t-32|e<<64-t;function Ke(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Ia=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Ca=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Ta=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Na=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,_a=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),La=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var Rl=Uint32Array.from([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]),at=new Uint32Array(64),Io=class extends St{constructor(e){super(64,e,8,!1)}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 f=0;f<16;f++,t+=4)at[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let h=at[f-15],d=at[f-2],m=_e(h,7)^_e(h,18)^h>>>3,x=_e(d,17)^_e(d,19)^d>>>10;at[f]=x+at[f-7]+m+at[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=_e(a,6)^_e(a,11)^_e(a,25),d=l+h+kn(a,c,u)+Rl[f]+at[f]|0,x=(_e(n,2)^_e(n,13)^_e(n,22))+In(n,s,o)|0;l=u,u=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+x|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,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){xe(at)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),xe(this.buffer)}},Co=class extends Io{A=Ye[0]|0;B=Ye[1]|0;C=Ye[2]|0;D=Ye[3]|0;E=Ye[4]|0;F=Ye[5]|0;G=Ye[6]|0;H=Ye[7]|0;constructor(){super(32)}};var Ra=ka(["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))),Ul=Ra[0],Dl=Ra[1],ct=new Uint32Array(80),ut=new Uint32Array(80),To=class extends St{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:d,Gl:m,Hh:x,Hl:g}=this;return[e,t,n,s,o,i,a,c,u,l,f,h,d,m,x,g]}set(e,t,n,s,o,i,a,c,u,l,f,h,d,m,x,g){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=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=d|0,this.Gl=m|0,this.Hh=x|0,this.Hl=g|0}process(e,t){for(let A=0;A<16;A++,t+=4)ct[A]=e.getUint32(t),ut[A]=e.getUint32(t+=4);for(let A=16;A<80;A++){let N=ct[A-15]|0,_=ut[A-15]|0,F=kt(N,_,1)^kt(N,_,8)^So(N,_,7),R=It(N,_,1)^It(N,_,8)^ko(N,_,7),C=ct[A-2]|0,O=ut[A-2]|0,z=kt(C,O,19)^Rr(C,O,61)^So(C,O,6),K=It(C,O,19)^Ur(C,O,61)^ko(C,O,6),p=Ta(R,K,ut[A-7],ut[A-16]),b=Na(p,F,z,ct[A-7],ct[A-16]);ct[A]=b|0,ut[A]=p|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:d,Fl:m,Gh:x,Gl:g,Hh:y,Hl:E}=this;for(let A=0;A<80;A++){let N=kt(f,h,14)^kt(f,h,18)^Rr(f,h,41),_=It(f,h,14)^It(f,h,18)^Ur(f,h,41),F=f&d^~f&x,R=h&m^~h&g,C=_a(E,_,R,Dl[A],ut[A]),O=La(C,y,N,F,Ul[A],ct[A]),z=C|0,K=kt(n,s,28)^Rr(n,s,34)^Rr(n,s,39),p=It(n,s,28)^Ur(n,s,34)^Ur(n,s,39),b=n&o^n&a^o&a,B=s&i^s&c^i&c;y=x|0,E=g|0,x=d|0,g=m|0,d=f|0,m=h|0,{h:f,l:h}=Ke(u|0,l|0,O|0,z|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=Ia(z,p,B);n=Ca(v,O,K,b),s=v|0}({h:n,l:s}=Ke(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Ke(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Ke(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=Ke(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=Ke(this.Eh|0,this.El|0,f|0,h|0),{h:d,l:m}=Ke(this.Fh|0,this.Fl|0,d|0,m|0),{h:x,l:g}=Ke(this.Gh|0,this.Gl|0,x|0,g|0),{h:y,l:E}=Ke(this.Hh|0,this.Hl|0,y|0,E|0),this.set(n,s,o,i,a,c,u,l,f,h,d,m,x,g,y,E)}roundClean(){xe(ct,ut)}destroy(){this.destroyed=!0,xe(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},No=class extends To{Ah=ae[0]|0;Al=ae[1]|0;Bh=ae[2]|0;Bl=ae[3]|0;Ch=ae[4]|0;Cl=ae[5]|0;Dh=ae[6]|0;Dl=ae[7]|0;Eh=ae[8]|0;El=ae[9]|0;Fh=ae[10]|0;Fl=ae[11]|0;Gh=ae[12]|0;Gl=ae[13]|0;Hh=ae[14]|0;Hl=ae[15]|0;constructor(){super(64)}};var ft=Lr(()=>new Co,Ao(1));var Ve=Lr(()=>new No,Ao(3));var q=(r,e,t)=>we(r,e,t),Lo=ke,tr=An,re=(...r)=>Bo(...r),rr=r=>_r(r),Ct=vo,Dr=r=>Sn(r),Nn=BigInt(0),_o=BigInt(1);function Le(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new TypeError(t+"expected boolean, got type="+typeof r)}return r}function _n(r){if(typeof r=="bigint"){if(!Tn(r))throw new RangeError("positive bigint expected, got "+r)}else Lo(r);return r}function Re(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(t+"expected number, got type="+typeof r)}if(!Number.isSafeInteger(r)){let t=e&&`"${e}" `;throw new RangeError(t+"expected safe integer, got "+r)}}function Fr(r){let e=_n(r).toString(16);return e.length&1?"0"+e:e}function Ua(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?Nn:BigInt("0x"+r)}function Tt(r){return Ua(An(r))}function He(r){return Ua(An(Or(we(r)).reverse()))}function Ln(r,e){if(ke(e),e===0)throw new RangeError("zero length");r=_n(r);let t=r.toString(16);if(t.length>e*2)throw new RangeError("number too large");return _r(t.padStart(e*2,"0"))}function Ro(r,e){return Ln(r,e).reverse()}function Da(r,e){if(r=q(r),e=q(e),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 Or(r){return Uint8Array.from(q(r))}function Rn(r){if(typeof r!="string")throw new TypeError("ascii string expected, got "+typeof r);return Uint8Array.from(r,(e,t)=>{let n=e.charCodeAt(0);if(e.length!==1||n>127)throw new RangeError(`string contains non-ASCII character "${r[t]}" with code ${n} at position ${t}`);return n})}var Tn=r=>typeof r=="bigint"&&Nn<=r;function Fl(r,e,t){return Tn(r)&&Tn(e)&&Tn(t)&&e<=r&&r<t}function nr(r,e,t,n){if(!Fl(e,t,n))throw new RangeError("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function sr(r){if(r<Nn)throw new Error("expected non-negative bigint, got "+r);let e;for(e=0;r>Nn;r>>=_o,e+=1);return e}var Kr=r=>(_o<<BigInt(r))-_o;function Fa(r,e,t){if(ke(r,"hashLen"),ke(e,"qByteLen"),typeof t!="function")throw new TypeError("hmacFn must be a function");let n=g=>new Uint8Array(g),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),u=n(r),l=0,f=()=>{c.fill(1),u.fill(0),l=0},h=(...g)=>t(u,re(c,...g)),d=(g=s)=>{u=h(o,g),c=h(),g.length!==0&&(u=h(i,g),c=h())},m=()=>{if(l++>=a)throw new Error("drbg: tried max amount of iterations");let g=0,y=[];for(;g<e;){c=h();let E=c.slice();y.push(E),g+=c.length}return re(...y)};return(g,y)=>{f(),d(g);let E;for(;(E=y(m()))===void 0;)d();return f(),E}}function Ue(r,e={},t={}){if(Object.prototype.toString.call(r)!=="[object Object]")throw new TypeError("expected valid options object");function n(o,i,a){if(!a&&i!=="function"&&!Object.hasOwn(r,o))throw new TypeError(`param "${o}" is invalid: expected own property`);let c=r[o];if(a&&c===void 0)return;let u=typeof c;if(u!==i||c===null)throw new TypeError(`param "${o}" is invalid: expected ${i}, got ${u}`)}let s=(o,i)=>Object.entries(o).forEach(([a,c])=>n(a,c,i));s(e,!1),s(t,!0)}var Uo=()=>{throw new Error("not implemented")};var ce=BigInt(0),Y=BigInt(1),Nt=BigInt(2),Ha=BigInt(3),Ma=BigInt(4),Pa=BigInt(5),Ol=BigInt(7),ja=BigInt(8),Kl=BigInt(9),qa=BigInt(16);function X(r,e){if(e<=ce)throw new Error("mod: expected positive modulus, got "+e);let t=r%e;return t>=ce?t:e+t}function G(r,e,t){if(e<ce)throw new Error("pow2: expected non-negative exponent, got "+e);let n=r;for(;e-- >ce;)n*=n,n%=t;return n}function Oa(r,e){if(r===ce)throw new Error("invert: expected non-zero number");if(e<=ce)throw new Error("invert: expected positive modulus, got "+e);let t=X(r,e),n=e,s=ce,o=Y,i=Y,a=ce;for(;t!==ce;){let u=n/t,l=n-t*u,f=s-i*u,h=o-a*u;n=t,t=l,s=i,o=a,i=f,a=h}if(n!==Y)throw new Error("invert: does not exist");return X(s,e)}function Do(r,e,t){let n=r;if(!n.eql(n.sqr(e),t))throw new Error("Cannot find square root")}function $a(r,e){let t=r,n=(t.ORDER+Y)/Ma,s=t.pow(e,n);return Do(t,s,e),s}function Vl(r,e){let t=r,n=(t.ORDER-Pa)/ja,s=t.mul(e,Nt),o=t.pow(s,n),i=t.mul(e,o),a=t.mul(t.mul(i,Nt),o),c=t.mul(i,t.sub(a,t.ONE));return Do(t,c,e),c}function Hl(r){let e=or(r),t=za(r),n=t(e,e.neg(e.ONE)),s=t(e,n),o=t(e,e.neg(n)),i=(r+Ol)/qa;return((a,c)=>{let u=a,l=u.pow(c,i),f=u.mul(l,n),h=u.mul(l,s),d=u.mul(l,o),m=u.eql(u.sqr(f),c),x=u.eql(u.sqr(h),c);l=u.cmov(l,f,m),f=u.cmov(d,h,x);let g=u.eql(u.sqr(f),c),y=u.cmov(l,f,g);return Do(u,y,c),y})}function za(r){if(r<Ha)throw new Error("sqrt is not defined for small field");let e=r-Y,t=0;for(;e%Nt===ce;)e/=Nt,t++;let n=Nt,s=or(r);for(;Ka(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return $a;let o=s.pow(n,e),i=(e+Y)/Nt;return function(c,u){let l=c;if(l.is0(u))return u;if(Ka(l,u)!==1)throw new Error("Cannot find square root");let f=t,h=l.mul(l.ONE,o),d=l.pow(u,e),m=l.pow(u,i);for(;!l.eql(d,l.ONE);){if(l.is0(d))return l.ZERO;let x=1,g=l.sqr(d);for(;!l.eql(g,l.ONE);)if(x++,g=l.sqr(g),x===f)throw new Error("Cannot find square root");let y=Y<<BigInt(f-x-1),E=l.pow(h,y);f=x,h=l.sqr(E),d=l.mul(d,h),m=l.mul(m,E)}return m}}function Ml(r){return r%Ma===Ha?$a:r%ja===Pa?Vl:r%qa===Kl?Hl(r):za(r)}var We=(r,e)=>(X(r,e)&Y)===Y,Pl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Fo(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=Pl.reduce((n,s)=>(n[s]="function",n),e);if(Ue(r,t),Re(r.BYTES,"BYTES"),Re(r.BITS,"BITS"),r.BYTES<1||r.BITS<1)throw new Error("invalid field: expected BYTES/BITS > 0");if(r.ORDER<=Y)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function jl(r,e,t){let n=r;if(t<ce)throw new Error("invalid exponent, negatives unsupported");if(t===ce)return n.ONE;if(t===Y)return e;let s=n.ONE,o=e;for(;t>ce;)t&Y&&(s=n.mul(s,o)),o=n.sqr(o),t>>=Y;return s}function Vr(r,e,t=!1){let n=r,s=new Array(e.length).fill(t?n.ZERO:void 0),o=e.reduce((a,c,u)=>n.is0(c)?a:(s[u]=a,n.mul(a,c)),n.ONE),i=n.inv(o);return e.reduceRight((a,c,u)=>n.is0(c)?a:(s[u]=n.mul(a,s[u]),n.mul(a,c)),i),s}function Ka(r,e){let t=r,n=(t.ORDER-Y)/Nt,s=t.pow(e,n),o=t.eql(s,t.ONE),i=t.eql(s,t.ZERO),a=t.eql(s,t.neg(t.ONE));if(!o&&!i&&!a)throw new Error("invalid Legendre symbol result");return o?1:i?0:-1}function ql(r,e){if(e!==void 0&&Lo(e),r<=ce)throw new Error("invalid n length: expected positive n, got "+r);if(e!==void 0&&e<1)throw new Error("invalid n length: expected positive bit length, got "+e);let t=sr(r);if(e!==void 0&&e<t)throw new Error(`invalid n length: expected bit length (${t}) >= n.length (${e})`);let n=e!==void 0?e:t,s=Math.ceil(n/8);return{nBitLength:n,nByteLength:s}}var Va=new WeakMap,Un=class{ORDER;BITS;BYTES;isLE;ZERO=ce;ONE=Y;_lengths;_mod;constructor(e,t={}){if(e<=Y)throw new Error("invalid field: expected ORDER > 1, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&Object.defineProperty(this,"sqrt",{value:t.sqrt,enumerable:!0}),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=Object.freeze(t.allowedLengths.slice())),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:s,nByteLength:o}=ql(e,n);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=s,this.BYTES=o,Object.freeze(this)}create(e){return X(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new TypeError("invalid field element: expected bigint, got "+typeof e);return ce<=e&&e<this.ORDER}is0(e){return e===ce}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&Y)===Y}neg(e){return X(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return X(e*e,this.ORDER)}add(e,t){return X(e+t,this.ORDER)}sub(e,t){return X(e-t,this.ORDER)}mul(e,t){return X(e*t,this.ORDER)}pow(e,t){return jl(this,e,t)}div(e,t){return X(e*Oa(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return Oa(e,this.ORDER)}sqrt(e){let t=Va.get(this);return t||Va.set(this,t=Ml(this.ORDER)),t(this,e)}toBytes(e){return this.isLE?Ro(e,this.BYTES):Ln(e,this.BYTES)}fromBytes(e,t=!1){q(e);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:a}=this;if(n){if(e.length<1||!n.includes(e.length)||e.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let u=new Uint8Array(s);u.set(e,o?0:u.length-e.length),e=u}if(e.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+e.length);let c=o?He(e):Tt(e);if(a&&(c=X(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return Vr(this,e)}cmov(e,t,n){return Le(n,"condition"),n?t:e}};Object.freeze(Un.prototype);function or(r,e={}){return new Un(r,e)}function Ga(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=Y)throw new Error("field order must be greater than 1");let e=sr(r-Y);return Math.ceil(e/8)}function Oo(r){let e=Ga(r);return e+Math.ceil(e/2)}function Ko(r,e,t=!1){q(r);let n=r.length,s=Ga(e),o=Math.max(Oo(e),16);if(n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=t?He(r):Tt(r),a=X(i,e-Y)+Y;return t?Ro(a,s):Ln(a,s)}var ir=BigInt(0),_t=BigInt(1);function Hr(r,e){let t=e.negate();return r?t:e}function Lt(r,e){let t=Vr(r.Fp,e.map(n=>n.Z));return e.map((n,s)=>r.fromAffine(n.toAffine(t[s])))}function Xa(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Vo(r,e){Xa(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),s=2**r,o=Kr(r),i=BigInt(r);return{windows:t,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Za(r,e,t){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=t,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=_t);let u=e*n,l=u+Math.abs(a)-1,f=a===0,h=a<0,d=e%2!==0;return{nextN:c,offset:l,isZero:f,isNeg:h,isNegF:d,offsetF:u}}var Ho=new WeakMap,Ja=new WeakMap;function Mo(r){return Ja.get(r)||1}function Ya(r){if(r!==ir)throw new Error("invalid wNAF")}var ar=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,n=this.ZERO){let s=e;for(;t>ir;)t&_t&&(n=n.add(s)),s=s.double(),t>>=_t;return n}precomputeWindow(e,t){let{windows:n,windowSize:s}=Vo(t,this.bits),o=[],i=e,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let u=1;u<s;u++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(e,t,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=Vo(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:u,isZero:l,isNeg:f,isNegF:h,offsetF:d}=Za(n,a,i);n=c,l?o=o.add(Hr(h,t[d])):s=s.add(Hr(f,t[u]))}return Ya(n),{p:s,f:o}}wNAFUnsafe(e,t,n,s=this.ZERO){let o=Vo(e,this.bits);for(let i=0;i<o.windows&&n!==ir;i++){let{nextN:a,offset:c,isZero:u,isNeg:l}=Za(n,i,o);if(n=a,!u){let f=t[c];s=s.add(l?f.negate():f)}}return Ya(n),s}getPrecomputes(e,t,n){let s=Ho.get(t);return s||(s=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(s=n(s)),Ho.set(t,s))),s}cached(e,t,n){let s=Mo(e);return this.wNAF(s,this.getPrecomputes(s,e,n),t)}unsafe(e,t,n,s){let o=Mo(e);return o===1?this._unsafeLadder(e,t,s):this.wNAFUnsafe(o,this.getPrecomputes(o,e,n),t,s)}createCache(e,t){Xa(t,this.bits),Ja.set(e,t),Ho.delete(e)}hasCache(e){return Mo(e)!==1}};function Qa(r,e,t,n){let s=e,o=r.ZERO,i=r.ZERO;for(;t>ir||n>ir;)t&_t&&(o=o.add(s)),n&_t&&(i=i.add(s)),s=s.double(),t>>=_t,n>>=_t;return{p1:o,p2:i}}function Wa(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Fo(e),e}else return or(r,{isLE:t})}function Dn(r,e,t={},n){if(n===void 0&&(n=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let u=e[c];if(!(typeof u=="bigint"&&u>ir))throw new Error(`CURVE.${c} must be positive bigint`)}let s=Wa(e.p,t.Fp,n),o=Wa(e.n,t.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!s.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:s,Fn:o}}function Fn(r,e){return function(n){let s=r(n);return{secretKey:s,publicKey:e(s)}}}var lt=BigInt(0),oe=BigInt(1),Po=BigInt(2),$l=BigInt(8);function zl(r,e,t,n){let s=r.sqr(t),o=r.sqr(n),i=r.add(r.mul(e.a,s),o),a=r.add(r.ONE,r.mul(e.d,r.mul(s,o)));return r.eql(i,a)}function ec(r,e={}){let t=e,n=Dn("edwards",r,t,t.FpFnLE),{Fp:s,Fn:o}=n,i=n.CURVE,{h:a}=i;Ue(t,{},{uvRatio:"function"});let c=Po<<BigInt(o.BYTES*8)-oe,u=x=>s.create(x),l=t.uvRatio===void 0?(x,g)=>{try{return{isValid:!0,value:s.sqrt(s.div(x,g))}}catch{return{isValid:!1,value:lt}}}:t.uvRatio;if(!zl(s,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function f(x,g,y=!1){let E=y?oe:lt;return nr("coordinate "+x,g,E,c),g}function h(x){if(!(x instanceof d))throw new Error("EdwardsPoint expected")}class d{static BASE=new d(i.Gx,i.Gy,oe,u(i.Gx*i.Gy));static ZERO=new d(lt,oe,oe,lt);static Fp=s;static Fn=o;X;Y;Z;T;constructor(g,y,E,A){this.X=f("x",g),this.Y=f("y",y),this.Z=f("z",E,!0),this.T=f("t",A),Object.freeze(this)}static CURVE(){return i}static fromAffine(g){if(g instanceof d)throw new Error("extended point not allowed");let{x:y,y:E}=g||{};return f("x",y),f("y",E),new d(y,E,oe,u(y*E))}static fromBytes(g,y=!1){let E=s.BYTES,{a:A,d:N}=i;g=Or(q(g,E,"point")),Le(y,"zip215");let _=Or(g),F=g[E-1];_[E-1]=F&-129;let R=He(_),C=y?c:s.ORDER;nr("point.y",R,lt,C);let O=u(R*R),z=u(O-oe),K=u(N*O-A),{isValid:p,value:b}=l(z,K);if(!p)throw new Error("bad point: invalid y coordinate");let B=(b&oe)===oe,v=(F&128)!==0;if(!y&&b===lt&&v)throw new Error("bad point: x=0 and x_0=1");return v!==B&&(b=u(-b)),d.fromAffine({x:b,y:R})}static fromHex(g,y=!1){return d.fromBytes(rr(g),y)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(g=8,y=!0){return m.createCache(this,g),y||this.multiply(Po),this}assertValidity(){let g=this,{a:y,d:E}=i;if(g.is0())throw new Error("bad point: ZERO");let{X:A,Y:N,Z:_,T:F}=g,R=u(A*A),C=u(N*N),O=u(_*_),z=u(O*O),K=u(R*y),p=u(O*u(K+C)),b=u(z+u(E*u(R*C)));if(p!==b)throw new Error("bad point: equation left != right (1)");let B=u(A*N),v=u(_*F);if(B!==v)throw new Error("bad point: equation left != right (2)")}equals(g){h(g);let{X:y,Y:E,Z:A}=this,{X:N,Y:_,Z:F}=g,R=u(y*F),C=u(N*A),O=u(E*F),z=u(_*A);return R===C&&O===z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.X),this.Y,this.Z,u(-this.T))}double(){let{a:g}=i,{X:y,Y:E,Z:A}=this,N=u(y*y),_=u(E*E),F=u(Po*u(A*A)),R=u(g*N),C=y+E,O=u(u(C*C)-N-_),z=R+_,K=z-F,p=R-_,b=u(O*K),B=u(z*p),v=u(O*p),w=u(K*z);return new d(b,B,w,v)}add(g){h(g);let{a:y,d:E}=i,{X:A,Y:N,Z:_,T:F}=this,{X:R,Y:C,Z:O,T:z}=g,K=u(A*R),p=u(N*C),b=u(F*E*z),B=u(_*O),v=u((A+N)*(R+C)-K-p),w=B-b,S=B+b,T=u(p-y*K),k=u(v*w),L=u(S*T),D=u(v*T),P=u(w*S);return new d(k,L,P,D)}subtract(g){return h(g),this.add(g.negate())}multiply(g){if(!o.isValidNot0(g))throw new RangeError("invalid scalar: expected 1 <= sc < curve.n");let{p:y,f:E}=m.cached(this,g,A=>Lt(d,A));return Lt(d,[y,E])[0]}multiplyUnsafe(g){if(!o.isValid(g))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return g===lt?d.ZERO:this.is0()||g===oe?this:m.unsafe(this,g,y=>Lt(d,y))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return m.unsafe(this,i.n).is0()}toAffine(g){let y=this,E=g,{X:A,Y:N,Z:_}=y,F=y.is0();E==null&&(E=F?$l:s.inv(_));let R=u(A*E),C=u(N*E),O=s.mul(_,E);if(F)return{x:lt,y:oe};if(O!==oe)throw new Error("invZ was invalid");return{x:R,y:C}}clearCofactor(){return a===oe?this:this.multiplyUnsafe(a)}toBytes(){let{x:g,y}=this.toAffine(),E=s.toBytes(y);return E[E.length-1]|=g&oe?128:0,E}toHex(){return tr(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let m=new ar(d,o.BITS);return o.BITS>=8&&d.BASE.precompute(8),Object.freeze(d.prototype),Object.freeze(d),d}var On=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(e){this.ep=e}static fromBytes(e){Uo()}static fromHex(e){Uo()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(e){return this.ep.toAffine(e)}toHex(){return tr(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(e){return this.assertSame(e),this.init(this.ep.add(e.ep))}subtract(e){return this.assertSame(e),this.init(this.ep.subtract(e.ep))}multiply(e){return this.init(this.ep.multiply(e))}multiplyUnsafe(e){return this.init(this.ep.multiplyUnsafe(e))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(e,t){return this.ep.precompute(e,t),this}};function tc(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');let n=e,s=t;Ue(s,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",zip215:"boolean",mapToCurve:"function"});let{prehash:o}=s,{BASE:i,Fp:a,Fn:c}=r,u=n.outputLen,l=2*a.BYTES;if(u!==void 0&&(Re(u,"hash.outputLen"),u!==l))throw new Error(`hash.outputLen must be ${l}, got ${u}`);let f=s.randomBytes===void 0?Dr:s.randomBytes,h=s.adjustScalarBytes===void 0?p=>p:s.adjustScalarBytes,d=s.domain===void 0?(p,b,B)=>{if(Le(B,"phflag"),b.length||B)throw new Error("Contexts/pre-hash are not supported");return p}:s.domain;function m(p){return c.create(He(p))}function x(p){let b=R.secretKey;q(p,R.secretKey,"secretKey");let B=q(n(p),2*b,"hashedSecretKey"),v=h(B.slice(0,b)),w=B.slice(b,2*b),S=m(v);return{head:v,prefix:w,scalar:S}}function g(p){let{head:b,prefix:B,scalar:v}=x(p),w=i.multiply(v),S=w.toBytes();return{head:b,prefix:B,scalar:v,point:w,pointBytes:S}}function y(p){return g(p).pointBytes}function E(p=Uint8Array.of(),...b){let B=re(...b);return m(n(d(B,q(p,void 0,"context"),!!o)))}function A(p,b,B={}){p=q(p,void 0,"message"),o&&(p=o(p));let{prefix:v,scalar:w,pointBytes:S}=g(b),T=E(B.context,v,p),k=i.multiply(T).toBytes(),L=E(B.context,k,S,p),D=c.create(T+L*w);if(!c.isValid(D))throw new Error("sign failed: invalid s");let P=re(k,c.toBytes(D));return q(P,R.signature,"result")}let N={zip215:s.zip215};function _(p,b,B,v=N){let{context:w}=v,S=v.zip215===void 0?!!N.zip215:v.zip215,T=R.signature;p=q(p,T,"signature"),b=q(b,void 0,"message"),B=q(B,R.publicKey,"publicKey"),S!==void 0&&Le(S,"zip215"),o&&(b=o(b));let k=T/2,L=p.subarray(0,k),D=He(p.subarray(k,T)),P,$,V;try{P=r.fromBytes(B,S),$=r.fromBytes(L,S),V=i.multiplyUnsafe(D)}catch{return!1}if(!S&&P.isSmallOrder())return!1;let te=E(w,L,B,b);return $.add(P.multiplyUnsafe(te)).subtract(V).clearCofactor().is0()}let F=a.BYTES,R={secretKey:F,publicKey:F,signature:2*F,seed:F};function C(p){return p=p===void 0?f(R.seed):p,q(p,R.seed,"seed")}function O(p){return Ct(p)&&p.length===R.secretKey}function z(p,b){try{return!!r.fromBytes(p,b===void 0?N.zip215:b)}catch{return!1}}let K={getExtendedPublicKey:g,randomSecretKey:C,isValidSecretKey:O,isValidPublicKey:z,toMontgomery(p){let{y:b}=r.fromBytes(p),B=R.publicKey,v=B===32;if(!v&&B!==57)throw new Error("only defined for 25519 and 448");let w=v?a.div(oe+b,oe-b):a.div(b-oe,b+oe);return a.toBytes(w)},toMontgomerySecret(p){let b=R.secretKey;q(p,b);let B=n(p.subarray(0,b));return h(B).subarray(0,b)}};return Object.freeze(R),Object.freeze(K),Object.freeze({keygen:Fn(C,y),getPublicKey:y,sign:A,verify:_,utils:K,Point:r,lengths:R})}function Mr(r,e){if(Re(r),Re(e),e<0||e>4)throw new Error("invalid I2OSP length: "+e);if(r<0||r>2**(8*e)-1)throw new Error("invalid I2OSP input: "+r);let t=Array.from({length:e}).fill(0);for(let n=e-1;n>=0;n--)t[n]=r&255,r>>>=8;return new Uint8Array(t)}function Gl(r,e){let t=new Uint8Array(r.length);for(let n=0;n<r.length;n++)t[n]=r[n]^e[n];return t}function Zl(r){if(!Ct(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let e=typeof r=="string"?Rn(r):r;if(e.length===0)throw new Error("DST must be non-empty");return e}function jo(r,e,t,n){q(r),Re(t),e=Zl(e),e.length>255&&(e=n(re(Rn("H2C-OVERSIZE-DST-"),e)));let{outputLen:s,blockLen:o}=n,i=Math.ceil(t/s);if(t>65535||i>255)throw new Error("expand_message_xmd: invalid lenInBytes");let a=re(e,Mr(e.length,1)),c=new Uint8Array(o),u=Mr(t,2),l=new Array(i),f=n(re(c,r,u,Mr(0,1),a));l[0]=n(re(f,Mr(1,1),a));for(let d=1;d<i;d++){let m=[Gl(f,l[d-1]),Mr(d+1,1),a];l[d]=n(re(...m))}return re(...l).slice(0,t)}var rc="HashToScalar-";var Yl=BigInt(0),Xe=BigInt(1),nc=BigInt(2);var Wl=BigInt(5),Xl=BigInt(8),cr=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Go={p:cr,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Xl,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Jl(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=cr,a=r*r%o*r%o,c=G(a,nc,o)*a%o,u=G(c,Xe,o)*r%o,l=G(u,Wl,o)*u%o,f=G(l,e,o)*l%o,h=G(f,t,o)*f%o,d=G(h,n,o)*h%o,m=G(d,s,o)*d%o,x=G(m,s,o)*d%o,g=G(x,e,o)*l%o;return{pow_p_5_8:G(g,nc,o)*r%o,b2:a}}function Ql(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var qo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Zo(r,e){let t=cr,n=X(e*e*e,t),s=X(n*n*e,t),o=Jl(r*s).pow_p_5_8,i=X(r*n*o,t),a=X(e*i*i,t),c=i,u=X(i*qo,t),l=a===r,f=a===X(-r,t),h=a===X(-r*qo,t);return l&&(i=c),(f||h)&&(i=u),We(i,t)&&(i=X(-i,t)),{isValid:l||f,value:i}}var dt=ec(Go,{uvRatio:Zo}),ht=dt.Fp,ic=dt.Fn;function eh(r){return tc(dt,Ve,Object.assign({adjustScalarBytes:Ql,zip215:!0},r))}var Yo=eh({});var $o=qo,th=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),rh=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),nh=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),sh=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),sc=r=>Zo(Xe,r),oh=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),zo=r=>ht.create(He(r)&oh);function oc(r){let{d:e}=Go,t=cr,n=y=>ht.create(y),s=n($o*r*r),o=n((s+Xe)*nh),i=BigInt(-1),a=n((i-e*s)*n(s+e)),{isValid:c,value:u}=Zo(o,a),l=n(u*r);We(l,t)||(l=n(-l)),c||(u=l),c||(i=s);let f=n(i*(s-Xe)*sh-a),h=u*u,d=n((u+u)*a),m=n(f*th),x=n(Xe-h),g=n(Xe+h);return new dt(n(d*g),n(x*m),n(m*g),n(d*x))}var pt=class r extends On{static BASE=new r(dt.BASE);static ZERO=new r(dt.ZERO);static Fp=ht;static Fn=ic;constructor(e){super(e)}static fromAffine(e){return new r(dt.fromAffine(e))}assertSame(e){if(!(e instanceof r))throw new Error("RistrettoPoint expected")}init(e){return new r(e)}static fromBytes(e){we(e,32);let{a:t,d:n}=Go,s=cr,o=N=>ht.create(N),i=zo(e);if(!Da(ht.toBytes(i),e)||We(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(Xe+t*a),u=o(Xe-t*a),l=o(c*c),f=o(u*u),h=o(t*n*l-f),{isValid:d,value:m}=sc(o(h*f)),x=o(m*u),g=o(m*x*h),y=o((i+i)*x);We(y,s)&&(y=o(-y));let E=o(c*g),A=o(y*E);if(!d||We(A,s)||E===Yl)throw new Error("invalid ristretto255 encoding 2");return new r(new dt(y,E,Xe,A))}static fromHex(e){return r.fromBytes(_r(e))}toBytes(){let{X:e,Y:t,Z:n,T:s}=this.ep,o=cr,i=g=>ht.create(g),a=i(i(n+t)*i(n-t)),c=i(e*t),u=i(c*c),{value:l}=sc(i(a*u)),f=i(l*a),h=i(l*c),d=i(f*h*s),m;if(We(s*d,o)){let g=i(t*$o),y=i(e*$o);e=g,t=y,m=i(f*rh)}else m=h;We(e*d,o)&&(t=i(-t));let x=i((n-t)*m);return We(x,o)&&(x=i(-x)),ht.toBytes(x)}equals(e){this.assertSame(e);let{X:t,Y:n}=this.ep,{X:s,Y:o}=e.ep,i=u=>ht.create(u),a=i(t*o)===i(n*s),c=i(n*o)===i(t*s);return a||c}is0(){return this.equals(r.ZERO)}};Object.freeze(pt.BASE);Object.freeze(pt.ZERO);Object.freeze(pt.prototype);Object.freeze(pt);var ih=Object.freeze({Point:pt,hashToCurve(r,e){let t=e?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":e.DST,n=jo(r,t,64,Ve);return ih.deriveToCurve(n)},hashToScalar(r,e={DST:rc}){let t=jo(r,e.DST,64,Ve);return ic.create(He(t))},deriveToCurve(r){we(r,64);let e=zo(r.subarray(0,32)),t=oc(e),n=zo(r.subarray(32,64)),s=oc(n);return new pt(t.add(s))}});var fr=32,Ie=64,ah=32;var ur,ac=(async()=>{try{return await Q.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function ch(r,e){let t;r.length===Ie?t=r.subarray(0,32):t=r;let n={crv:"Ed25519",kty:"OKP",x:j(r.subarray(32),"base64url"),d:j(t,"base64url"),ext:!0,key_ops:["sign"]},s=await Q.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await Q.get().subtle.sign({name:"Ed25519"},s,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(o,0,o.byteLength)}function uh(r,e){let t=r.subarray(0,ah);return Yo.sign(e instanceof Uint8Array?e:e.subarray(),t)}async function cc(r,e){return ur==null&&(ur=await ac),ur?ch(r,e):uh(r,e)}async function fh(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await Q.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Q.get().subtle.verify({name:"Ed25519"},n,e,t instanceof Uint8Array?t:t.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function lh(r,e,t){return Yo.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function uc(r,e,t){return ur==null&&(ur=await ac),ur?fh(r,e,t):lh(r,e,t)}function lr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Kn=class{type="Ed25519";raw;constructor(e){this.raw=jr(e,fr)}toMultihash(){return Et.digest(Jt(this))}toCID(){return Se.createV1(114,this.toMultihash())}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let s=uc(this.raw,t,e);return lr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},Pr=class{type="Ed25519";raw;publicKey;constructor(e,t){this.raw=jr(e,Ie),this.publicKey=new Kn(t)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}sign(e,t){t?.signal?.throwIfAborted();let n=cc(this.raw,e);return lr(n)?n.then(s=>(t?.signal?.throwIfAborted(),s)):(t?.signal?.throwIfAborted(),n)}};function Wo(r){if(r.length>Ie){r=jr(r,Ie+fr);let n=r.subarray(0,Ie),s=r.subarray(Ie,r.length);return new Pr(n,s)}r=jr(r,Ie);let e=r.subarray(0,Ie),t=r.subarray(fr);return new Pr(e,t)}function jr(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new U(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}var hh=Math.pow(2,7),dh=Math.pow(2,14),ph=Math.pow(2,21),lc=Math.pow(2,28),hc=Math.pow(2,35),dc=Math.pow(2,42),pc=Math.pow(2,49),ge=128,gt=127;function qr(r){if(r<hh)return 1;if(r<dh)return 2;if(r<ph)return 3;if(r<lc)return 4;if(r<hc)return 5;if(r<dc)return 6;if(r<pc)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function gc(r,e,t=0){switch(qr(r)){case 8:e[t++]=r&255|ge,r/=128;case 7:e[t++]=r&255|ge,r/=128;case 6:e[t++]=r&255|ge,r/=128;case 5:e[t++]=r&255|ge,r/=128;case 4:e[t++]=r&255|ge,r>>>=7;case 3:e[t++]=r&255|ge,r>>>=7;case 2:e[t++]=r&255|ge,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function mc(r,e){let t=r[e],n=0;if(n+=t>,t<ge||(t=r[e+1],n+=(t>)<<7,t<ge)||(t=r[e+2],n+=(t>)<<14,t<ge)||(t=r[e+3],n+=(t>)<<21,t<ge)||(t=r[e+4],n+=(t>)*lc,t<ge)||(t=r[e+5],n+=(t>)*hc,t<ge)||(t=r[e+6],n+=(t>)*dc,t<ge)||(t=r[e+7],n+=(t>)*pc,t<ge))return n;throw new RangeError("Could not decode varint")}var Xo=new Float32Array([-0]),mt=new Uint8Array(Xo.buffer);function yc(r,e,t){Xo[0]=r,e[t]=mt[0],e[t+1]=mt[1],e[t+2]=mt[2],e[t+3]=mt[3]}function bc(r,e){return mt[0]=r[e],mt[1]=r[e+1],mt[2]=r[e+2],mt[3]=r[e+3],Xo[0]}var Jo=new Float64Array([-0]),le=new Uint8Array(Jo.buffer);function wc(r,e,t){Jo[0]=r,e[t]=le[0],e[t+1]=le[1],e[t+2]=le[2],e[t+3]=le[3],e[t+4]=le[4],e[t+5]=le[5],e[t+6]=le[6],e[t+7]=le[7]}function xc(r,e){return le[0]=r[e],le[1]=r[e+1],le[2]=r[e+2],le[3]=r[e+3],le[4]=r[e+4],le[5]=r[e+5],le[6]=r[e+6],le[7]=r[e+7],Jo[0]}var gh=BigInt(Number.MAX_SAFE_INTEGER),mh=BigInt(Number.MIN_SAFE_INTEGER),Ae=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 Rt;if(e<gh&&e>mh)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>vc&&(s=0n,++n>vc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Rt;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):Rt}},Rt=new Ae(0,0);Rt.toBigInt=function(){return 0n};Rt.zzEncode=Rt.zzDecode=function(){return this};Rt.length=function(){return 1};var vc=4294967296n;function Ec(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 Bc(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 Qo(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 De(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Vn(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ei=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,De(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 De(this,4);return Vn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw De(this,4);return Vn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw De(this,4);let e=bc(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw De(this,4);let e=xc(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 De(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Bc(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw De(this,e);this.pos+=e}else do if(this.pos>=this.len)throw De(this);while((this.buf[this.pos++]&128)!==0);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 Ae(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 De(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 De(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 De(this,8);let e=Vn(this.buf,this.pos+=4),t=Vn(this.buf,this.pos+=4);return new Ae(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=mc(this.buf,this.pos);return this.pos+=qr(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 $r(r){return new ei(r instanceof Uint8Array?r:r.subarray())}function Hn(r,e,t){let n=$r(r);return e.decode(n,void 0,t)}function ti(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return Be(i);s+i>e&&(n=Be(e),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ut=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function ri(){}var si=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},yh=ti();function bh(r){return globalThis.Buffer!=null?Be(r):yh(r)}var Gr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ut(ri,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Ut(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new oi((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(Mn,10,Ae.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ae.fromBigInt(e);return this._push(Mn,t.length(),t)}uint64Number(e){return this._push(gc,qr(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=Ae.fromBigInt(e).zzEncode();return this._push(Mn,t.length(),t)}sint64Number(e){let t=Ae.fromNumber(e).zzEncode();return this._push(Mn,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(ni,1,e?1:0)}fixed32(e){return this._push(zr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ae.fromBigInt(e);return this._push(zr,4,t.lo)._push(zr,4,t.hi)}fixed64Number(e){let t=Ae.fromNumber(e);return this._push(zr,4,t.lo)._push(zr,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(yc,4,e)}double(e){return this._push(wc,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(ni,1,0):this.uint32(t)._push(xh,t,e)}string(e){let t=Ec(e);return t!==0?this.uint32(t)._push(Qo,t,e):this._push(ni,1,0)}fork(){return this.states=new si(this),this.head=this.tail=new Ut(ri,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 Ut(ri,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=bh(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function ni(r,e,t){e[t]=r&255}function wh(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var oi=class extends Ut{next;constructor(e,t){super(wh,e,t),this.next=void 0}};function Mn(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 zr(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 xh(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Gr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(vh,e,r),this},Gr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Eh,e,r),this});function vh(r,e,t){e.set(r,t)}function Eh(r,e,t){r.length<40?Qo(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(H(r),t)}function ii(){return new Gr}function Pn(r,e){let t=ii();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}function*jn(r,e,t){let n=$r(r);yield*e.stream(n,void 0,"$",t)}var qn={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function $n(r,e,t,n,s){return{name:r,type:e,encode:t,decode:n,stream:s}}function ai(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(i,a){let c=e(i);a.int32(c)},n=function(i){let a=i.int32();return e(a)},s=function*(i){let a=i.int32();yield e(a)};return $n("enum",qn.VARINT,t,n,s)}function zn(r,e,t){return $n("message",qn.LENGTH_DELIMITED,r,e,t)}var J;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(J||(J={}));var ci;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ci||(ci={}));(function(r){r.codec=()=>ai(ci)})(J||(J={}));var yt;(function(r){let e;r.codec=()=>(e==null&&(e=zn((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),J.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=J.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:J.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Pn(o,r.codec())}r.encode=t;function n(o,i){return Hn(o,r.codec(),i)}r.decode=n;function s(o,i){return jn(o,r.codec(),i)}r.stream=s})(yt||(yt={}));var Zr;(function(r){let e;r.codec=()=>(e==null&&(e=zn((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),J.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=J.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:J.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Pn(o,r.codec())}r.encode=t;function n(o,i){return Hn(o,r.codec(),i)}r.decode=n;function s(o,i){return jn(o,r.codec(),i)}r.stream=s})(Zr||(Zr={}));function Dt(r){if(isNaN(r)||r<=0)throw new U("random bytes length must be a Number bigger than 0");return Sn(r)}var Wr={};he(Wr,{MAX_RSA_KEY_SIZE:()=>ui,generateRSAKeyPair:()=>Tc,jwkToJWKKeyPair:()=>Nc,jwkToPkcs1:()=>kh,jwkToPkix:()=>di,jwkToRSAPrivateKey:()=>mi,pkcs1MessageToJwk:()=>li,pkcs1MessageToRSAPrivateKey:()=>Gn,pkcs1ToJwk:()=>Sh,pkcs1ToRSAPrivateKey:()=>pi,pkixMessageToJwk:()=>hi,pkixMessageToRSAPublicKey:()=>gi,pkixToJwk:()=>Ih,pkixToRSAPublicKey:()=>Cc});var hr=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=Wr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return Se.createV1(114,this._multihash)}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}verify(e,t,n){return Ic(this.jwk,t,e,n)}},Yr=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=Wr.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}sign(e,t){return kc(this.jwk,e,t)}};var ui=8192,fi=18,Bh=1062,Ah=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Sh(r){let e=Te(r);return li(e)}function li(r){return{n:j(r[1],"base64url"),e:j(r[2],"base64url"),d:j(r[3],"base64url"),p:j(r[4],"base64url"),q:j(r[5],"base64url"),dp:j(r[6],"base64url"),dq:j(r[7],"base64url"),qi:j(r[8],"base64url"),kty:"RSA"}}function kh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new U("JWK was missing components");return Ne([pe(Uint8Array.from([0])),pe(H(r.n,"base64url")),pe(H(r.e,"base64url")),pe(H(r.d,"base64url")),pe(H(r.p,"base64url")),pe(H(r.q,"base64url")),pe(H(r.dp,"base64url")),pe(H(r.dq,"base64url")),pe(H(r.qi,"base64url"))]).subarray()}function Ih(r){let e=Te(r,{offset:0});return hi(e)}function hi(r){let e=Te(r[1],{offset:0});return{kty:"RSA",n:j(e[0],"base64url"),e:j(e[1],"base64url")}}function di(r){if(r.n==null||r.e==null)throw new U("JWK was missing components");return Ne([Ah,Nr(Ne([pe(H(r.n,"base64url")),pe(H(r.e,"base64url"))]))]).subarray()}function pi(r){let e=Te(r);return Gn(e)}function Gn(r){let e=li(r);return mi(e)}function Cc(r,e){if(r.byteLength>=Bh)throw new Pt("Key size is too large");let t=Te(r,{offset:0});return gi(t,r,e)}function gi(r,e,t){let n=hi(r);if(t==null){let s=ft(yt.encode({Type:J.RSA,Data:e}));t=Oe(fi,s)}return new hr(n,t)}function mi(r){if(Lc(r)>ui)throw new U("Key size is too large");let e=Nc(r),t=ft(yt.encode({Type:J.RSA,Data:di(e.publicKey)})),n=Oe(fi,t);return new Yr(e.privateKey,new hr(e.publicKey,n))}async function Tc(r){if(r>ui)throw new U("Key size is too large");let e=await _c(r),t=ft(yt.encode({Type:J.RSA,Data:di(e.publicKey)})),n=Oe(fi,t);return new Yr(e.privateKey,new hr(e.publicKey,n))}function Nc(r){if(r==null)throw new U("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function _c(r,e){let t=await Q.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let n=await Ch(t,e);return{privateKey:n[0],publicKey:n[1]}}async function kc(r,e,t){let n=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let s=await Q.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,e instanceof Uint8Array?e:e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function Ic(r,e,t,n){let s=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Q.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,e,t instanceof Uint8Array?t:t.subarray());return n?.signal?.throwIfAborted(),o}async function Ch(r,e){if(r.privateKey==null||r.publicKey==null)throw new U("Private and public key are required");let t=await Promise.all([Q.get().subtle.exportKey("jwk",r.privateKey),Q.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function Lc(r){if(r.kty!=="RSA")throw new U("invalid key type");if(r.n==null)throw new U("invalid key modulus");return H(r.n,"base64url").length*8}var Zn=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(e,t){if(Qt(e),we(t,void 0,"key"),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 n=this.blockLen,s=new Uint8Array(n);s.set(t.length>n?e.create().update(t).digest():t);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=e.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),xe(s)}update(e){return er(this),this.iHash.update(e),this}digestInto(e){er(this),En(e,this),this.finished=!0;let t=e.subarray(0,this.outputLen);this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(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}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Yn=(()=>{let r=((e,t,n)=>new Zn(e,t).update(n).digest());return r.create=(e,t)=>new Zn(e,t),r})();var Rc=(r,e)=>(r+(r>=0?e:-e)/Uc)/e;function Th(r,e,t){nr("scalar",r,Me,t);let[[n,s],[o,i]]=e,a=Rc(i*r,t),c=Rc(-s*r,t),u=r-a*n-c*o,l=-a*s-c*i,f=u<Me,h=l<Me;f&&(u=-u),h&&(l=-l);let d=Kr(Math.ceil(sr(t)/2))+bt;if(u<Me||u>=d||l<Me||l>=d)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:f,k1:u,k2neg:h,k2:l}}function bi(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function yi(r,e){Ue(r);let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return Le(t.lowS,"lowS"),Le(t.prehash,"prehash"),t.format!==void 0&&bi(t.format),t}var wi=class extends Error{constructor(e=""){super(e)}},Fe={Err:wi,_tlv:{encode:(r,e)=>{let{Err:t}=Fe;if(Re(r,"tag"),r<0||r>255)throw new t("tlv.encode: wrong tag");if(typeof e!="string")throw new TypeError('"data" expected string, got type='+typeof e);if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=Fr(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let o=n>127?Fr(s.length/2|128):"";return Fr(r)+o+s+e},decode(r,e){let{Err:t}=Fe;e=q(e,void 0,"DER data");let n=0;if(r<0||r>255)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let u=e.subarray(n,n+c);if(u.length!==c)throw new t("tlv.decode: length bytes not complete");if(u[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=Fe;if(_n(r),r<Me)throw new e("integer: negative integers are not allowed");let t=Fr(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=Fe;if(r.length<1)throw new e("invalid signature integer: empty");if(r[0]&128)throw new e("invalid signature integer: negative");if(r.length>1&&r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Tt(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=Fe,s=q(r,void 0,"signature"),{v:o,l:i}=n.decode(48,s);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(u)}},hexFromSig(r){let{_tlv:e,_int:t}=Fe,n=e.encode(2,t.encode(r.r)),s=e.encode(2,t.encode(r.s)),o=n+s;return e.encode(48,o)}};Object.freeze(Fe._tlv);Object.freeze(Fe._int);Object.freeze(Fe);var Me=BigInt(0),bt=BigInt(1),Uc=BigInt(2),Wn=BigInt(3),Nh=BigInt(4);function Dc(r,e={}){let t=Dn("weierstrass",r,e),n=t.Fp,s=t.Fn,o=t.CURVE,{h:i,n:a}=o;Ue(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c,allowInfinityPoint:u}=e;if(c&&(!n.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=Oc(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function h(K,p,b){if(u&&p.is0())return Uint8Array.of(0);let{x:B,y:v}=p.toAffine(),w=n.toBytes(B);if(Le(b,"isCompressed"),b){f();let S=!n.isOdd(v);return re(Fc(S),w)}else return re(Uint8Array.of(4),w,n.toBytes(v))}function d(K){q(K,void 0,"Point");let{publicKey:p,publicKeyUncompressed:b}=l,B=K.length,v=K[0],w=K.subarray(1);if(u&&B===1&&v===0)return{x:n.ZERO,y:n.ZERO};if(B===p&&(v===2||v===3)){let S=n.fromBytes(w);if(!n.isValid(S))throw new Error("bad point: is not on curve, wrong x");let T=g(S),k;try{k=n.sqrt(T)}catch(P){let $=P instanceof Error?": "+P.message:"";throw new Error("bad point: is not on curve, sqrt error"+$)}f();let L=n.isOdd(k);return(v&1)===1!==L&&(k=n.neg(k)),{x:S,y:k}}else if(B===b&&v===4){let S=n.BYTES,T=n.fromBytes(w.subarray(0,S)),k=n.fromBytes(w.subarray(S,S*2));if(!y(T,k))throw new Error("bad point: is not on curve");return{x:T,y:k}}else throw new Error(`bad point: got length ${B}, expected compressed=${p} or uncompressed=${b}`)}let m=e.toBytes===void 0?h:e.toBytes,x=e.fromBytes===void 0?d:e.fromBytes;function g(K){let p=n.sqr(K),b=n.mul(p,K);return n.add(n.add(b,n.mul(K,o.a)),o.b)}function y(K,p){let b=n.sqr(p),B=g(K);return n.eql(b,B)}if(!y(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let E=n.mul(n.pow(o.a,Wn),Nh),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(E,A)))throw new Error("bad curve params: a or b");function N(K,p,b=!1){if(!n.isValid(p)||b&&n.is0(p))throw new Error(`bad point coordinate ${K}`);return p}function _(K){if(!(K instanceof C))throw new Error("Weierstrass Point expected")}function F(K){if(!c||!c.basises)throw new Error("no endo");return Th(K,c.basises,s.ORDER)}function R(K,p,b,B,v){return b=new C(n.mul(b.X,K),b.Y,b.Z),p=Hr(B,p),b=Hr(v,b),p.add(b)}class C{static BASE=new C(o.Gx,o.Gy,n.ONE);static ZERO=new C(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(p,b,B){this.X=N("x",p),this.Y=N("y",b,!0),this.Z=N("z",B),Object.freeze(this)}static CURVE(){return o}static fromAffine(p){let{x:b,y:B}=p||{};if(!p||!n.isValid(b)||!n.isValid(B))throw new Error("invalid affine point");if(p instanceof C)throw new Error("projective point not allowed");return n.is0(b)&&n.is0(B)?C.ZERO:new C(b,B,n.ONE)}static fromBytes(p){let b=C.fromAffine(x(q(p,void 0,"point")));return b.assertValidity(),b}static fromHex(p){return C.fromBytes(rr(p))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(p=8,b=!0){return z.createCache(this,p),b||this.multiply(Wn),this}assertValidity(){let p=this;if(p.is0()){if(e.allowInfinityPoint&&n.is0(p.X)&&n.eql(p.Y,n.ONE)&&n.is0(p.Z))return;throw new Error("bad point: ZERO")}let{x:b,y:B}=p.toAffine();if(!n.isValid(b)||!n.isValid(B))throw new Error("bad point: x or y not field elements");if(!y(b,B))throw new Error("bad point: equation left != right");if(!p.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(p)}equals(p){_(p);let{X:b,Y:B,Z:v}=this,{X:w,Y:S,Z:T}=p,k=n.eql(n.mul(b,T),n.mul(w,v)),L=n.eql(n.mul(B,T),n.mul(S,v));return k&&L}negate(){return new C(this.X,n.neg(this.Y),this.Z)}double(){let{a:p,b}=o,B=n.mul(b,Wn),{X:v,Y:w,Z:S}=this,T=n.ZERO,k=n.ZERO,L=n.ZERO,D=n.mul(v,v),P=n.mul(w,w),$=n.mul(S,S),V=n.mul(v,w);return V=n.add(V,V),L=n.mul(v,S),L=n.add(L,L),T=n.mul(p,L),k=n.mul(B,$),k=n.add(T,k),T=n.sub(P,k),k=n.add(P,k),k=n.mul(T,k),T=n.mul(V,T),L=n.mul(B,L),$=n.mul(p,$),V=n.sub(D,$),V=n.mul(p,V),V=n.add(V,L),L=n.add(D,D),D=n.add(L,D),D=n.add(D,$),D=n.mul(D,V),k=n.add(k,D),$=n.mul(w,S),$=n.add($,$),D=n.mul($,V),T=n.sub(T,D),L=n.mul($,P),L=n.add(L,L),L=n.add(L,L),new C(T,k,L)}add(p){_(p);let{X:b,Y:B,Z:v}=this,{X:w,Y:S,Z:T}=p,k=n.ZERO,L=n.ZERO,D=n.ZERO,P=o.a,$=n.mul(o.b,Wn),V=n.mul(b,w),te=n.mul(B,S),ne=n.mul(v,T),se=n.add(b,B),W=n.add(w,S);se=n.mul(se,W),W=n.add(V,te),se=n.sub(se,W),W=n.add(b,v);let ye=n.add(w,T);return W=n.mul(W,ye),ye=n.add(V,ne),W=n.sub(W,ye),ye=n.add(B,v),k=n.add(S,T),ye=n.mul(ye,k),k=n.add(te,ne),ye=n.sub(ye,k),D=n.mul(P,W),k=n.mul($,ne),D=n.add(k,D),k=n.sub(te,D),D=n.add(te,D),L=n.mul(k,D),te=n.add(V,V),te=n.add(te,V),ne=n.mul(P,ne),W=n.mul($,W),te=n.add(te,ne),ne=n.sub(V,ne),ne=n.mul(P,ne),W=n.add(W,ne),V=n.mul(te,W),L=n.add(L,V),V=n.mul(ye,W),k=n.mul(se,k),k=n.sub(k,V),V=n.mul(se,te),D=n.mul(ye,D),D=n.add(D,V),new C(k,L,D)}subtract(p){return _(p),this.add(p.negate())}is0(){return this.equals(C.ZERO)}multiply(p){let{endo:b}=e;if(!s.isValidNot0(p))throw new RangeError("invalid scalar: out of range");let B,v,w=S=>z.cached(this,S,T=>Lt(C,T));if(b){let{k1neg:S,k1:T,k2neg:k,k2:L}=F(p),{p:D,f:P}=w(T),{p:$,f:V}=w(L);v=P.add(V),B=R(b.beta,D,$,S,k)}else{let{p:S,f:T}=w(p);B=S,v=T}return Lt(C,[B,v])[0]}multiplyUnsafe(p){let{endo:b}=e,B=this,v=p;if(!s.isValid(v))throw new RangeError("invalid scalar: out of range");if(v===Me||B.is0())return C.ZERO;if(v===bt)return B;if(z.hasCache(this))return this.multiply(v);if(b){let{k1neg:w,k1:S,k2neg:T,k2:k}=F(v),{p1:L,p2:D}=Qa(C,B,S,k);return R(b.beta,L,D,w,T)}else return z.unsafe(B,v)}toAffine(p){let b=this,B=p,{X:v,Y:w,Z:S}=b;if(n.eql(S,n.ONE))return{x:v,y:w};let T=b.is0();B==null&&(B=T?n.ONE:n.inv(S));let k=n.mul(v,B),L=n.mul(w,B),D=n.mul(S,B);if(T)return{x:n.ZERO,y:n.ZERO};if(!n.eql(D,n.ONE))throw new Error("invZ was invalid");return{x:k,y:L}}isTorsionFree(){let{isTorsionFree:p}=e;return i===bt?!0:p?p(C,this):z.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:p}=e;return i===bt?this:p?p(C,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===bt?this.is0():this.clearCofactor().is0()}toBytes(p=!0){return Le(p,"isCompressed"),this.assertValidity(),m(C,this,p)}toHex(p=!0){return tr(this.toBytes(p))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let O=s.BITS,z=new ar(C,e.endo?Math.ceil(O/2):O);return O>=8&&C.BASE.precompute(8),Object.freeze(C.prototype),Object.freeze(C),C}function Fc(r){return Uint8Array.of(r?2:3)}function Oc(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function _h(r,e={}){let{Fn:t}=r,n=e.randomBytes===void 0?Dr:e.randomBytes,s=Object.assign(Oc(r.Fp,t),{seed:Math.max(Oo(t.ORDER),16)});function o(d){try{let m=t.fromBytes(d);return t.isValidNot0(m)}catch{return!1}}function i(d,m){let{publicKey:x,publicKeyUncompressed:g}=s;try{let y=d.length;return m===!0&&y!==x||m===!1&&y!==g?!1:!!r.fromBytes(d)}catch{return!1}}function a(d){return d=d===void 0?n(s.seed):d,Ko(q(d,s.seed,"seed"),t.ORDER)}function c(d,m=!0){return r.BASE.multiply(t.fromBytes(d)).toBytes(m)}function u(d){let{secretKey:m,publicKey:x,publicKeyUncompressed:g}=s,y=t._lengths;if(!Ct(d))return;let E=q(d,void 0,"key").length,A=E===x||E===g,N=E===m||!!y?.includes(E);if(!(A&&N))return A}function l(d,m,x=!0){if(u(d)===!0)throw new Error("first arg must be private key");if(u(m)===!1)throw new Error("second arg must be public key");let g=t.fromBytes(d);return r.fromBytes(m).multiply(g).toBytes(x)}let f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},h=Fn(a,c);return Object.freeze(f),Object.freeze(s),Object.freeze({getPublicKey:c,getSharedSecret:l,keygen:h,Point:r,utils:f,lengths:s})}function Kc(r,e,t={}){let n=e;Qt(n),Ue(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let s=t.randomBytes===void 0?Dr:t.randomBytes,o=t.hmac===void 0?(v,w)=>Yn(n,v,w):t.hmac,{Fp:i,Fn:a}=r,{ORDER:c,BITS:u}=a,{keygen:l,getPublicKey:f,getSharedSecret:h,utils:d,lengths:m}=_h(r,t),x={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},g=c*Uc+bt<i.ORDER;function y(v){let w=c>>bt;return v>w}function E(v,w){if(!a.isValidNot0(w))throw new Error(`invalid signature ${v}: out of range 1..Point.Fn.ORDER`);return w}function A(){if(g)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function N(v,w){bi(w);let S=m.signature,T=w==="compact"?S:w==="recovered"?S+1:void 0;return q(v,T)}class _{r;s;recovery;constructor(w,S,T){if(this.r=E("r",w),this.s=E("s",S),T!=null){if(A(),![0,1,2,3].includes(T))throw new Error("invalid recovery id");this.recovery=T}Object.freeze(this)}static fromBytes(w,S=x.format){N(w,S);let T;if(S==="der"){let{r:P,s:$}=Fe.toSig(q(w));return new _(P,$)}S==="recovered"&&(T=w[0],S="compact",w=w.subarray(1));let k=m.signature/2,L=w.subarray(0,k),D=w.subarray(k,k*2);return new _(a.fromBytes(L),a.fromBytes(D),T)}static fromHex(w,S){return this.fromBytes(rr(w),S)}assertRecovery(){let{recovery:w}=this;if(w==null)throw new Error("invalid recovery id: must be present");return w}addRecoveryBit(w){return new _(this.r,this.s,w)}recoverPublicKey(w){let{r:S,s:T}=this,k=this.assertRecovery(),L=k===2||k===3?S+c:S;if(!i.isValid(L))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let D=i.toBytes(L),P=r.fromBytes(re(Fc((k&1)===0),D)),$=a.inv(L),V=R(q(w,void 0,"msgHash")),te=a.create(-V*$),ne=a.create(T*$),se=r.BASE.multiplyUnsafe(te).add(P.multiplyUnsafe(ne));if(se.is0())throw new Error("invalid recovery: point at infinify");return se.assertValidity(),se}hasHighS(){return y(this.s)}toBytes(w=x.format){if(bi(w),w==="der")return rr(Fe.hexFromSig(this));let{r:S,s:T}=this,k=a.toBytes(S),L=a.toBytes(T);return w==="recovered"?(A(),re(Uint8Array.of(this.assertRecovery()),k,L)):re(k,L)}toHex(w){return tr(this.toBytes(w))}}Object.freeze(_.prototype),Object.freeze(_);let F=t.bits2int===void 0?function(w){if(w.length>8192)throw new Error("input is too large");let S=Tt(w),T=w.length*8-u;return T>0?S>>BigInt(T):S}:t.bits2int,R=t.bits2int_modN===void 0?function(w){return a.create(F(w))}:t.bits2int_modN,C=Kr(u);function O(v){return nr("num < 2^"+u,v,Me,C),a.toBytes(v)}function z(v,w){return q(v,void 0,"message"),w?q(n(v),void 0,"prehashed message"):v}function K(v,w,S){let{lowS:T,prehash:k,extraEntropy:L}=yi(S,x);v=z(v,k);let D=R(v),P=a.fromBytes(w);if(!a.isValidNot0(P))throw new Error("invalid private key");let $=[O(P),O(D)];if(L!=null&&L!==!1){let se=L===!0?s(m.secretKey):L;$.push(q(se,void 0,"extraEntropy"))}let V=re(...$),te=D;function ne(se){let W=F(se);if(!a.isValidNot0(W))return;let ye=a.inv(W),Mt=r.BASE.multiply(W).toAffine(),br=a.create(Mt.x);if(br===Me)return;let dn=a.create(ye*a.create(te+br*P));if(dn===Me)return;let Ui=(Mt.x===br?0:2)|Number(Mt.y&bt),Di=dn;return T&&y(dn)&&(Di=a.neg(dn),Ui^=1),new _(br,Di,g?void 0:Ui)}return{seed:V,k2sig:ne}}function p(v,w,S={}){let{seed:T,k2sig:k}=K(v,w,S);return Fa(n.outputLen,a.BYTES,o)(T,k).toBytes(S.format)}function b(v,w,S,T={}){let{lowS:k,prehash:L,format:D}=yi(T,x);if(S=q(S,void 0,"publicKey"),w=z(w,L),!Ct(v)){let P=v instanceof _?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+P)}N(v,D);try{let P=_.fromBytes(v,D),$=r.fromBytes(S);if(k&&P.hasHighS())return!1;let{r:V,s:te}=P,ne=R(w),se=a.inv(te),W=a.create(ne*se),ye=a.create(V*se),Mt=r.BASE.multiplyUnsafe(W).add($.multiplyUnsafe(ye));return Mt.is0()?!1:a.create(Mt.x)===V}catch{return!1}}function B(v,w,S={}){let{prehash:T}=yi(S,x);return w=z(w,T),_.fromBytes(v,"recovered").recoverPublicKey(w).toBytes()}return Object.freeze({keygen:l,getPublicKey:f,getSharedSecret:h,utils:d,lengths:m,Point:r,sign:p,verify:b,recoverPublicKey:B,Signature:_,hash:n})}var vi={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Lh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Vc=BigInt(2);function Rh(r){let e=vi.p,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%e,l=u*u*r%e,f=G(l,t,e)*l%e,h=G(f,t,e)*l%e,d=G(h,Vc,e)*u%e,m=G(d,s,e)*d%e,x=G(m,o,e)*m%e,g=G(x,a,e)*x%e,y=G(g,c,e)*g%e,E=G(y,a,e)*x%e,A=G(E,t,e)*l%e,N=G(A,i,e)*m%e,_=G(N,n,e)*u%e,F=G(_,Vc,e);if(!xi.eql(xi.sqr(F),r))throw new Error("Cannot find square root");return F}var xi=or(vi.p,{sqrt:Rh}),Uh=Dc(vi,{Fp:xi,endo:Lh}),Pe=Kc(Uh,ft);var Hc=32;function Mc(r,e,t){let n=Wt.digest(e instanceof Uint8Array?e:e.subarray());if(lr(n))return n.then(({digest:s})=>(t?.signal?.throwIfAborted(),Pe.sign(s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new xr(String(s))});try{return Pe.sign(n.digest,r,{prehash:!1,format:"der"})}catch(s){throw new xr(String(s))}}function Pc(r,e,t,n){let s=Wt.digest(t instanceof Uint8Array?t:t.subarray());if(lr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Pe.verify(e,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new vr(String(o))});try{return n?.signal?.throwIfAborted(),Pe.verify(e,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new vr(String(o))}}var Xn=class{type="secp256k1";raw;_key;constructor(e){this._key=$c(e),this.raw=jc(this._key)}toMultihash(){return Et.digest(Jt(this))}toCID(){return Se.createV1(114,this.toMultihash())}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}verify(e,t,n){return Pc(this._key,t,e,n)}},Jn=class{type="secp256k1";raw;publicKey;constructor(e,t){this.raw=qc(e),this.publicKey=new Xn(t??zc(e))}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:be(this.raw,e.raw)}sign(e,t){return Mc(this.raw,e,t)}};function Ei(r){return new Jn(r)}function jc(r){return Pe.Point.fromBytes(r).toBytes()}function qc(r){try{return Pe.getPublicKey(r,!0),r}catch(e){throw new Er(String(e))}}function $c(r){try{return Pe.Point.fromBytes(r),r}catch(e){throw new Pt(String(e))}}function zc(r){try{return Pe.getPublicKey(r,!0)}catch(e){throw new Er(String(e))}}function Jt(r){return yt.encode({Type:J[r.type],Data:r.raw})}function Gc(r){let e=Zr.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case J.RSA:return pi(t);case J.Ed25519:return Wo(t);case J.secp256k1:return Ei(t);case J.ECDSA:return ya(t);default:throw new jt}}function Zc(r){if(r.byteLength===Ie)return Wo(r);if(r.byteLength===Hc)return Ei(r);let e=Te(r),t=e[2]?.[0];if(t===ra||t===na||t===sa)return xo(e);if(e.length>8)return Gn(e);throw new U("Could not extract private key from raw bytes")}function Ft(r){return Zr.encode({Type:J[r.type],Data:r.raw})}var Xr=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),wt=new Uint32Array(80),Bi=class extends St{A=Xr[0]|0;B=Xr[1]|0;C=Xr[2]|0;D=Xr[3]|0;E=Xr[4]|0;constructor(){super(64,20,8,!1)}get(){let{A:e,B:t,C:n,D:s,E:o}=this;return[e,t,n,s,o]}set(e,t,n,s,o){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=o|0}process(e,t){for(let c=0;c<16;c++,t+=4)wt[c]=e.getUint32(t,!1);for(let c=16;c<80;c++)wt[c]=Bn(wt[c-3]^wt[c-8]^wt[c-14]^wt[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let u,l;c<20?(u=kn(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=In(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Bn(n,5)+u+a+l+wt[c]|0;a=i,i=o,o=Bn(s,30),s=n,n=f}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,this.set(n,s,o,i,a)}roundClean(){xe(wt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0),xe(this.buffer)}},Yc=Lr(()=>new Bi);function Wc(r,e,t,n){Qt(r);let s=Aa({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(ke(o,"c"),ke(i,"dkLen"),ke(a,"asyncTick"),o<1)throw new Error("iterations (c) must be >= 1");if(i<1)throw new Error('"dkLen" must be >= 1');if(i>(2**32-1)*r.outputLen)throw new Error("derived key too long");let c=Eo(e,"password"),u=Eo(t,"salt"),l=new Uint8Array(i),f=Yn.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function Xc(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),xe(s),t}function Jc(r,e,t,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Wc(r,e,t,n),u,l=new Uint8Array(4),f=At(l),h=new Uint8Array(a.outputLen);for(let d=1,m=0;m<o;d++,m+=a.outputLen){let x=i.subarray(m,m+a.outputLen);f.setInt32(0,d,!1),(u=c._cloneInto(u)).update(l).digestInto(h),x.set(h.subarray(0,x.length));for(let g=1;g<s;g++){a._cloneInto(u).update(h).digestInto(h);for(let y=0;y<x.length;y++)x[y]^=h[y]}}return Xc(a,c,i,u,h)}async function Qn(r,e,t,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=Wc(r,e,t,n),l,f=new Uint8Array(4),h=At(f),d=new Uint8Array(c.outputLen);for(let m=1,x=0;x<o;m++,x+=c.outputLen){let g=a.subarray(x,x+c.outputLen);h.setInt32(0,m,!1),(l=u._cloneInto(l)).update(f).digestInto(d),g.set(d.subarray(0,g.length)),await Ba(s-1,i,()=>{c._cloneInto(l).update(d).digestInto(d);for(let y=0;y<g.length;y++)g[y]^=d[y]})}return Xc(c,u,a,l,d)}var Qc={sha1:Yc,"sha2-256":ft,"sha2-512":Ve};function Jr(r,e,t,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Qc).join(" / ");throw new U(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Qc[s],i=Jc(o,r,e,{c:t,dkLen:n});return Bt.encode(i).substring(1)}var Je="/",eu=new TextEncoder().encode(Je),es=eu[0],Qr=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=H(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==es)throw new Error("Invalid key")}toString(e="utf8"){return j(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(Je))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=eu),this._buf[0]!==es){let e=new Uint8Array(this._buf.byteLength+1);e.fill(es,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===es;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let s=0;s<t.length;s++){if(n.length<s+1)return!1;let o=t[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(Je).slice(1)}type(){return Dh(this.baseNamespace())}name(){return Fh(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(Je)||(e+=Je),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(Je):new r(e.slice(0,-1).join(Je))}child(e){return this.toString()===Je?e:e.toString()===Je?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...Oh(e.map(t=>t.namespaces()))])}};function Dh(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Fh(r){let e=r.split(":");return e[e.length-1]}function Oh(r){return[].concat(...r)}var ef=Oi(uu(),1);var Ai={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var dr={};he(dr,{create:()=>Wh,derivedEmptyPasswordKey:()=>ts});var ts={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Wh(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=Q.get();t*=8;async function c(f,h){let d=a.getRandomValues(new Uint8Array(o)),m=a.getRandomValues(new Uint8Array(n)),x={name:e,iv:m};typeof h=="string"&&(h=H(h));let g;if(h.length===0){g=await a.subtle.importKey("jwk",ts,{name:"AES-GCM"},!0,["encrypt"]);try{let E={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(E,A,{name:e,length:t},!0,["encrypt"])}catch{g=await a.subtle.importKey("jwk",ts,{name:"AES-GCM"},!0,["encrypt"])}}else{let E={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(E,A,{name:e,length:t},!0,["encrypt"])}let y=await a.subtle.encrypt(x,g,f);return Yt([d,x.iv,new Uint8Array(y)])}async function u(f,h){let d=f.subarray(0,o),m=f.subarray(o,o+n),x=f.subarray(o+n),g={name:e,iv:m};typeof h=="string"&&(h=H(h));let y;if(h.length===0)try{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},N=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(A,N,{name:e,length:t},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",ts,{name:"AES-GCM"},!0,["decrypt"])}else{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},N=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(A,N,{name:e,length:t},!0,["decrypt"])}let E=await a.subtle.decrypt(g,y,x);return new Uint8Array(E)}return{encrypt:c,decrypt:u}}var M=Oi(fu());function Ot(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 xt(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 u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*e);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function ss(...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 ki(){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=Ot(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,Ot(o,8)-n}function lu(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=xt(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xt(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 hu(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 ve(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 Qy=Math.log(2);function os(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ii(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 st(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 rn=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return Ii(this.items)}},en=[new Uint8Array([1])],du="0123456789";var gr="",$e=new ArrayBuffer(0),Ci=new Uint8Array(0),nn="EndOfContent",gu="OCTET STRING",mu="BIT STRING";function ot(r){var e;return e=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}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?M.BufferSourceConverter.toUint8Array(o.valueHex):Ci}fromBER(n,s,o,i){let a=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!st(this,a,s,o))return-1;let c=s+o;return this.valueHexView=a.subarray(s,c),this.valueHexView.length?(this.blockLength=o,c):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",$e)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var et=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}constructor({blockLength:e=0,error:t=gr,warnings:n=[],valueBeforeDecode:s=Ci}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};et.NAME="baseBlock";var ue=class extends et{fromBER(e,t,n,s){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'")}};ue.NAME="valueBlock";var is=class extends ot(et){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?M.BufferSourceConverter.toUint8Array(e.valueHex):Ci,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",$e}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=xt(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=M.BufferSourceConverter.toUint8Array(e);if(!st(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=0;for(;;){let l=c+1;if(l>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c++,(o[l]&128)===0)break}this.blockLength=c+1;let u=this.valueHexView=new Uint8Array(c);for(let l=0;l<c;l++)u[l]=o[l+1]&127;this.blockLength<=9?this.tagNumber=Ot(u,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}}};is.NAME="identificationBlock";var as=class extends et{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=M.BufferSourceConverter.toUint8Array(e);if(!st(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=Ot(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=xt(this.length,8);if(s.byteLength>127)return this.error="Too big length",$e;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let 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}}};as.NAME="lengthBlock";var I={},ie=class extends et{constructor({name:e=gr,optional:t=!1,primitiveSchema:n,...s}={},o){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new is(s),this.lenBlock=new as(s),this.valueBlock=o?new o(s):new ue(s)}fromBER(e,t,n,s){let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length,s);return o===-1?(this.error=this.valueBlock.error,o):(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),o)}toBER(e,t){let n=t||new rn;t||yu(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?$e:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){let e=this.constructor.NAME,t=M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${e} : ${t}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return hu(t,n)}};ie.NAME="BaseBlock";function yu(r){var e;if(r instanceof I.Constructed)for(let t of r.valueBlock.value)yu(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((e=r.lenBlock)===null||e===void 0)&&e.isIndefiniteForm)}var cs=class extends ie{getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}constructor({value:e=gr,...t}={},n){super(t,n),e&&this.fromString(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}'`}};cs.NAME="BaseStringBlock";var us=class extends ot(ue){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};us.NAME="PrimitiveValueBlock";var bu,fs=class extends ie{constructor(e={}){super(e,us),this.idBlock.isConstructed=!1}};bu=fs;I.Primitive=bu;fs.NAME="PRIMITIVE";var od=100,id=1e4,ad=16*1024*1024,cd="Maximum ASN.1 nesting depth exceeded",ud="Maximum ASN.1 node count exceeded",fd="Maximum ASN.1 content length exceeded";function fn(r={}){var e,t,n;return{depth:0,maxDepth:(e=r.maxDepth)!==null&&e!==void 0?e:od,nodesCount:0,maxNodes:(t=r.maxNodes)!==null&&t!==void 0?t:id,maxContentLength:(n=r.maxContentLength)!==null&&n!==void 0?n:ad}}function ld(r){let e=new ie({},ue);return e.error=r,{offset:-1,result:e}}function hd(r){if(r.nodesCount+=1,r.nodesCount>r.maxNodes)return ud}function dd(r,e){if(r>e.maxContentLength)return fd}function Ti(r,e,t,n){let s=n.depth+1;if(s>n.maxDepth)return ld(cd);n.depth=s;try{return wu(r,e,t,n)}finally{n.depth-=1}}function pd(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 wu(r,e=0,t=r.length,n=fn()){let s=e,o=new ie({},ue),i=new et;if(!st(i,r,e,t))return o.error=i.error,{offset:-1,result:o};if(!r.subarray(e,e+t).length)return o.error="Zero buffer length",{offset:-1,result:o};let c=hd(n);if(c)return o.error=c,{offset:-1,result:o};let u=o.idBlock.fromBER(r,e,t);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),u===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(e=u,t-=o.idBlock.blockLength,u=o.lenBlock.fromBER(r,e,t),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),u===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};e=u,t-=o.lenBlock.blockLength;let l=o.lenBlock.isIndefiniteForm?t:o.lenBlock.length,f=dd(l,n);if(f)return o.error=f,{offset:-1,result:o};if(!o.idBlock.isConstructed&&o.lenBlock.isIndefiniteForm)return o.error="Indefinite length form used for primitive encoding form",{offset:-1,result:o};let h=ie;switch(o.idBlock.tagClass){case 1:if(o.idBlock.tagNumber>=37&&o.idBlock.isHexOnly===!1)return o.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:o};switch(o.idBlock.tagNumber){case 0:if(o.idBlock.isConstructed&&o.lenBlock.length>0)return o.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:o};h=I.EndOfContent;break;case 1:h=I.Boolean;break;case 2:h=I.Integer;break;case 3:h=I.BitString;break;case 4:h=I.OctetString;break;case 5:h=I.Null;break;case 6:h=I.ObjectIdentifier;break;case 10:h=I.Enumerated;break;case 12:h=I.Utf8String;break;case 13:h=I.RelativeObjectIdentifier;break;case 14:h=I.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:h=I.Sequence;break;case 17:h=I.Set;break;case 18:h=I.NumericString;break;case 19:h=I.PrintableString;break;case 20:h=I.TeletexString;break;case 21:h=I.VideotexString;break;case 22:h=I.IA5String;break;case 23:h=I.UTCTime;break;case 24:h=I.GeneralizedTime;break;case 25:h=I.GraphicString;break;case 26:h=I.VisibleString;break;case 27:h=I.GeneralString;break;case 28:h=I.UniversalString;break;case 29:h=I.CharacterString;break;case 30:h=I.BmpString;break;case 31:h=I.DATE;break;case 32:h=I.TimeOfDay;break;case 33:h=I.DateTime;break;case 34:h=I.Duration;break;default:{let d=o.idBlock.isConstructed?new I.Constructed:new I.Primitive;d.idBlock=o.idBlock,d.lenBlock=o.lenBlock,d.warnings=o.warnings,o=d}}break;default:h=o.idBlock.isConstructed?I.Constructed:I.Primitive}return o=pd(o,h),u=o.fromBER(r,e,l,n),o.valueBeforeDecodeView=r.subarray(s,s+o.blockLength),{offset:u,result:o}}function qs(r,e={}){if(!r.byteLength){let t=new ie({},ue);return t.error="Input buffer has zero length",{offset:-1,result:t}}return wu(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength,fn(e))}function gd(r,e){return r?1:e}var je=class extends ue{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n,s){let o=M.BufferSourceConverter.toUint8Array(e),i=s??fn();if(!st(this,o,t,n))return-1;if(this.valueBeforeDecodeView=o.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let a=t;for(;gd(this.isIndefiniteForm,n)>0;){let c=Ti(o,a,n,i);if(c.offset===-1)return this.error=c.result.error,this.warnings.concat(c.result.warnings),-1;if(a=c.offset,this.blockLength+=c.result.blockLength,n-=c.result.blockLength,this.value.push(c.result),this.isIndefiniteForm&&c.result.constructor.NAME===nn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===nn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),a}toBER(e,t){let n=t||new rn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?$e:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};je.NAME="ConstructedValueBlock";var xu,vt=class extends ie{constructor(e={}){super(e,je),this.idBlock.isConstructed=!0}fromBER(e,t,n,s){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length,s);return o===-1?(this.error=this.valueBlock.error,o):(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),o)}onAsciiEncoding(){let e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
|
|
3
|
-
`).map(
|
|
2
|
+
"use strict";var Libp2PKeychain=(()=>{var Ih=Object.create;var zn=Object.defineProperty;var Th=Object.getOwnPropertyDescriptor;var Nh=Object.getOwnPropertyNames;var Uh=Object.getPrototypeOf,Lh=Object.prototype.hasOwnProperty;var Mr=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),V=(r,e)=>{for(var t in e)zn(r,t,{get:e[t],enumerable:!0})},hc=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Nh(e))!Lh.call(r,o)&&o!==t&&zn(r,o,{get:()=>e[o],enumerable:!(n=Th(e,o))||n.enumerable});return r};var dc=(r,e,t)=>(t=r!=null?Ih(Uh(r)):{},hc(e||!r||!r.__esModule?zn(t,"default",{value:r,enumerable:!0}):t,r)),Dh=r=>hc(zn({},"__esModule",{value:!0}),r);var Tl=Mr((LE,Il)=>{"use strict";function Ug(r){return r>=55296&&r<=56319}function Lg(r){return r>=56320&&r<=57343}Il.exports=function(e,t,n){if(typeof t!="string")throw new Error("Input must be string");for(var o=t.length,s=0,i,a,c=0;c<o;c+=1){if(i=t.charCodeAt(c),a=t[c],Ug(i)&&Lg(t.charCodeAt(c+1))&&(c+=1,a+=t[c]),s+=e(a),s===n)return t.slice(0,c+1);if(s>n)return t.slice(0,c-a.length+1)}return t}});var Ul=Mr((DE,Nl)=>{"use strict";function Dg(r){return r>=55296&&r<=56319}function Rg(r){return r>=56320&&r<=57343}Nl.exports=function(e){if(typeof e!="string")throw new Error("Input must be string");for(var t=e.length,n=0,o=null,s=null,i=0;i<t;i++)o=e.charCodeAt(i),Rg(o)?s!=null&&Dg(s)?n+=1:n+=3:o<=127?n+=1:o>=128&&o<=2047?n+=2:o>=2048&&o<=65535&&(n+=3),s=o;return n}});var Dl=Mr((RE,Ll)=>{"use strict";var _g=Tl(),Og=Ul();Ll.exports=_g.bind(null,Og)});var Ol=Mr((_E,_l)=>{"use strict";var Fg=Dl(),Vg=/[\/\?<>\\:\*\|"]/g,Kg=/[\x00-\x1f\x80-\x9f]/g,Mg=/^\.+$/,Hg=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i;function Pg(r,e){for(var t=r.length;t>0&&(r[t-1]==="."||r[t-1]===" ");)t--;return t<r.length?r.slice(0,t)+e:r}function Rl(r,e){if(typeof r!="string")throw new Error("Input must be string");var t=r.replace(Vg,e).replace(Kg,e).replace(Mg,e).replace(Hg,e);return t=Pg(t,e),Fg(t,255)}_l.exports=function(r,e){var t=e&&e.replacement||"",n=Rl(r,t);return t===""?n:Rl(n,"")}});var Fl=Mr(_r=>{"use strict";var qg="[object ArrayBuffer]",st=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===qg}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),o=r.toUint8Array(t);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])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 o=new Uint8Array(n),s=0;for(let i of t){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},tc="string",jg=/^[0-9a-f\s]+$/i,zg=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Gg=/^[a-zA-Z0-9-_]+$/,Ho=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return n.buffer}static toString(e){let t=st.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},Ne=class{static toString(e,t=!1){let n=st.toArrayBuffer(e),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,t);s+=String.fromCharCode(a)}return s}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let s=0;s<e.length;s++)o.setUint16(s*2,e.charCodeAt(s),t);return n}},Po=class r{static isHex(e){return typeof e===tc&&jg.test(e)}static isBase64(e){return typeof e===tc&&zg.test(e)}static isBase64Url(e){return typeof e===tc&&Gg.test(e)}static ToString(e,t="utf8"){let n=st.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 Ne.toString(n,!0);case"utf16":case"utf16be":return Ne.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 Ne.fromString(e,!0);case"utf16":case"utf16be":return Ne.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=st.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 Ho.fromString(e);case"utf16":case"utf16be":return Ne.fromString(e);case"utf16le":case"usc2":return Ne.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 Ho.toString(e);case"utf16":case"utf16be":return Ne.toString(e);case"utf16le":case"usc2":return Ne.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 o=0;o<t;o++)n[o]=e.charCodeAt(o);return n.buffer}static ToBinary(e){let t=st.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=st.toUint8Array(e),n="",o=t.length;for(let s=0;s<o;s++){let i=t[s];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 o=0;o<t.length;o=o+2){let s=t.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(e,t=!1){return Ne.toString(e,t)}static FromUtf16String(e,t=!1){return Ne.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,"")||""}};Po.DEFAULT_UTF8_ENCODING="utf8";function Zg(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)t[s]=o[s]}return t}function Yg(...r){let e=r.map(o=>o.byteLength).reduce((o,s)=>o+s),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)t[n++]=s}),t.buffer}function Jg(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<r.byteLength;o++)if(t[o]!==n[o])return!1;return!0}_r.BufferSourceConverter=st;_r.Convert=Po;_r.assign=Zg;_r.combine=Yg;_r.isEqual=Jg});var By={};V(By,{isKeychain:()=>Ey,keychain:()=>vy});function Rh(r){return r.buffer instanceof ArrayBuffer}function Z(r){return Rh(r)?r:r.slice()}var Hr=class extends Error{constructor(e="An error occurred while signing a message"){super(e),this.name="SigningError"}},Pr=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},Gn=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var ne={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new Gn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return e}};var _=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},Wt=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}},$r=class extends Error{static name="InvalidPrivateKeyError";constructor(e="Invalid private key"){super(e),this.name="InvalidPrivateKeyError"}};var Zn=class extends Error{static name="NotFoundError";constructor(e="Not found"){super(e),this.name="NotFoundError"}};var Qt=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var pc=Symbol.for("@libp2p/service-capabilities");var Os={};V(Os,{base58btc:()=>oe,base58flickr:()=>Ph});var tb=new Uint8Array(0);function mc(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 Je(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return Ut(r);if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return Ut(new Uint8Array(r.buffer,r.byteOffset,r.byteLength));throw new Error("Unknown type, must be binary type")}function gc(r){return new TextEncoder().encode(r)}function yc(r){return new TextDecoder().decode(r)}function _h(r){return r?.buffer instanceof ArrayBuffer}function Ut(r){return _h(r)?r:r.slice()}function Oh(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 o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var b=0,m=0,g=0,w=h.length;g!==w&&h[g]===0;)g++,b++;for(var x=(w-g)*u+1>>>0,S=new Uint8Array(x);g!==w;){for(var C=h[g],D=0,T=x-1;(C!==0||D<m)&&T!==-1;T--,D++)C+=256*S[T]>>>0,S[T]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");m=D,g++}for(var A=x-m;A!==x&&S[A]===0;)A++;for(var F=c.repeat(b);A<x;++A)F+=r.charAt(S[A]);return F}function d(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var b=0;if(h[b]!==" "){for(var m=0,g=0;h[b]===c;)m++,b++;for(var w=(h.length-b)*f+1>>>0,x=new Uint8Array(w);h[b];){var S=t[h.charCodeAt(b)];if(S===255)return;for(var C=0,D=w-1;(S!==0||C<g)&&D!==-1;D--,C++)S+=a*x[D]>>>0,x[D]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");g=C,b++}if(h[b]!==" "){for(var T=w-g;T!==w&&x[T]===0;)T++;for(var A=new Uint8Array(m+(w-T)),F=m;T!==w;)A[F++]=x[T++];return A}}}function p(h){var b=d(h);if(b)return b;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:d,decode:p}}var Fh=Oh,Vh=Fh,wc=Vh;var Ls=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")}},Ds=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let o=t.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,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 xc(this,e)}},Rs=class{decoders;constructor(e){this.decoders=e}or(e){return xc(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 xc(r,e){return new Rs({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var _s=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new Ls(e,t,n),this.decoder=new Ds(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function er({name:r,prefix:e,encode:t,decode:n}){return new _s(r,e,t,n)}function ht({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=wc(t,r);return er({prefix:e,name:r,encode:n,decode:s=>Je(o(s))})}function Kh(r,e,t,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*t/8|0),i=0,a=0,c=0;for(let f=0;f<o;++f){let u=e[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|u,i+=t,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function Mh(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;(s.length*t&7)!==0;)s+="=";return s}function Hh(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function J({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let o=Hh(n);return er({prefix:e,name:r,encode(s){return Mh(s,n,t)},decode(s){return Kh(s,o,t,r)}})}var oe=ht({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ph=ht({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Fs={};V(Fs,{base32:()=>tr,base32hex:()=>zh,base32hexpad:()=>Zh,base32hexpadupper:()=>Yh,base32hexupper:()=>Gh,base32pad:()=>qh,base32padupper:()=>jh,base32upper:()=>$h,base32z:()=>Jh});var tr=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),$h=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),qh=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),jh=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),zh=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Gh=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Zh=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Yh=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Jh=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Vs={};V(Vs,{base36:()=>qr,base36upper:()=>Xh});var qr=ht({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Xh=ht({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Wh=Bc,vc=128,Qh=127,ed=~Qh,td=Math.pow(2,31);function Bc(r,e,t){e=e||[],t=t||0;for(var n=t;r>=td;)e[t++]=r&255|vc,r/=128;for(;r&ed;)e[t++]=r&255|vc,r>>>=7;return e[t]=r|0,Bc.bytes=t-n+1,e}var rd=Ks,nd=128,Ec=127;function Ks(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Ks.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&Ec)<<o:(i&Ec)*Math.pow(2,o),o+=7}while(i>=nd);return Ks.bytes=s-n,t}var od=Math.pow(2,7),sd=Math.pow(2,14),id=Math.pow(2,21),ad=Math.pow(2,28),cd=Math.pow(2,35),fd=Math.pow(2,42),ud=Math.pow(2,49),ld=Math.pow(2,56),hd=Math.pow(2,63),dd=function(r){return r<od?1:r<sd?2:r<id?3:r<ad?4:r<cd?5:r<fd?6:r<ud?7:r<ld?8:r<hd?9:10},pd={encode:Wh,decode:rd,encodingLength:dd},md=pd,jr=md;function zr(r,e=0){return[jr.decode(r,e),jr.decode.bytes]}function rr(r,e,t=0){return jr.encode(r,e,t),e}function nr(r){return jr.encodingLength(r)}function Ke(r,e){let t=e.byteLength,n=nr(r),o=n+nr(t),s=new Uint8Array(o+t);return rr(r,s,0),rr(t,s,n),s.set(e,o),new or(r,t,e,s)}function Ac(r){let e=Je(r),[t,n]=zr(e),[o,s]=zr(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new or(t,o,i,e)}function Sc(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&mc(r.bytes,t.bytes)}}var or=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=Ut(n),this.bytes=Ut(o)}};function kc(r,e){let{bytes:t,version:n}=r;return n===0?yd(t,Ms(r),e??oe.encoder):bd(t,Ms(r),e??tr.encoder)}var Cc=new WeakMap;function Ms(r){let e=Cc.get(r);if(e==null){let t=new Map;return Cc.set(r,t),t}return e}var ke=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,this.multihash=n,this.bytes=Ut(o),this["/"]=this.bytes}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!==Zr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==wd)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=Ke(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&&Sc(e.multihash,n.multihash)}toString(e){return kc(this,e)}toJSON(){return{"/":kc(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:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??Ic(n,o,s.bytes))}else if(t[xd]===!0){let{version:n,multihash:o,code:s}=t,i=Ac(o);return r.create(n,s,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!==Zr)throw new Error(`Version 0 CID must use dag-pb (code: ${Zr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Ic(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Zr,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,o=Je(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new or(t.multihashCode,t.digestSize,s,o);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,d]=zr(e.subarray(t));return t+=d,l},o=n(),s=Zr;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=gd(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ms(s).set(n,e),s}};function gd(r,e){switch(r[0]){case"Q":{let t=e??oe;return[oe.prefix,t.decode(`${oe.prefix}${r}`)]}case oe.prefix:{let t=e??oe;return[oe.prefix,t.decode(r)]}case tr.prefix:{let t=e??tr;return[tr.prefix,t.decode(r)]}case qr.prefix:{let t=e??qr;return[qr.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function yd(r,e,t){let{prefix:n}=t;if(n!==oe.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function bd(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var Zr=112,wd=18;function Ic(r,e,t){let n=nr(r),o=n+nr(e),s=new Uint8Array(o+t.byteLength);return rr(r,s,0),rr(e,s,n),s.set(t,o),s}var xd=Symbol.for("@ipld/js-cid/CID");var Hs={};V(Hs,{identity:()=>Lt});var Tc=0,vd="identity",Nc=Je;function Ed(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return Ke(Tc,Nc(r))}var Lt={code:Tc,name:vd,encode:Nc,digest:Ed};function Ce(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}var Uc="1.2.840.10045.3.1.7",Lc="1.3.132.0.34",Dc="1.3.132.0.35";async function Rc(r,e,t){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);t?.signal?.throwIfAborted();let o=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,Z(e.subarray()));return t?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function _c(r,e,t,n){let o=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,Z(e),Z(t.subarray()));return n?.signal?.throwIfAborted(),s}function Xe(r=0){return new Uint8Array(r)}function Yr(r=0){return new Uint8Array(r)}function Ps(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=Yr(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return t}function Oc(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}var Vc=Symbol.for("@achingbrain/uint8arraylist");function Fc(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let o=t+n.byteLength;if(e<o)return{buf:n,index:e-t};t=o}throw new RangeError("index is out of bounds")}function Jn(r){return!!r?.[Vc]}var ge=class r{bufs;length;[Vc]=!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(Jn(n)){t+=n.byteLength;for(let o of n.bufs)this.bufs.push(o)}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(Jn(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=Fc(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Fc(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(Jn(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:o}=this._subList(e,t);return Ps(n,o)}subarray(e,t){let{bufs:n,length:o}=this._subList(e,t);return n.length===1?n[0]:Ps(n,o)}sublist(e,t){let{bufs:n,length:o}=this._subList(e,t),s=new r;return s.length=o,s.bufs=n,s}_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=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=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(!Jn(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 o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;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 d=f;d>=0;d--){let p=this.get(l+d);if(n[d]!==p){u=Math.max(1,d-a[p]);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=Yr(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 o=Xe(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,t,n),this.write(o,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 o=Xe(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,t,n),this.write(o,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 o=Xe(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,t,n),this.write(o,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=Yr(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 o=Xe(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,t,n),this.write(o,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 o=Xe(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,t,n),this.write(o,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 o=Xe(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,t,n),this.write(o,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 o=Xe(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,t,n),this.write(o,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 o=Xe(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,t,n),this.write(o,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(!Oc(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((o,s)=>o+s.byteLength,0)),n.length=t,n}};var $s={};V($s,{base10:()=>Bd});var Bd=ht({prefix:"9",name:"base10",alphabet:"0123456789"});var qs={};V(qs,{base16:()=>Ad,base16upper:()=>Sd});var Ad=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Sd=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var js={};V(js,{base2:()=>kd});var kd=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var zs={};V(zs,{base256emoji:()=>Ud});var Kc=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}"),Cd=Kc.reduce((r,e,t)=>(r[t]=e,r),[]),Id=Kc.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Td(r){return r.reduce((e,t)=>(e+=Cd[t],e),"")}function Nd(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let o=Id[n];if(o==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(o)}return new Uint8Array(e)}var Ud=er({prefix:"\u{1F680}",name:"base256emoji",encode:Td,decode:Nd});var Gs={};V(Gs,{base64:()=>Dt,base64pad:()=>Ld,base64url:()=>Dd,base64urlpad:()=>Rd});var Dt=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ld=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Dd=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Rd=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Zs={};V(Zs,{base8:()=>_d});var _d=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ys={};V(Ys,{identity:()=>Od});var Od=er({prefix:"\0",name:"identity",encode:r=>yc(r),decode:r=>gc(r)});var Hb=new TextEncoder,Pb=new TextDecoder;var Ws={};V(Ws,{sha256:()=>sr,sha512:()=>Md});var Kd=20;function Xs({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:o}){return new Js(r,e,t,n,o)}var Js=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,o,s){this.name=e,this.code=t,this.encode=n,this.minDigestLength=o??Kd,this.maxDigestLength=s}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?Mc(n,this.code,t?.truncate):n.then(o=>Mc(o,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function Mc(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return Ke(e,r)}function Pc(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var sr=Xs({name:"sha2-256",code:18,encode:Pc("SHA-256")}),Md=Xs({name:"sha2-512",code:19,encode:Pc("SHA-512")});var Qs={...Ys,...js,...Zs,...$s,...qs,...Fs,...Vs,...Os,...Gs,...zs},ew={...Ws,...Hs};function Xn(r=0){return new Uint8Array(r)}function qc(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var $c=qc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ei=qc("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=Xn(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Hd={utf8:$c,"utf-8":$c,hex:Qs.base16,latin1:ei,ascii:ei,binary:ei,...Qs},Wn=Hd;function q(r,e="utf8"){let t=Wn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function j(r,e="utf8"){let t=Wn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Pd=parseInt("11111",2),ti=parseInt("10000000",2),$d=parseInt("01111111",2),jc={0:Jr,1:Jr,2:qd,3:Gd,4:Zd,5:zd,6:jd,16:Jr,22:Jr,48:Jr};function Ue(r,e={offset:0}){let t=r[e.offset]&Pd;if(e.offset++,jc[t]!=null)return jc[t](r,e);throw new Error("No decoder for tag "+t)}function Xr(r,e){let t=0;if((r[e.offset]&ti)===ti){let n=r[e.offset]&$d,o="0x";e.offset++;for(let s=0;s<n;s++,e.offset++)o+=r[e.offset].toString(16).padStart(2,"0");t=parseInt(o,16)}else t=r[e.offset],e.offset++;return t}function Jr(r,e){Xr(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=Ue(r,e);if(n===null)break;t.push(n)}return t}function qd(r,e){let t=Xr(r,e),n=e.offset,o=e.offset+t,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return e.offset+=t,Uint8Array.from(s)}function jd(r,e){let t=Xr(r,e),n=e.offset+t,o=r[e.offset];e.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let a=`${s}.${i}`,c=[];for(;e.offset<n;){let f=r[e.offset];if(e.offset++,c.push(f&127),f<128){c.reverse();let u=0;for(let l=0;l<c.length;l++)u+=c[l]<<l*7;a+=`.${u}`,c=[]}}return a}function zd(r,e){return e.offset++,null}function Gd(r,e){let t=Xr(r,e),n=r[e.offset];e.offset++;let o=r.subarray(e.offset,e.offset+t-1);if(e.offset+=t,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function Zd(r,e){let t=Xr(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function Yd(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new ge;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function Qn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=Yd(r.byteLength);return new ge(Uint8Array.from([e.byteLength|ti]),e)}function ye(r){let e=new ge,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new ge(Uint8Array.from([2]),Qn(e),e)}function Wr(r){let e=Uint8Array.from([0]),t=new ge(e,r);return new ge(Uint8Array.from([3]),Qn(t),t)}function zc(r){return new ge(Uint8Array.from([4]),Qn(r),r)}function Le(r,e=48){let t=new ge;for(let n of r)t.append(n);return new ge(Uint8Array.from([e]),Qn(t),t)}var Jd=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Xd=Uint8Array.from([6,5,43,129,4,0,34]),Wd=Uint8Array.from([6,5,43,129,4,0,35]),Qd={ext:!0,kty:"EC",crv:"P-256"},e0={ext:!0,kty:"EC",crv:"P-384"},t0={ext:!0,kty:"EC",crv:"P-521"},ri=32,ni=48,oi=66;function Gc(r){let e=Ue(r);return si(e)}function si(r){let e=r[1],t=j(e,"base64url"),n=r[2][1][0],o=1,s,i;if(e.byteLength===ri)return s=j(n.subarray(o,o+ri),"base64url"),i=j(n.subarray(o+ri),"base64url"),new ir({...Qd,key_ops:["sign"],d:t,x:s,y:i});if(e.byteLength===ni)return s=j(n.subarray(o,o+ni),"base64url"),i=j(n.subarray(o+ni),"base64url"),new ir({...e0,key_ops:["sign"],d:t,x:s,y:i});if(e.byteLength===oi)return s=j(n.subarray(o,o+oi),"base64url"),i=j(n.subarray(o+oi),"base64url"),new ir({...t0,key_ops:["sign"],d:t,x:s,y:i});throw new _(`Private key length was wrong length, got ${e.byteLength}, expected 32, 48 or 66`)}function Zc(r){return Le([ye(Uint8Array.from([1])),zc(q(r.d??"","base64url")),Le([Jc(r.crv)],160),Le([Wr(new ge(Uint8Array.from([4]),q(r.x??"","base64url"),q(r.y??"","base64url")))],161)]).subarray()}function Yc(r){return Le([ye(Uint8Array.from([1])),Le([Jc(r.crv)],160),Le([Wr(new ge(Uint8Array.from([4]),q(r.x??"","base64url"),q(r.y??"","base64url")))],161)]).subarray()}function Jc(r){if(r==="P-256")return Jd;if(r==="P-384")return Xd;if(r==="P-521")return Wd;throw new _(`Invalid curve ${r}`)}var eo=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=Yc(this.jwk)),this._raw}toMultihash(){return Lt.digest(ar(this))}toCID(){return ke.createV1(114,this.toMultihash())}toString(){return oe.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}async verify(e,t,n){return _c(this.jwk,t,e,n)}},ir=class{type="ECDSA";jwk;publicKey;_raw;constructor(e){this.jwk=e,this.publicKey=new eo({crv:e.crv,ext:e.ext,key_ops:["verify"],kty:"EC",x:e.x,y:e.y})}get raw(){return this._raw==null&&(this._raw=Zc(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}async sign(e,t){return Rc(this.jwk,e,t)}};function ii(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function Ie(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(`${t}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new RangeError(`${t}expected integer >= 0, got ${r}`)}}function ve(r,e,t=""){let n=ii(r),o=r?.length,s=e!==void 0;if(!n||s&&o!==e){let i=t&&`"${t}" `,a=s?` of length ${e}`:"",c=n?`length=${o}`:`type=${typeof r}`,f=i+"expected Uint8Array"+a+", got "+c;throw n?new RangeError(f):new TypeError(f)}return r}function cr(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(Ie(r.outputLen),Ie(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function fr(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 to(r,e){ve(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new RangeError('"digestInto() output" expected to be of length >='+t)}function Ee(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function Rt(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function De(r,e){return r<<32-e|r>>>e}function ro(r,e){return r<<e|r>>>32-e>>>0}var Wc=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",r0=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function no(r){if(ve(r),Wc)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=r0[r[t]];return e}var We={_0:48,_9:57,A:65,F:70,a:97,f:102};function Xc(r){if(r>=We._0&&r<=We._9)return r-We._0;if(r>=We.A&&r<=We.F)return r-(We.A-10);if(r>=We.a&&r<=We.f)return r-(We.a-10)}function Qr(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(Wc)try{return Uint8Array.fromHex(r)}catch(o){throw o instanceof SyntaxError?new RangeError(o.message):o}let e=r.length,t=e/2;if(e%2)throw new RangeError("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=Xc(r.charCodeAt(s)),a=Xc(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new RangeError('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}var n0=async()=>{};async function Qc(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let s=Date.now()-n;s>=0&&s<e||(await n0(),n+=s)}}function o0(r){if(typeof r!="string")throw new TypeError("string expected");return new Uint8Array(new TextEncoder().encode(r))}function ai(r,e=""){return typeof r=="string"?o0(r):ve(r,void 0,e)}function ci(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];ve(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}function ef(r,e){if(e!==void 0&&{}.toString.call(e)!=="[object Object]")throw new TypeError("options must be object or undefined");return Object.assign(r,e)}function en(r,e={}){let t=(o,s)=>r(s).update(o).digest(),n=r(void 0);return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.canXOF=n.canXOF,t.create=o=>r(o),Object.assign(t,e),Object.freeze(t)}function oo(r=32){Ie(r,"bytesLength");let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return e.getRandomValues(new Uint8Array(r))}var fi=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function so(r,e,t){return r&e^~r&t}function io(r,e,t){return r&e^r&t^e&t}var _t=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,n,o){this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(e),this.view=Rt(this.buffer)}update(e){fr(this),ve(e);let{view:t,buffer:n,blockLen:o}=this,s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=Rt(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){fr(this),to(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[i++]=128,Ee(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)t[l]=0;n.setBigUint64(o-8,BigInt(this.length*8),s),this.process(n,0);let a=Rt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must 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],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=s,e.length=o,e.pos=a,o%t&&e.buffer.set(n),e}clone(){return this._cloneInto()}},Qe=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var le=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var ao=BigInt(4294967295),tf=BigInt(32);function s0(r,e=!1){return e?{h:Number(r&ao),l:Number(r>>tf&ao)}:{h:Number(r>>tf&ao)|0,l:Number(r&ao)|0}}function rf(r,e=!1){let t=r.length,n=new Uint32Array(t),o=new Uint32Array(t);for(let s=0;s<t;s++){let{h:i,l:a}=s0(r[s],e);[n[s],o[s]]=[i,a]}return[n,o]}var ui=(r,e,t)=>r>>>t,li=(r,e,t)=>r<<32-t|e>>>t,Ot=(r,e,t)=>r>>>t|e<<32-t,Ft=(r,e,t)=>r<<32-t|e>>>t,tn=(r,e,t)=>r<<64-t|e>>>t-32,rn=(r,e,t)=>r>>>t-32|e<<64-t;function Me(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var nf=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),of=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,sf=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),af=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,cf=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),ff=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var a0=Uint32Array.from([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]),dt=new Uint32Array(64),hi=class extends _t{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|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)dt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let d=dt[l-15],p=dt[l-2],h=De(d,7)^De(d,18)^d>>>3,b=De(p,17)^De(p,19)^p>>>10;dt[l]=b+dt[l-7]+h+dt[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let d=De(a,6)^De(a,11)^De(a,25),p=u+d+so(a,c,f)+a0[l]+dt[l]|0,b=(De(n,2)^De(n,13)^De(n,22))+io(n,o,s)|0;u=f,f=c,c=a,a=i+p|0,i=s,s=o,o=n,n=p+b|0}n=n+this.A|0,o=o+this.B|0,s=s+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,o,s,i,a,c,f,u)}roundClean(){Ee(dt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),Ee(this.buffer)}},di=class extends hi{A=Qe[0]|0;B=Qe[1]|0;C=Qe[2]|0;D=Qe[3]|0;E=Qe[4]|0;F=Qe[5]|0;G=Qe[6]|0;H=Qe[7]|0;constructor(){super(32)}};var uf=rf(["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))),c0=uf[0],f0=uf[1],pt=new Uint32Array(80),mt=new Uint32Array(80),pi=class extends _t{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:d,Gh:p,Gl:h,Hh:b,Hl:m}=this;return[e,t,n,o,s,i,a,c,f,u,l,d,p,h,b,m]}set(e,t,n,o,s,i,a,c,f,u,l,d,p,h,b,m){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|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=d|0,this.Gh=p|0,this.Gl=h|0,this.Hh=b|0,this.Hl=m|0}process(e,t){for(let x=0;x<16;x++,t+=4)pt[x]=e.getUint32(t),mt[x]=e.getUint32(t+=4);for(let x=16;x<80;x++){let S=pt[x-15]|0,C=mt[x-15]|0,D=Ot(S,C,1)^Ot(S,C,8)^ui(S,C,7),T=Ft(S,C,1)^Ft(S,C,8)^li(S,C,7),A=pt[x-2]|0,F=mt[x-2]|0,G=Ot(A,F,19)^tn(A,F,61)^ui(A,F,6),K=Ft(A,F,19)^rn(A,F,61)^li(A,F,6),y=sf(T,K,mt[x-7],mt[x-16]),v=af(y,D,G,pt[x-7],pt[x-16]);pt[x]=v|0,mt[x]=y|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:d,Fh:p,Fl:h,Gh:b,Gl:m,Hh:g,Hl:w}=this;for(let x=0;x<80;x++){let S=Ot(l,d,14)^Ot(l,d,18)^tn(l,d,41),C=Ft(l,d,14)^Ft(l,d,18)^rn(l,d,41),D=l&p^~l&b,T=d&h^~d&m,A=cf(w,C,T,f0[x],mt[x]),F=ff(A,g,S,D,c0[x],pt[x]),G=A|0,K=Ot(n,o,28)^tn(n,o,34)^tn(n,o,39),y=Ft(n,o,28)^rn(n,o,34)^rn(n,o,39),v=n&s^n&a^s&a,k=o&i^o&c^i&c;g=b|0,w=m|0,b=p|0,m=h|0,p=l|0,h=d|0,{h:l,l:d}=Me(f|0,u|0,F|0,G|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let B=nf(G,y,k);n=of(B,F,K,v),o=B|0}({h:n,l:o}=Me(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=Me(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=Me(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=Me(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:d}=Me(this.Eh|0,this.El|0,l|0,d|0),{h:p,l:h}=Me(this.Fh|0,this.Fl|0,p|0,h|0),{h:b,l:m}=Me(this.Gh|0,this.Gl|0,b|0,m|0),{h:g,l:w}=Me(this.Hh|0,this.Hl|0,g|0,w|0),this.set(n,o,s,i,a,c,f,u,l,d,p,h,b,m,g,w)}roundClean(){Ee(pt,mt)}destroy(){this.destroyed=!0,Ee(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},mi=class extends pi{Ah=le[0]|0;Al=le[1]|0;Bh=le[2]|0;Bl=le[3]|0;Ch=le[4]|0;Cl=le[5]|0;Dh=le[6]|0;Dl=le[7]|0;Eh=le[8]|0;El=le[9]|0;Fh=le[10]|0;Fl=le[11]|0;Gh=le[12]|0;Gl=le[13]|0;Hh=le[14]|0;Hl=le[15]|0;constructor(){super(64)}};var gt=en(()=>new di,fi(1));var He=en(()=>new mi,fi(3));var $=(r,e,t)=>ve(r,e,t),yi=Ie,ur=no,ie=(...r)=>ci(...r),lr=r=>Qr(r),Vt=ii,nn=r=>oo(r),fo=BigInt(0),gi=BigInt(1);function Re(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new TypeError(t+"expected boolean, got type="+typeof r)}return r}function uo(r){if(typeof r=="bigint"){if(!co(r))throw new RangeError("positive bigint expected, got "+r)}else yi(r);return r}function _e(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(t+"expected number, got type="+typeof r)}if(!Number.isSafeInteger(r)){let t=e&&`"${e}" `;throw new RangeError(t+"expected safe integer, got "+r)}}function on(r){let e=uo(r).toString(16);return e.length&1?"0"+e:e}function lf(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?fo:BigInt("0x"+r)}function Kt(r){return lf(no(r))}function Pe(r){return lf(no(sn(ve(r)).reverse()))}function lo(r,e){if(Ie(e),e===0)throw new RangeError("zero length");r=uo(r);let t=r.toString(16);if(t.length>e*2)throw new RangeError("number too large");return Qr(t.padStart(e*2,"0"))}function bi(r,e){return lo(r,e).reverse()}function hf(r,e){if(r=$(r),e=$(e),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 sn(r){return Uint8Array.from($(r))}function ho(r){if(typeof r!="string")throw new TypeError("ascii string expected, got "+typeof r);return Uint8Array.from(r,(e,t)=>{let n=e.charCodeAt(0);if(e.length!==1||n>127)throw new RangeError(`string contains non-ASCII character "${r[t]}" with code ${n} at position ${t}`);return n})}var co=r=>typeof r=="bigint"&&fo<=r;function u0(r,e,t){return co(r)&&co(e)&&co(t)&&e<=r&&r<t}function hr(r,e,t,n){if(!u0(e,t,n))throw new RangeError("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function dr(r){if(r<fo)throw new Error("expected non-negative bigint, got "+r);let e;for(e=0;r>fo;r>>=gi,e+=1);return e}var an=r=>(gi<<BigInt(r))-gi;function df(r,e,t){if(Ie(r,"hashLen"),Ie(e,"qByteLen"),typeof t!="function")throw new TypeError("hmacFn must be a function");let n=m=>new Uint8Array(m),o=Uint8Array.of(),s=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),f=n(r),u=0,l=()=>{c.fill(1),f.fill(0),u=0},d=(...m)=>t(f,ie(c,...m)),p=(m=o)=>{f=d(s,m),c=d(),m.length!==0&&(f=d(i,m),c=d())},h=()=>{if(u++>=a)throw new Error("drbg: tried max amount of iterations");let m=0,g=[];for(;m<e;){c=d();let w=c.slice();g.push(w),m+=c.length}return ie(...g)};return(m,g)=>{l(),p(m);let w;for(;(w=g(h()))===void 0;)p();return l(),w}}function Oe(r,e={},t={}){if(Object.prototype.toString.call(r)!=="[object Object]")throw new TypeError("expected valid options object");function n(s,i,a){if(!a&&i!=="function"&&!Object.hasOwn(r,s))throw new TypeError(`param "${s}" is invalid: expected own property`);let c=r[s];if(a&&c===void 0)return;let f=typeof c;if(f!==i||c===null)throw new TypeError(`param "${s}" is invalid: expected ${i}, got ${f}`)}let o=(s,i)=>Object.entries(s).forEach(([a,c])=>n(a,c,i));o(e,!1),o(t,!0)}var wi=()=>{throw new Error("not implemented")};var he=BigInt(0),X=BigInt(1),Mt=BigInt(2),yf=BigInt(3),bf=BigInt(4),wf=BigInt(5),l0=BigInt(7),xf=BigInt(8),h0=BigInt(9),vf=BigInt(16);function te(r,e){if(e<=he)throw new Error("mod: expected positive modulus, got "+e);let t=r%e;return t>=he?t:e+t}function Y(r,e,t){if(e<he)throw new Error("pow2: expected non-negative exponent, got "+e);let n=r;for(;e-- >he;)n*=n,n%=t;return n}function pf(r,e){if(r===he)throw new Error("invert: expected non-zero number");if(e<=he)throw new Error("invert: expected positive modulus, got "+e);let t=te(r,e),n=e,o=he,s=X,i=X,a=he;for(;t!==he;){let f=n/t,u=n-t*f,l=o-i*f,d=s-a*f;n=t,t=u,o=i,s=a,i=l,a=d}if(n!==X)throw new Error("invert: does not exist");return te(o,e)}function xi(r,e,t){let n=r;if(!n.eql(n.sqr(e),t))throw new Error("Cannot find square root")}function Ef(r,e){let t=r,n=(t.ORDER+X)/bf,o=t.pow(e,n);return xi(t,o,e),o}function d0(r,e){let t=r,n=(t.ORDER-wf)/xf,o=t.mul(e,Mt),s=t.pow(o,n),i=t.mul(e,s),a=t.mul(t.mul(i,Mt),s),c=t.mul(i,t.sub(a,t.ONE));return xi(t,c,e),c}function p0(r){let e=pr(r),t=Bf(r),n=t(e,e.neg(e.ONE)),o=t(e,n),s=t(e,e.neg(n)),i=(r+l0)/vf;return((a,c)=>{let f=a,u=f.pow(c,i),l=f.mul(u,n),d=f.mul(u,o),p=f.mul(u,s),h=f.eql(f.sqr(l),c),b=f.eql(f.sqr(d),c);u=f.cmov(u,l,h),l=f.cmov(p,d,b);let m=f.eql(f.sqr(l),c),g=f.cmov(u,l,m);return xi(f,g,c),g})}function Bf(r){if(r<yf)throw new Error("sqrt is not defined for small field");let e=r-X,t=0;for(;e%Mt===he;)e/=Mt,t++;let n=Mt,o=pr(r);for(;mf(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Ef;let s=o.pow(n,e),i=(e+X)/Mt;return function(c,f){let u=c;if(u.is0(f))return f;if(mf(u,f)!==1)throw new Error("Cannot find square root");let l=t,d=u.mul(u.ONE,s),p=u.pow(f,e),h=u.pow(f,i);for(;!u.eql(p,u.ONE);){if(u.is0(p))return u.ZERO;let b=1,m=u.sqr(p);for(;!u.eql(m,u.ONE);)if(b++,m=u.sqr(m),b===l)throw new Error("Cannot find square root");let g=X<<BigInt(l-b-1),w=u.pow(d,g);l=b,d=u.sqr(w),p=u.mul(p,d),h=u.mul(h,w)}return h}}function m0(r){return r%bf===yf?Ef:r%xf===wf?d0:r%vf===h0?p0(r):Bf(r)}var et=(r,e)=>(te(r,e)&X)===X,g0=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function vi(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=g0.reduce((n,o)=>(n[o]="function",n),e);if(Oe(r,t),_e(r.BYTES,"BYTES"),_e(r.BITS,"BITS"),r.BYTES<1||r.BITS<1)throw new Error("invalid field: expected BYTES/BITS > 0");if(r.ORDER<=X)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function y0(r,e,t){let n=r;if(t<he)throw new Error("invalid exponent, negatives unsupported");if(t===he)return n.ONE;if(t===X)return e;let o=n.ONE,s=e;for(;t>he;)t&X&&(o=n.mul(o,s)),s=n.sqr(s),t>>=X;return o}function cn(r,e,t=!1){let n=r,o=new Array(e.length).fill(t?n.ZERO:void 0),s=e.reduce((a,c,f)=>n.is0(c)?a:(o[f]=a,n.mul(a,c)),n.ONE),i=n.inv(s);return e.reduceRight((a,c,f)=>n.is0(c)?a:(o[f]=n.mul(a,o[f]),n.mul(a,c)),i),o}function mf(r,e){let t=r,n=(t.ORDER-X)/Mt,o=t.pow(e,n),s=t.eql(o,t.ONE),i=t.eql(o,t.ZERO),a=t.eql(o,t.neg(t.ONE));if(!s&&!i&&!a)throw new Error("invalid Legendre symbol result");return s?1:i?0:-1}function b0(r,e){if(e!==void 0&&yi(e),r<=he)throw new Error("invalid n length: expected positive n, got "+r);if(e!==void 0&&e<1)throw new Error("invalid n length: expected positive bit length, got "+e);let t=dr(r);if(e!==void 0&&e<t)throw new Error(`invalid n length: expected bit length (${t}) >= n.length (${e})`);let n=e!==void 0?e:t,o=Math.ceil(n/8);return{nBitLength:n,nByteLength:o}}var gf=new WeakMap,po=class{ORDER;BITS;BYTES;isLE;ZERO=he;ONE=X;_lengths;_mod;constructor(e,t={}){if(e<=X)throw new Error("invalid field: expected ORDER > 1, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&Object.defineProperty(this,"sqrt",{value:t.sqrt,enumerable:!0}),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=Object.freeze(t.allowedLengths.slice())),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:o,nByteLength:s}=b0(e,n);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=o,this.BYTES=s,Object.freeze(this)}create(e){return te(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new TypeError("invalid field element: expected bigint, got "+typeof e);return he<=e&&e<this.ORDER}is0(e){return e===he}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&X)===X}neg(e){return te(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return te(e*e,this.ORDER)}add(e,t){return te(e+t,this.ORDER)}sub(e,t){return te(e-t,this.ORDER)}mul(e,t){return te(e*t,this.ORDER)}pow(e,t){return y0(this,e,t)}div(e,t){return te(e*pf(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return pf(e,this.ORDER)}sqrt(e){let t=gf.get(this);return t||gf.set(this,t=m0(this.ORDER)),t(this,e)}toBytes(e){return this.isLE?bi(e,this.BYTES):lo(e,this.BYTES)}fromBytes(e,t=!1){$(e);let{_lengths:n,BYTES:o,isLE:s,ORDER:i,_mod:a}=this;if(n){if(e.length<1||!n.includes(e.length)||e.length>o)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let f=new Uint8Array(o);f.set(e,s?0:f.length-e.length),e=f}if(e.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+e.length);let c=s?Pe(e):Kt(e);if(a&&(c=te(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return cn(this,e)}cmov(e,t,n){return Re(n,"condition"),n?t:e}};Object.freeze(po.prototype);function pr(r,e={}){return new po(r,e)}function Af(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=X)throw new Error("field order must be greater than 1");let e=dr(r-X);return Math.ceil(e/8)}function Ei(r){let e=Af(r);return e+Math.ceil(e/2)}function Bi(r,e,t=!1){$(r);let n=r.length,o=Af(e),s=Math.max(Ei(e),16);if(n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=t?Pe(r):Kt(r),a=te(i,e-X)+X;return t?bi(a,o):lo(a,o)}var mr=BigInt(0),Ht=BigInt(1);function fn(r,e){let t=e.negate();return r?t:e}function Pt(r,e){let t=cn(r.Fp,e.map(n=>n.Z));return e.map((n,o)=>r.fromAffine(n.toAffine(t[o])))}function If(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Ai(r,e){If(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),o=2**r,s=an(r),i=BigInt(r);return{windows:t,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Sf(r,e,t){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=t,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=Ht);let f=e*n,u=f+Math.abs(a)-1,l=a===0,d=a<0,p=e%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:d,isNegF:p,offsetF:f}}var Si=new WeakMap,Tf=new WeakMap;function ki(r){return Tf.get(r)||1}function kf(r){if(r!==mr)throw new Error("invalid wNAF")}var gr=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,n=this.ZERO){let o=e;for(;t>mr;)t&Ht&&(n=n.add(o)),o=o.double(),t>>=Ht;return n}precomputeWindow(e,t){let{windows:n,windowSize:o}=Ai(t,this.bits),s=[],i=e,a=i;for(let c=0;c<n;c++){a=i,s.push(a);for(let f=1;f<o;f++)a=a.add(i),s.push(a);i=a.double()}return s}wNAF(e,t,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=Ai(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:f,isZero:u,isNeg:l,isNegF:d,offsetF:p}=Sf(n,a,i);n=c,u?s=s.add(fn(d,t[p])):o=o.add(fn(l,t[f]))}return kf(n),{p:o,f:s}}wNAFUnsafe(e,t,n,o=this.ZERO){let s=Ai(e,this.bits);for(let i=0;i<s.windows&&n!==mr;i++){let{nextN:a,offset:c,isZero:f,isNeg:u}=Sf(n,i,s);if(n=a,!f){let l=t[c];o=o.add(u?l.negate():l)}}return kf(n),o}getPrecomputes(e,t,n){let o=Si.get(t);return o||(o=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(o=n(o)),Si.set(t,o))),o}cached(e,t,n){let o=ki(e);return this.wNAF(o,this.getPrecomputes(o,e,n),t)}unsafe(e,t,n,o){let s=ki(e);return s===1?this._unsafeLadder(e,t,o):this.wNAFUnsafe(s,this.getPrecomputes(s,e,n),t,o)}createCache(e,t){If(t,this.bits),Tf.set(e,t),Si.delete(e)}hasCache(e){return ki(e)!==1}};function Nf(r,e,t,n){let o=e,s=r.ZERO,i=r.ZERO;for(;t>mr||n>mr;)t&Ht&&(s=s.add(o)),n&Ht&&(i=i.add(o)),o=o.double(),t>>=Ht,n>>=Ht;return{p1:s,p2:i}}function Cf(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return vi(e),e}else return pr(r,{isLE:t})}function mo(r,e,t={},n){if(n===void 0&&(n=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let f=e[c];if(!(typeof f=="bigint"&&f>mr))throw new Error(`CURVE.${c} must be positive bigint`)}let o=Cf(e.p,t.Fp,n),s=Cf(e.n,t.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!o.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:o,Fn:s}}function go(r,e){return function(n){let o=r(n);return{secretKey:o,publicKey:e(o)}}}var yt=BigInt(0),fe=BigInt(1),Ci=BigInt(2),w0=BigInt(8);function x0(r,e,t,n){let o=r.sqr(t),s=r.sqr(n),i=r.add(r.mul(e.a,o),s),a=r.add(r.ONE,r.mul(e.d,r.mul(o,s)));return r.eql(i,a)}function Uf(r,e={}){let t=e,n=mo("edwards",r,t,t.FpFnLE),{Fp:o,Fn:s}=n,i=n.CURVE,{h:a}=i;Oe(t,{},{uvRatio:"function"});let c=Ci<<BigInt(s.BYTES*8)-fe,f=b=>o.create(b),u=t.uvRatio===void 0?(b,m)=>{try{return{isValid:!0,value:o.sqrt(o.div(b,m))}}catch{return{isValid:!1,value:yt}}}:t.uvRatio;if(!x0(o,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function l(b,m,g=!1){let w=g?fe:yt;return hr("coordinate "+b,m,w,c),m}function d(b){if(!(b instanceof p))throw new Error("EdwardsPoint expected")}class p{static BASE=new p(i.Gx,i.Gy,fe,f(i.Gx*i.Gy));static ZERO=new p(yt,fe,fe,yt);static Fp=o;static Fn=s;X;Y;Z;T;constructor(m,g,w,x){this.X=l("x",m),this.Y=l("y",g),this.Z=l("z",w,!0),this.T=l("t",x),Object.freeze(this)}static CURVE(){return i}static fromAffine(m){if(m instanceof p)throw new Error("extended point not allowed");let{x:g,y:w}=m||{};return l("x",g),l("y",w),new p(g,w,fe,f(g*w))}static fromBytes(m,g=!1){let w=o.BYTES,{a:x,d:S}=i;m=sn($(m,w,"point")),Re(g,"zip215");let C=sn(m),D=m[w-1];C[w-1]=D&-129;let T=Pe(C),A=g?c:o.ORDER;hr("point.y",T,yt,A);let F=f(T*T),G=f(F-fe),K=f(S*F-x),{isValid:y,value:v}=u(G,K);if(!y)throw new Error("bad point: invalid y coordinate");let k=(v&fe)===fe,B=(D&128)!==0;if(!g&&v===yt&&B)throw new Error("bad point: x=0 and x_0=1");return B!==k&&(v=f(-v)),p.fromAffine({x:v,y:T})}static fromHex(m,g=!1){return p.fromBytes(lr(m),g)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(m=8,g=!0){return h.createCache(this,m),g||this.multiply(Ci),this}assertValidity(){let m=this,{a:g,d:w}=i;if(m.is0())throw new Error("bad point: ZERO");let{X:x,Y:S,Z:C,T:D}=m,T=f(x*x),A=f(S*S),F=f(C*C),G=f(F*F),K=f(T*g),y=f(F*f(K+A)),v=f(G+f(w*f(T*A)));if(y!==v)throw new Error("bad point: equation left != right (1)");let k=f(x*S),B=f(C*D);if(k!==B)throw new Error("bad point: equation left != right (2)")}equals(m){d(m);let{X:g,Y:w,Z:x}=this,{X:S,Y:C,Z:D}=m,T=f(g*D),A=f(S*x),F=f(w*D),G=f(C*x);return T===A&&F===G}is0(){return this.equals(p.ZERO)}negate(){return new p(f(-this.X),this.Y,this.Z,f(-this.T))}double(){let{a:m}=i,{X:g,Y:w,Z:x}=this,S=f(g*g),C=f(w*w),D=f(Ci*f(x*x)),T=f(m*S),A=g+w,F=f(f(A*A)-S-C),G=T+C,K=G-D,y=T-C,v=f(F*K),k=f(G*y),B=f(F*y),E=f(K*G);return new p(v,k,E,B)}add(m){d(m);let{a:g,d:w}=i,{X:x,Y:S,Z:C,T:D}=this,{X:T,Y:A,Z:F,T:G}=m,K=f(x*T),y=f(S*A),v=f(D*w*G),k=f(C*F),B=f((x+S)*(T+A)-K-y),E=k-v,I=k+v,L=f(y-g*K),N=f(B*E),R=f(I*L),O=f(B*L),P=f(E*I);return new p(N,R,P,O)}subtract(m){return d(m),this.add(m.negate())}multiply(m){if(!s.isValidNot0(m))throw new RangeError("invalid scalar: expected 1 <= sc < curve.n");let{p:g,f:w}=h.cached(this,m,x=>Pt(p,x));return Pt(p,[g,w])[0]}multiplyUnsafe(m){if(!s.isValid(m))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return m===yt?p.ZERO:this.is0()||m===fe?this:h.unsafe(this,m,g=>Pt(p,g))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return h.unsafe(this,i.n).is0()}toAffine(m){let g=this,w=m,{X:x,Y:S,Z:C}=g,D=g.is0();w==null&&(w=D?w0:o.inv(C));let T=f(x*w),A=f(S*w),F=o.mul(C,w);if(D)return{x:yt,y:fe};if(F!==fe)throw new Error("invZ was invalid");return{x:T,y:A}}clearCofactor(){return a===fe?this:this.multiplyUnsafe(a)}toBytes(){let{x:m,y:g}=this.toAffine(),w=o.toBytes(g);return w[w.length-1]|=m&fe?128:0,w}toHex(){return ur(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let h=new gr(p,s.BITS);return s.BITS>=8&&p.BASE.precompute(8),Object.freeze(p.prototype),Object.freeze(p),p}var yo=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(e){this.ep=e}static fromBytes(e){wi()}static fromHex(e){wi()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(e){return this.ep.toAffine(e)}toHex(){return ur(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(e){return this.assertSame(e),this.init(this.ep.add(e.ep))}subtract(e){return this.assertSame(e),this.init(this.ep.subtract(e.ep))}multiply(e){return this.init(this.ep.multiply(e))}multiplyUnsafe(e){return this.init(this.ep.multiplyUnsafe(e))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(e,t){return this.ep.precompute(e,t),this}};function Lf(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');let n=e,o=t;Oe(o,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",zip215:"boolean",mapToCurve:"function"});let{prehash:s}=o,{BASE:i,Fp:a,Fn:c}=r,f=n.outputLen,u=2*a.BYTES;if(f!==void 0&&(_e(f,"hash.outputLen"),f!==u))throw new Error(`hash.outputLen must be ${u}, got ${f}`);let l=o.randomBytes===void 0?nn:o.randomBytes,d=o.adjustScalarBytes===void 0?y=>y:o.adjustScalarBytes,p=o.domain===void 0?(y,v,k)=>{if(Re(k,"phflag"),v.length||k)throw new Error("Contexts/pre-hash are not supported");return y}:o.domain;function h(y){return c.create(Pe(y))}function b(y){let v=T.secretKey;$(y,T.secretKey,"secretKey");let k=$(n(y),2*v,"hashedSecretKey"),B=d(k.slice(0,v)),E=k.slice(v,2*v),I=h(B);return{head:B,prefix:E,scalar:I}}function m(y){let{head:v,prefix:k,scalar:B}=b(y),E=i.multiply(B),I=E.toBytes();return{head:v,prefix:k,scalar:B,point:E,pointBytes:I}}function g(y){return m(y).pointBytes}function w(y=Uint8Array.of(),...v){let k=ie(...v);return h(n(p(k,$(y,void 0,"context"),!!s)))}function x(y,v,k={}){y=$(y,void 0,"message"),s&&(y=s(y));let{prefix:B,scalar:E,pointBytes:I}=m(v),L=w(k.context,B,y),N=i.multiply(L).toBytes(),R=w(k.context,N,I,y),O=c.create(L+R*E);if(!c.isValid(O))throw new Error("sign failed: invalid s");let P=ie(N,c.toBytes(O));return $(P,T.signature,"result")}let S={zip215:o.zip215};function C(y,v,k,B=S){let{context:E}=B,I=B.zip215===void 0?!!S.zip215:B.zip215,L=T.signature;y=$(y,L,"signature"),v=$(v,void 0,"message"),k=$(k,T.publicKey,"publicKey"),I!==void 0&&Re(I,"zip215"),s&&(v=s(v));let N=L/2,R=y.subarray(0,N),O=Pe(y.subarray(N,L)),P,z,M;try{P=r.fromBytes(k,I),z=r.fromBytes(R,I),M=i.multiplyUnsafe(O)}catch{return!1}if(!I&&P.isSmallOrder())return!1;let se=w(E,R,k,v);return z.add(P.multiplyUnsafe(se)).subtract(M).clearCofactor().is0()}let D=a.BYTES,T={secretKey:D,publicKey:D,signature:2*D,seed:D};function A(y){return y=y===void 0?l(T.seed):y,$(y,T.seed,"seed")}function F(y){return Vt(y)&&y.length===T.secretKey}function G(y,v){try{return!!r.fromBytes(y,v===void 0?S.zip215:v)}catch{return!1}}let K={getExtendedPublicKey:m,randomSecretKey:A,isValidSecretKey:F,isValidPublicKey:G,toMontgomery(y){let{y:v}=r.fromBytes(y),k=T.publicKey,B=k===32;if(!B&&k!==57)throw new Error("only defined for 25519 and 448");let E=B?a.div(fe+v,fe-v):a.div(v-fe,v+fe);return a.toBytes(E)},toMontgomerySecret(y){let v=T.secretKey;$(y,v);let k=n(y.subarray(0,v));return d(k).subarray(0,v)}};return Object.freeze(T),Object.freeze(K),Object.freeze({keygen:go(A,g),getPublicKey:g,sign:x,verify:C,utils:K,Point:r,lengths:T})}function un(r,e){if(_e(r),_e(e),e<0||e>4)throw new Error("invalid I2OSP length: "+e);if(r<0||r>2**(8*e)-1)throw new Error("invalid I2OSP input: "+r);let t=Array.from({length:e}).fill(0);for(let n=e-1;n>=0;n--)t[n]=r&255,r>>>=8;return new Uint8Array(t)}function v0(r,e){let t=new Uint8Array(r.length);for(let n=0;n<r.length;n++)t[n]=r[n]^e[n];return t}function E0(r){if(!Vt(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let e=typeof r=="string"?ho(r):r;if(e.length===0)throw new Error("DST must be non-empty");return e}function Ii(r,e,t,n){$(r),_e(t),e=E0(e),e.length>255&&(e=n(ie(ho("H2C-OVERSIZE-DST-"),e)));let{outputLen:o,blockLen:s}=n,i=Math.ceil(t/o);if(t>65535||i>255)throw new Error("expand_message_xmd: invalid lenInBytes");let a=ie(e,un(e.length,1)),c=new Uint8Array(s),f=un(t,2),u=new Array(i),l=n(ie(c,r,f,un(0,1),a));u[0]=n(ie(l,un(1,1),a));for(let p=1;p<i;p++){let h=[v0(l,u[p-1]),un(p+1,1),a];u[p]=n(ie(...h))}return ie(...u).slice(0,t)}var Df="HashToScalar-";var B0=BigInt(0),tt=BigInt(1),Rf=BigInt(2);var A0=BigInt(5),S0=BigInt(8),yr=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Li={p:yr,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:S0,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function k0(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),o=BigInt(80),s=yr,a=r*r%s*r%s,c=Y(a,Rf,s)*a%s,f=Y(c,tt,s)*r%s,u=Y(f,A0,s)*f%s,l=Y(u,e,s)*u%s,d=Y(l,t,s)*l%s,p=Y(d,n,s)*d%s,h=Y(p,o,s)*p%s,b=Y(h,o,s)*p%s,m=Y(b,e,s)*u%s;return{pow_p_5_8:Y(m,Rf,s)*r%s,b2:a}}function C0(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Ti=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Di(r,e){let t=yr,n=te(e*e*e,t),o=te(n*n*e,t),s=k0(r*o).pow_p_5_8,i=te(r*n*s,t),a=te(e*i*i,t),c=i,f=te(i*Ti,t),u=a===r,l=a===te(-r,t),d=a===te(-r*Ti,t);return u&&(i=c),(l||d)&&(i=f),et(i,t)&&(i=te(-i,t)),{isValid:u||l,value:i}}var wt=Uf(Li,{uvRatio:Di}),bt=wt.Fp,Ff=wt.Fn;function I0(r){return Lf(wt,He,Object.assign({adjustScalarBytes:C0,zip215:!0},r))}var Ri=I0({});var Ni=Ti,T0=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),N0=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),U0=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),L0=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),_f=r=>Di(tt,r),D0=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Ui=r=>bt.create(Pe(r)&D0);function Of(r){let{d:e}=Li,t=yr,n=g=>bt.create(g),o=n(Ni*r*r),s=n((o+tt)*U0),i=BigInt(-1),a=n((i-e*o)*n(o+e)),{isValid:c,value:f}=Di(s,a),u=n(f*r);et(u,t)||(u=n(-u)),c||(f=u),c||(i=o);let l=n(i*(o-tt)*L0-a),d=f*f,p=n((f+f)*a),h=n(l*T0),b=n(tt-d),m=n(tt+d);return new wt(n(p*m),n(b*h),n(h*m),n(p*b))}var xt=class r extends yo{static BASE=new r(wt.BASE);static ZERO=new r(wt.ZERO);static Fp=bt;static Fn=Ff;constructor(e){super(e)}static fromAffine(e){return new r(wt.fromAffine(e))}assertSame(e){if(!(e instanceof r))throw new Error("RistrettoPoint expected")}init(e){return new r(e)}static fromBytes(e){ve(e,32);let{a:t,d:n}=Li,o=yr,s=S=>bt.create(S),i=Ui(e);if(!hf(bt.toBytes(i),e)||et(i,o))throw new Error("invalid ristretto255 encoding 1");let a=s(i*i),c=s(tt+t*a),f=s(tt-t*a),u=s(c*c),l=s(f*f),d=s(t*n*u-l),{isValid:p,value:h}=_f(s(d*l)),b=s(h*f),m=s(h*b*d),g=s((i+i)*b);et(g,o)&&(g=s(-g));let w=s(c*m),x=s(g*w);if(!p||et(x,o)||w===B0)throw new Error("invalid ristretto255 encoding 2");return new r(new wt(g,w,tt,x))}static fromHex(e){return r.fromBytes(Qr(e))}toBytes(){let{X:e,Y:t,Z:n,T:o}=this.ep,s=yr,i=m=>bt.create(m),a=i(i(n+t)*i(n-t)),c=i(e*t),f=i(c*c),{value:u}=_f(i(a*f)),l=i(u*a),d=i(u*c),p=i(l*d*o),h;if(et(o*p,s)){let m=i(t*Ni),g=i(e*Ni);e=m,t=g,h=i(l*N0)}else h=d;et(e*p,s)&&(t=i(-t));let b=i((n-t)*h);return et(b,s)&&(b=i(-b)),bt.toBytes(b)}equals(e){this.assertSame(e);let{X:t,Y:n}=this.ep,{X:o,Y:s}=e.ep,i=f=>bt.create(f),a=i(t*s)===i(n*o),c=i(n*s)===i(t*o);return a||c}is0(){return this.equals(r.ZERO)}};Object.freeze(xt.BASE);Object.freeze(xt.ZERO);Object.freeze(xt.prototype);Object.freeze(xt);var R0=Object.freeze({Point:xt,hashToCurve(r,e){let t=e?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":e.DST,n=Ii(r,t,64,He);return R0.deriveToCurve(n)},hashToScalar(r,e={DST:Df}){let t=Ii(r,e.DST,64,He);return Ff.create(Pe(t))},deriveToCurve(r){ve(r,64);let e=Ui(r.subarray(0,32)),t=Of(e),n=Ui(r.subarray(32,64)),o=Of(n);return new xt(t.add(o))}});var wr=32,Te=64,_0=32;var br,Vf=(async()=>{try{return await ne.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function O0(r,e){let t;r.length===Te?t=r.subarray(0,32):t=r;let n={crv:"Ed25519",kty:"OKP",x:j(r.subarray(32),"base64url"),d:j(t,"base64url"),ext:!0,key_ops:["sign"]},o=await ne.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),s=await ne.get().subtle.sign({name:"Ed25519"},o,Z(e instanceof Uint8Array?e:e.subarray()));return new Uint8Array(s,0,s.byteLength)}function F0(r,e){let t=r.subarray(0,_0);return Ri.sign(e instanceof Uint8Array?e:e.subarray(),t)}async function Kf(r,e){return br==null&&(br=await Vf),br?O0(r,e):F0(r,e)}async function V0(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await ne.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await ne.get().subtle.verify({name:"Ed25519"},n,Z(e),Z(t instanceof Uint8Array?t:t.subarray()))}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function K0(r,e,t){return Ri.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function Mf(r,e,t){return br==null&&(br=await Vf),br?V0(r,e,t):K0(r,e,t)}function M0(r){return r?.buffer instanceof ArrayBuffer}function Pf(r){if(M0(r))return r;let e=r.slice();return new Uint8Array(e.buffer,0,e.byteLength)}function _i(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=Xn(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return Pf(t)}function xr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var bo=class{type="Ed25519";raw;constructor(e){this.raw=hn(e,wr)}toMultihash(){return Lt.digest(ar(this))}toCID(){return ke.createV1(114,this.toMultihash())}toString(){return oe.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let o=Mf(this.raw,t,e);return xr(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}},ln=class{type="Ed25519";raw;publicKey;constructor(e,t){this.raw=hn(e,Te),this.publicKey=new bo(t)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}sign(e,t){t?.signal?.throwIfAborted();let n=Kf(this.raw,e);return xr(n)?n.then(o=>(t?.signal?.throwIfAborted(),o)):(t?.signal?.throwIfAborted(),n)}};function Oi(r){if(r.length>Te){r=hn(r,Te+wr);let n=r.subarray(0,Te),o=r.subarray(Te,r.length);return new ln(n,o)}r=hn(r,Te);let e=r.subarray(0,Te),t=r.subarray(wr);return new ln(e,t)}function hn(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new _(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}function vt(r=0){return new Uint8Array(r)}var H0=Math.pow(2,7),P0=Math.pow(2,14),$0=Math.pow(2,21),$f=Math.pow(2,28),qf=Math.pow(2,35),jf=Math.pow(2,42),zf=Math.pow(2,49),be=128,Et=127;function dn(r){if(r<H0)return 1;if(r<P0)return 2;if(r<$0)return 3;if(r<$f)return 4;if(r<qf)return 5;if(r<jf)return 6;if(r<zf)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Gf(r,e,t=0){switch(dn(r)){case 8:e[t++]=r&255|be,r/=128;case 7:e[t++]=r&255|be,r/=128;case 6:e[t++]=r&255|be,r/=128;case 5:e[t++]=r&255|be,r/=128;case 4:e[t++]=r&255|be,r>>>=7;case 3:e[t++]=r&255|be,r>>>=7;case 2:e[t++]=r&255|be,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Zf(r,e){let t=r[e],n=0;if(n+=t&Et,t<be||(t=r[e+1],n+=(t&Et)<<7,t<be)||(t=r[e+2],n+=(t&Et)<<14,t<be)||(t=r[e+3],n+=(t&Et)<<21,t<be)||(t=r[e+4],n+=(t&Et)*$f,t<be)||(t=r[e+5],n+=(t&Et)*qf,t<be)||(t=r[e+6],n+=(t&Et)*jf,t<be)||(t=r[e+7],n+=(t&Et)*zf,t<be))return n;throw new RangeError("Could not decode varint")}var Fi=new Float32Array([-0]),Bt=new Uint8Array(Fi.buffer);function Yf(r,e,t){Fi[0]=r,e[t]=Bt[0],e[t+1]=Bt[1],e[t+2]=Bt[2],e[t+3]=Bt[3]}function Jf(r,e){return Bt[0]=r[e],Bt[1]=r[e+1],Bt[2]=r[e+2],Bt[3]=r[e+3],Fi[0]}var Vi=new Float64Array([-0]),me=new Uint8Array(Vi.buffer);function Xf(r,e,t){Vi[0]=r,e[t]=me[0],e[t+1]=me[1],e[t+2]=me[2],e[t+3]=me[3],e[t+4]=me[4],e[t+5]=me[5],e[t+6]=me[6],e[t+7]=me[7]}function Wf(r,e){return me[0]=r[e],me[1]=r[e+1],me[2]=r[e+2],me[3]=r[e+3],me[4]=r[e+4],me[5]=r[e+5],me[6]=r[e+6],me[7]=r[e+7],Vi[0]}var q0=BigInt(Number.MAX_SAFE_INTEGER),j0=BigInt(Number.MIN_SAFE_INTEGER),Se=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 $t;if(e<q0&&e>j0)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,o=e-(n<<32n);return t&&(n=~n|0n,o=~o|0n,++o>Qf&&(o=0n,++n>Qf&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(e){if(e===0)return $t;let t=e<0;t&&(e=-e);let n=e>>>0,o=(e-n)/4294967296>>>0;return t&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}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):$t}},$t=new Se(0,0);$t.toBigInt=function(){return 0n};$t.zzEncode=$t.zzDecode=function(){return this};$t.length=function(){return 1};var Qf=4294967296n;function eu(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 tu(r,e,t){if(t-e<1)return"";let o,s=[],i=0,a;for(;e<t;)a=r[e++],a<128?s[i++]=a:a>191&&a<224?s[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,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function Ki(r,e,t){let n=t,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128);return t-n}function Fe(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function wo(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Mi=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,Fe(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 Fe(this,4);return wo(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Fe(this,4);return wo(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Fe(this,4);let e=Jf(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Fe(this,4);let e=Wf(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 Fe(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return tu(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Fe(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Fe(this);while((this.buf[this.pos++]&128)!==0);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 Se(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 Fe(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 Fe(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 Fe(this,8);let e=wo(this.buf,this.pos+=4),t=wo(this.buf,this.pos+=4);return new Se(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=Zf(this.buf,this.pos);return this.pos+=dn(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 pn(r){return new Mi(r instanceof Uint8Array?r:r.subarray())}function xo(r,e,t){let n=pn(r);return e.decode(n,void 0,t)}var ji={};V(ji,{base10:()=>W0});var Fx=new Uint8Array(0);function nu(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function rt(r){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 ou(r){return new TextEncoder().encode(r)}function su(r){return new TextDecoder().decode(r)}function z0(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 o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var b=0,m=0,g=0,w=h.length;g!==w&&h[g]===0;)g++,b++;for(var x=(w-g)*u+1>>>0,S=new Uint8Array(x);g!==w;){for(var C=h[g],D=0,T=x-1;(C!==0||D<m)&&T!==-1;T--,D++)C+=256*S[T]>>>0,S[T]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");m=D,g++}for(var A=x-m;A!==x&&S[A]===0;)A++;for(var F=c.repeat(b);A<x;++A)F+=r.charAt(S[A]);return F}function d(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var b=0;if(h[b]!==" "){for(var m=0,g=0;h[b]===c;)m++,b++;for(var w=(h.length-b)*f+1>>>0,x=new Uint8Array(w);h[b];){var S=t[h.charCodeAt(b)];if(S===255)return;for(var C=0,D=w-1;(S!==0||C<g)&&D!==-1;D--,C++)S+=a*x[D]>>>0,x[D]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");g=C,b++}if(h[b]!==" "){for(var T=w-g;T!==w&&x[T]===0;)T++;for(var A=new Uint8Array(m+(w-T)),F=m;T!==w;)A[F++]=x[T++];return A}}}function p(h){var b=d(h);if(b)return b;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:d,decode:p}}var G0=z0,Z0=G0,au=Z0;var Hi=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")}},Pi=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let o=t.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,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 cu(this,e)}},$i=class{decoders;constructor(e){this.decoders=e}or(e){return cu(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 cu(r,e){return new $i({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var qi=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new Hi(e,t,n),this.decoder=new Pi(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function vr({name:r,prefix:e,encode:t,decode:n}){return new qi(r,e,t,n)}function At({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=au(t,r);return vr({prefix:e,name:r,encode:n,decode:s=>rt(o(s))})}function Y0(r,e,t,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*t/8|0),i=0,a=0,c=0;for(let f=0;f<o;++f){let u=e[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|u,i+=t,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function J0(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;(s.length*t&7)!==0;)s+="=";return s}function X0(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function W({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let o=X0(n);return vr({prefix:e,name:r,encode(s){return J0(s,n,t)},decode(s){return Y0(s,o,t,r)}})}var W0=At({prefix:"9",name:"base10",alphabet:"0123456789"});var zi={};V(zi,{base16:()=>Q0,base16upper:()=>ep});var Q0=W({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ep=W({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Gi={};V(Gi,{base2:()=>tp});var tp=W({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Zi={};V(Zi,{base256emoji:()=>ip});var fu=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}"),rp=fu.reduce((r,e,t)=>(r[t]=e,r),[]),np=fu.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function op(r){return r.reduce((e,t)=>(e+=rp[t],e),"")}function sp(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let o=np[n];if(o==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(o)}return new Uint8Array(e)}var ip=vr({prefix:"\u{1F680}",name:"base256emoji",encode:op,decode:sp});var Yi={};V(Yi,{base32:()=>Er,base32hex:()=>up,base32hexpad:()=>hp,base32hexpadupper:()=>dp,base32hexupper:()=>lp,base32pad:()=>cp,base32padupper:()=>fp,base32upper:()=>ap,base32z:()=>pp});var Er=W({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ap=W({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),cp=W({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),fp=W({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),up=W({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),lp=W({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),hp=W({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),dp=W({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),pp=W({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ji={};V(Ji,{base36:()=>mn,base36upper:()=>mp});var mn=At({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),mp=At({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Xi={};V(Xi,{base58btc:()=>$e,base58flickr:()=>gp});var $e=At({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),gp=At({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Wi={};V(Wi,{base64:()=>yp,base64pad:()=>bp,base64url:()=>wp,base64urlpad:()=>xp});var yp=W({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),bp=W({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),wp=W({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),xp=W({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Qi={};V(Qi,{base8:()=>vp});var vp=W({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ea={};V(ea,{identity:()=>Ep});var Ep=vr({prefix:"\0",name:"identity",encode:r=>su(r),decode:r=>ou(r)});var Qx=new TextEncoder,e1=new TextDecoder;var ra={};V(ra,{identity:()=>jp});var Sp=hu,uu=128,kp=127,Cp=~kp,Ip=Math.pow(2,31);function hu(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Ip;)e[t++]=r&255|uu,r/=128;for(;r&Cp;)e[t++]=r&255|uu,r>>>=7;return e[t]=r|0,hu.bytes=t-n+1,e}var Tp=ta,Np=128,lu=127;function ta(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw ta.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&lu)<<o:(i&lu)*Math.pow(2,o),o+=7}while(i>=Np);return ta.bytes=s-n,t}var Up=Math.pow(2,7),Lp=Math.pow(2,14),Dp=Math.pow(2,21),Rp=Math.pow(2,28),_p=Math.pow(2,35),Op=Math.pow(2,42),Fp=Math.pow(2,49),Vp=Math.pow(2,56),Kp=Math.pow(2,63),Mp=function(r){return r<Up?1:r<Lp?2:r<Dp?3:r<Rp?4:r<_p?5:r<Op?6:r<Fp?7:r<Vp?8:r<Kp?9:10},Hp={encode:Sp,decode:Tp,encodingLength:Mp},Pp=Hp,gn=Pp;function yn(r,e=0){return[gn.decode(r,e),gn.decode.bytes]}function Br(r,e,t=0){return gn.encode(r,e,t),e}function Ar(r){return gn.encodingLength(r)}function kr(r,e){let t=e.byteLength,n=Ar(r),o=n+Ar(t),s=new Uint8Array(o+t);return Br(r,s,0),Br(t,s,n),s.set(e,o),new Sr(r,t,e,s)}function du(r){let e=rt(r),[t,n]=yn(e),[o,s]=yn(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Sr(t,o,i,e)}function pu(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&nu(r.bytes,t.bytes)}}var Sr=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};var mu=0,$p="identity",gu=rt;function qp(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return kr(mu,gu(r))}var jp={code:mu,name:$p,encode:gu,digest:qp};var sa={};V(sa,{sha256:()=>Gp,sha512:()=>Zp});var zp=20;function oa({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:o}){return new na(r,e,t,n,o)}var na=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,o,s){this.name=e,this.code=t,this.encode=n,this.minDigestLength=o??zp,this.maxDigestLength=s}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?yu(n,this.code,t?.truncate):n.then(o=>yu(o,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function yu(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return kr(e,r)}function wu(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Gp=oa({name:"sha2-256",code:18,encode:wu("SHA-256")}),Zp=oa({name:"sha2-512",code:19,encode:wu("SHA-512")});function xu(r,e){let{bytes:t,version:n}=r;return n===0?Jp(t,ia(r),e??$e.encoder):Xp(t,ia(r),e??Er.encoder)}var vu=new WeakMap;function ia(r){let e=vu.get(r);if(e==null){let t=new Map;return vu.set(r,t),t}return e}var Eo=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,this.multihash=n,this.bytes=o,this["/"]=o}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!==wn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Wp)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=kr(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&&pu(e.multihash,n.multihash)}toString(e){return xu(this,e)}toJSON(){return{"/":xu(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:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??Eu(n,o,s.bytes))}else if(t[Qp]===!0){let{version:n,multihash:o,code:s}=t,i=du(o);return r.create(n,s,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!==wn)throw new Error(`Version 0 CID must use dag-pb (code: ${wn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Eu(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,wn,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,o=rt(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new Sr(t.multihashCode,t.digestSize,s,o);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,d]=yn(e.subarray(t));return t+=d,l},o=n(),s=wn;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=Yp(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ia(s).set(n,e),s}};function Yp(r,e){switch(r[0]){case"Q":{let t=e??$e;return[$e.prefix,t.decode(`${$e.prefix}${r}`)]}case $e.prefix:{let t=e??$e;return[$e.prefix,t.decode(r)]}case Er.prefix:{let t=e??Er;return[Er.prefix,t.decode(r)]}case mn.prefix:{let t=e??mn;return[mn.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function Jp(r,e,t){let{prefix:n}=t;if(n!==$e.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function Xp(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var wn=112,Wp=18;function Eu(r,e,t){let n=Ar(r),o=n+Ar(e),s=new Uint8Array(o+t.byteLength);return Br(r,s,0),Br(e,s,n),s.set(t,o),s}var Qp=Symbol.for("@ipld/js-cid/CID");var aa={...ea,...Gi,...Qi,...ji,...zi,...Yi,...Ji,...Xi,...Wi,...Zi},E1={...sa,...ra};function Au(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Bu=Au("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ca=Au("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=vt(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),em={utf8:Bu,"utf-8":Bu,hex:aa.base16,latin1:ca,ascii:ca,binary:ca,...aa},Su=em;function ku(r,e="utf8"){let t=Su[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function fa(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return vt(i);o+i>e&&(n=vt(e),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var qt=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function ua(){}var ha=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},tm=fa();function rm(r){return globalThis.Buffer!=null?vt(r):tm(r)}var vn=class{len;head;tail;states;constructor(){this.len=0,this.head=new qt(ua,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new qt(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new da((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(Bo,10,Se.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Se.fromBigInt(e);return this._push(Bo,t.length(),t)}uint64Number(e){return this._push(Gf,dn(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=Se.fromBigInt(e).zzEncode();return this._push(Bo,t.length(),t)}sint64Number(e){let t=Se.fromNumber(e).zzEncode();return this._push(Bo,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(la,1,e?1:0)}fixed32(e){return this._push(xn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Se.fromBigInt(e);return this._push(xn,4,t.lo)._push(xn,4,t.hi)}fixed64Number(e){let t=Se.fromNumber(e);return this._push(xn,4,t.lo)._push(xn,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(Yf,4,e)}double(e){return this._push(Xf,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(la,1,0):this.uint32(t)._push(om,t,e)}string(e){let t=eu(e);return t!==0?this.uint32(t)._push(Ki,t,e):this._push(la,1,0)}fork(){return this.states=new ha(this),this.head=this.tail=new qt(ua,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 qt(ua,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=rm(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function la(r,e,t){e[t]=r&255}function nm(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var da=class extends qt{next;constructor(e,t){super(nm,e,t),this.next=void 0}};function Bo(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 xn(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 om(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(vn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(sm,e,r),this},vn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(im,e,r),this});function sm(r,e,t){e.set(r,t)}function im(r,e,t){r.length<40?Ki(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(ku(r),t)}function pa(){return new vn}function Ao(r,e){let t=pa();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}function*So(r,e,t){let n=pn(r);yield*e.stream(n,void 0,"$",t)}var ko={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function Co(r,e,t,n,o){return{name:r,type:e,encode:t,decode:n,stream:o}}function ma(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(i,a){let c=e(i);a.int32(c)},n=function(i){let a=i.int32();return e(a)},o=function*(i){let a=i.int32();yield e(a)};return Co("enum",ko.VARINT,t,n,o)}function Io(r,e,t){return Co("message",ko.LENGTH_DELIMITED,r,e,t)}var re;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(re||(re={}));var ga;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ga||(ga={}));(function(r){r.codec=()=>ma(ga)})(re||(re={}));var St;(function(r){let e;r.codec=()=>(e==null&&(e=Io((s,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),s.Type!=null&&(i.uint32(8),re.codec().encode(s.Type,i)),s.Data!=null&&(i.uint32(18),i.bytes(s.Data)),a.lengthDelimited!==!1&&i.ldelim()},(s,i,a={})=>{let c={},f=i==null?s.len:s.pos+i;for(;s.pos<f;){let u=s.uint32();switch(u>>>3){case 1:{c.Type=re.codec().decode(s);break}case 2:{c.Data=s.bytes();break}default:{s.skipType(u&7);break}}}return c},function*(s,i,a,c={}){let f=i==null?s.len:s.pos+i;for(;s.pos<f;){let u=s.uint32();switch(u>>>3){case 1:{yield{field:`${a}.Type`,value:re.codec().decode(s)};break}case 2:{yield{field:`${a}.Data`,value:s.bytes()};break}default:{s.skipType(u&7);break}}}})),e);function t(s){return Ao(s,r.codec())}r.encode=t;function n(s,i){return xo(s,r.codec(),i)}r.decode=n;function o(s,i){return So(s,r.codec(),i)}r.stream=o})(St||(St={}));var En;(function(r){let e;r.codec=()=>(e==null&&(e=Io((s,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),s.Type!=null&&(i.uint32(8),re.codec().encode(s.Type,i)),s.Data!=null&&(i.uint32(18),i.bytes(s.Data)),a.lengthDelimited!==!1&&i.ldelim()},(s,i,a={})=>{let c={},f=i==null?s.len:s.pos+i;for(;s.pos<f;){let u=s.uint32();switch(u>>>3){case 1:{c.Type=re.codec().decode(s);break}case 2:{c.Data=s.bytes();break}default:{s.skipType(u&7);break}}}return c},function*(s,i,a,c={}){let f=i==null?s.len:s.pos+i;for(;s.pos<f;){let u=s.uint32();switch(u>>>3){case 1:{yield{field:`${a}.Type`,value:re.codec().decode(s)};break}case 2:{yield{field:`${a}.Data`,value:s.bytes()};break}default:{s.skipType(u&7);break}}}})),e);function t(s){return Ao(s,r.codec())}r.encode=t;function n(s,i){return xo(s,r.codec(),i)}r.decode=n;function o(s,i){return So(s,r.codec(),i)}r.stream=o})(En||(En={}));function jt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0");return oo(r)}var An={};V(An,{MAX_RSA_KEY_SIZE:()=>ya,generateRSAKeyPair:()=>Uu,jwkToJWKKeyPair:()=>Lu,jwkToPkcs1:()=>um,jwkToPkix:()=>va,jwkToRSAPrivateKey:()=>Aa,pkcs1MessageToJwk:()=>wa,pkcs1MessageToRSAPrivateKey:()=>To,pkcs1ToJwk:()=>fm,pkcs1ToRSAPrivateKey:()=>Ea,pkixMessageToJwk:()=>xa,pkixMessageToRSAPublicKey:()=>Ba,pkixToJwk:()=>lm,pkixToRSAPublicKey:()=>Nu});var Cr=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=An.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ke.createV1(114,this._multihash)}toString(){return oe.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}verify(e,t,n){return Tu(this.jwk,t,e,n)}},Bn=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=An.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}sign(e,t){return Iu(this.jwk,e,t)}};var ya=8192,ba=18,am=1062,cm=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function fm(r){let e=Ue(r);return wa(e)}function wa(r){return{n:j(r[1],"base64url"),e:j(r[2],"base64url"),d:j(r[3],"base64url"),p:j(r[4],"base64url"),q:j(r[5],"base64url"),dp:j(r[6],"base64url"),dq:j(r[7],"base64url"),qi:j(r[8],"base64url"),kty:"RSA"}}function um(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 _("JWK was missing components");return Le([ye(Uint8Array.from([0])),ye(q(r.n,"base64url")),ye(q(r.e,"base64url")),ye(q(r.d,"base64url")),ye(q(r.p,"base64url")),ye(q(r.q,"base64url")),ye(q(r.dp,"base64url")),ye(q(r.dq,"base64url")),ye(q(r.qi,"base64url"))]).subarray()}function lm(r){let e=Ue(r,{offset:0});return xa(e)}function xa(r){let e=Ue(r[1],{offset:0});return{kty:"RSA",n:j(e[0],"base64url"),e:j(e[1],"base64url")}}function va(r){if(r.n==null||r.e==null)throw new _("JWK was missing components");return Le([cm,Wr(Le([ye(q(r.n,"base64url")),ye(q(r.e,"base64url"))]))]).subarray()}function Ea(r){let e=Ue(r);return To(e)}function To(r){let e=wa(r);return Aa(e)}function Nu(r,e){if(r.byteLength>=am)throw new Wt("Key size is too large");let t=Ue(r,{offset:0});return Ba(t,r,e)}function Ba(r,e,t){let n=xa(r);if(t==null){let o=gt(St.encode({Type:re.RSA,Data:e}));t=Ke(ba,o)}return new Cr(n,t)}function Aa(r){if(Ru(r)>ya)throw new _("Key size is too large");let e=Lu(r),t=gt(St.encode({Type:re.RSA,Data:va(e.publicKey)})),n=Ke(ba,t);return new Bn(e.privateKey,new Cr(e.publicKey,n))}async function Uu(r){if(r>ya)throw new _("Key size is too large");let e=await Du(r),t=gt(St.encode({Type:re.RSA,Data:va(e.publicKey)})),n=Ke(ba,t);return new Bn(e.privateKey,new Cr(e.publicKey,n))}function Lu(r){if(r==null)throw new _("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Du(r,e){let t=await ne.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let n=await hm(t,e);return{privateKey:n[0],publicKey:n[1]}}async function Iu(r,e,t){let n=await ne.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let o=await ne.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,Z(e instanceof Uint8Array?e:e.subarray()));return t?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function Tu(r,e,t,n){let o=await ne.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let s=await ne.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},o,Z(e),Z(t instanceof Uint8Array?t:t.subarray()));return n?.signal?.throwIfAborted(),s}async function hm(r,e){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required");let t=await Promise.all([ne.get().subtle.exportKey("jwk",r.privateKey),ne.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function Ru(r){if(r.kty!=="RSA")throw new _("invalid key type");if(r.n==null)throw new _("invalid key modulus");return q(r.n,"base64url").length*8}var No=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(e,t){if(cr(e),ve(t,void 0,"key"),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 n=this.blockLen,o=new Uint8Array(n);o.set(t.length>n?e.create().update(t).digest():t);for(let s=0;s<o.length;s++)o[s]^=54;this.iHash.update(o),this.oHash=e.create();for(let s=0;s<o.length;s++)o[s]^=106;this.oHash.update(o),Ee(o)}update(e){return fr(this),this.iHash.update(e),this}digestInto(e){fr(this),to(e,this),this.finished=!0;let t=e.subarray(0,this.outputLen);this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Uo=(()=>{let r=((e,t,n)=>new No(e,t).update(n).digest());return r.create=(e,t)=>new No(e,t),r})();var _u=(r,e)=>(r+(r>=0?e:-e)/Ou)/e;function dm(r,e,t){hr("scalar",r,qe,t);let[[n,o],[s,i]]=e,a=_u(i*r,t),c=_u(-o*r,t),f=r-a*n-c*s,u=-a*o-c*i,l=f<qe,d=u<qe;l&&(f=-f),d&&(u=-u);let p=an(Math.ceil(dr(t)/2))+kt;if(f<qe||f>=p||u<qe||u>=p)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:l,k1:f,k2neg:d,k2:u}}function ka(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function Sa(r,e){Oe(r);let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return Re(t.lowS,"lowS"),Re(t.prehash,"prehash"),t.format!==void 0&&ka(t.format),t}var Ca=class extends Error{constructor(e=""){super(e)}},Ve={Err:Ca,_tlv:{encode:(r,e)=>{let{Err:t}=Ve;if(_e(r,"tag"),r<0||r>255)throw new t("tlv.encode: wrong tag");if(typeof e!="string")throw new TypeError('"data" expected string, got type='+typeof e);if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,o=on(n);if(o.length/2&128)throw new t("tlv.encode: long form length too big");let s=n>127?on(o.length/2|128):"";return on(r)+s+o+e},decode(r,e){let{Err:t}=Ve;e=$(e,void 0,"DER data");let n=0;if(r<0||r>255)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let o=e[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let f=e.subarray(n,n+c);if(f.length!==c)throw new t("tlv.decode: length bytes not complete");if(f[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let u of f)i=i<<8|u;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=Ve;if(uo(r),r<qe)throw new e("integer: negative integers are not allowed");let t=on(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=Ve;if(r.length<1)throw new e("invalid signature integer: empty");if(r[0]&128)throw new e("invalid signature integer: negative");if(r.length>1&&r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Kt(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=Ve,o=$(r,void 0,"signature"),{v:s,l:i}=n.decode(48,o);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:f,l:u}=n.decode(2,c);if(u.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(f)}},hexFromSig(r){let{_tlv:e,_int:t}=Ve,n=e.encode(2,t.encode(r.r)),o=e.encode(2,t.encode(r.s)),s=n+o;return e.encode(48,s)}};Object.freeze(Ve._tlv);Object.freeze(Ve._int);Object.freeze(Ve);var qe=BigInt(0),kt=BigInt(1),Ou=BigInt(2),Lo=BigInt(3),pm=BigInt(4);function Fu(r,e={}){let t=mo("weierstrass",r,e),n=t.Fp,o=t.Fn,s=t.CURVE,{h:i,n:a}=s;Oe(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c,allowInfinityPoint:f}=e;if(c&&(!n.is0(s.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let u=Ku(n,o);function l(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function d(K,y,v){if(f&&y.is0())return Uint8Array.of(0);let{x:k,y:B}=y.toAffine(),E=n.toBytes(k);if(Re(v,"isCompressed"),v){l();let I=!n.isOdd(B);return ie(Vu(I),E)}else return ie(Uint8Array.of(4),E,n.toBytes(B))}function p(K){$(K,void 0,"Point");let{publicKey:y,publicKeyUncompressed:v}=u,k=K.length,B=K[0],E=K.subarray(1);if(f&&k===1&&B===0)return{x:n.ZERO,y:n.ZERO};if(k===y&&(B===2||B===3)){let I=n.fromBytes(E);if(!n.isValid(I))throw new Error("bad point: is not on curve, wrong x");let L=m(I),N;try{N=n.sqrt(L)}catch(P){let z=P instanceof Error?": "+P.message:"";throw new Error("bad point: is not on curve, sqrt error"+z)}l();let R=n.isOdd(N);return(B&1)===1!==R&&(N=n.neg(N)),{x:I,y:N}}else if(k===v&&B===4){let I=n.BYTES,L=n.fromBytes(E.subarray(0,I)),N=n.fromBytes(E.subarray(I,I*2));if(!g(L,N))throw new Error("bad point: is not on curve");return{x:L,y:N}}else throw new Error(`bad point: got length ${k}, expected compressed=${y} or uncompressed=${v}`)}let h=e.toBytes===void 0?d:e.toBytes,b=e.fromBytes===void 0?p:e.fromBytes;function m(K){let y=n.sqr(K),v=n.mul(y,K);return n.add(n.add(v,n.mul(K,s.a)),s.b)}function g(K,y){let v=n.sqr(y),k=m(K);return n.eql(v,k)}if(!g(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let w=n.mul(n.pow(s.a,Lo),pm),x=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(w,x)))throw new Error("bad curve params: a or b");function S(K,y,v=!1){if(!n.isValid(y)||v&&n.is0(y))throw new Error(`bad point coordinate ${K}`);return y}function C(K){if(!(K instanceof A))throw new Error("Weierstrass Point expected")}function D(K){if(!c||!c.basises)throw new Error("no endo");return dm(K,c.basises,o.ORDER)}function T(K,y,v,k,B){return v=new A(n.mul(v.X,K),v.Y,v.Z),y=fn(k,y),v=fn(B,v),y.add(v)}class A{static BASE=new A(s.Gx,s.Gy,n.ONE);static ZERO=new A(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=o;X;Y;Z;constructor(y,v,k){this.X=S("x",y),this.Y=S("y",v,!0),this.Z=S("z",k),Object.freeze(this)}static CURVE(){return s}static fromAffine(y){let{x:v,y:k}=y||{};if(!y||!n.isValid(v)||!n.isValid(k))throw new Error("invalid affine point");if(y instanceof A)throw new Error("projective point not allowed");return n.is0(v)&&n.is0(k)?A.ZERO:new A(v,k,n.ONE)}static fromBytes(y){let v=A.fromAffine(b($(y,void 0,"point")));return v.assertValidity(),v}static fromHex(y){return A.fromBytes(lr(y))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,v=!0){return G.createCache(this,y),v||this.multiply(Lo),this}assertValidity(){let y=this;if(y.is0()){if(e.allowInfinityPoint&&n.is0(y.X)&&n.eql(y.Y,n.ONE)&&n.is0(y.Z))return;throw new Error("bad point: ZERO")}let{x:v,y:k}=y.toAffine();if(!n.isValid(v)||!n.isValid(k))throw new Error("bad point: x or y not field elements");if(!g(v,k))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(y)}equals(y){C(y);let{X:v,Y:k,Z:B}=this,{X:E,Y:I,Z:L}=y,N=n.eql(n.mul(v,L),n.mul(E,B)),R=n.eql(n.mul(k,L),n.mul(I,B));return N&&R}negate(){return new A(this.X,n.neg(this.Y),this.Z)}double(){let{a:y,b:v}=s,k=n.mul(v,Lo),{X:B,Y:E,Z:I}=this,L=n.ZERO,N=n.ZERO,R=n.ZERO,O=n.mul(B,B),P=n.mul(E,E),z=n.mul(I,I),M=n.mul(B,E);return M=n.add(M,M),R=n.mul(B,I),R=n.add(R,R),L=n.mul(y,R),N=n.mul(k,z),N=n.add(L,N),L=n.sub(P,N),N=n.add(P,N),N=n.mul(L,N),L=n.mul(M,L),R=n.mul(k,R),z=n.mul(y,z),M=n.sub(O,z),M=n.mul(y,M),M=n.add(M,R),R=n.add(O,O),O=n.add(R,O),O=n.add(O,z),O=n.mul(O,M),N=n.add(N,O),z=n.mul(E,I),z=n.add(z,z),O=n.mul(z,M),L=n.sub(L,O),R=n.mul(z,P),R=n.add(R,R),R=n.add(R,R),new A(L,N,R)}add(y){C(y);let{X:v,Y:k,Z:B}=this,{X:E,Y:I,Z:L}=y,N=n.ZERO,R=n.ZERO,O=n.ZERO,P=s.a,z=n.mul(s.b,Lo),M=n.mul(v,E),se=n.mul(k,I),ae=n.mul(B,L),ce=n.add(v,k),ee=n.add(E,I);ce=n.mul(ce,ee),ee=n.add(M,se),ce=n.sub(ce,ee),ee=n.add(v,B);let xe=n.add(E,L);return ee=n.mul(ee,xe),xe=n.add(M,ae),ee=n.sub(ee,xe),xe=n.add(k,B),N=n.add(I,L),xe=n.mul(xe,N),N=n.add(se,ae),xe=n.sub(xe,N),O=n.mul(P,ee),N=n.mul(z,ae),O=n.add(N,O),N=n.sub(se,O),O=n.add(se,O),R=n.mul(N,O),se=n.add(M,M),se=n.add(se,M),ae=n.mul(P,ae),ee=n.mul(z,ee),se=n.add(se,ae),ae=n.sub(M,ae),ae=n.mul(P,ae),ee=n.add(ee,ae),M=n.mul(se,ee),R=n.add(R,M),M=n.mul(xe,ee),N=n.mul(ce,N),N=n.sub(N,M),M=n.mul(ce,se),O=n.mul(xe,O),O=n.add(O,M),new A(N,R,O)}subtract(y){return C(y),this.add(y.negate())}is0(){return this.equals(A.ZERO)}multiply(y){let{endo:v}=e;if(!o.isValidNot0(y))throw new RangeError("invalid scalar: out of range");let k,B,E=I=>G.cached(this,I,L=>Pt(A,L));if(v){let{k1neg:I,k1:L,k2neg:N,k2:R}=D(y),{p:O,f:P}=E(L),{p:z,f:M}=E(R);B=P.add(M),k=T(v.beta,O,z,I,N)}else{let{p:I,f:L}=E(y);k=I,B=L}return Pt(A,[k,B])[0]}multiplyUnsafe(y){let{endo:v}=e,k=this,B=y;if(!o.isValid(B))throw new RangeError("invalid scalar: out of range");if(B===qe||k.is0())return A.ZERO;if(B===kt)return k;if(G.hasCache(this))return this.multiply(B);if(v){let{k1neg:E,k1:I,k2neg:L,k2:N}=D(B),{p1:R,p2:O}=Nf(A,k,I,N);return T(v.beta,R,O,E,L)}else return G.unsafe(k,B)}toAffine(y){let v=this,k=y,{X:B,Y:E,Z:I}=v;if(n.eql(I,n.ONE))return{x:B,y:E};let L=v.is0();k==null&&(k=L?n.ONE:n.inv(I));let N=n.mul(B,k),R=n.mul(E,k),O=n.mul(I,k);if(L)return{x:n.ZERO,y:n.ZERO};if(!n.eql(O,n.ONE))throw new Error("invZ was invalid");return{x:N,y:R}}isTorsionFree(){let{isTorsionFree:y}=e;return i===kt?!0:y?y(A,this):G.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:y}=e;return i===kt?this:y?y(A,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===kt?this.is0():this.clearCofactor().is0()}toBytes(y=!0){return Re(y,"isCompressed"),this.assertValidity(),h(A,this,y)}toHex(y=!0){return ur(this.toBytes(y))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let F=o.BITS,G=new gr(A,e.endo?Math.ceil(F/2):F);return F>=8&&A.BASE.precompute(8),Object.freeze(A.prototype),Object.freeze(A),A}function Vu(r){return Uint8Array.of(r?2:3)}function Ku(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function mm(r,e={}){let{Fn:t}=r,n=e.randomBytes===void 0?nn:e.randomBytes,o=Object.assign(Ku(r.Fp,t),{seed:Math.max(Ei(t.ORDER),16)});function s(p){try{let h=t.fromBytes(p);return t.isValidNot0(h)}catch{return!1}}function i(p,h){let{publicKey:b,publicKeyUncompressed:m}=o;try{let g=p.length;return h===!0&&g!==b||h===!1&&g!==m?!1:!!r.fromBytes(p)}catch{return!1}}function a(p){return p=p===void 0?n(o.seed):p,Bi($(p,o.seed,"seed"),t.ORDER)}function c(p,h=!0){return r.BASE.multiply(t.fromBytes(p)).toBytes(h)}function f(p){let{secretKey:h,publicKey:b,publicKeyUncompressed:m}=o,g=t._lengths;if(!Vt(p))return;let w=$(p,void 0,"key").length,x=w===b||w===m,S=w===h||!!g?.includes(w);if(!(x&&S))return x}function u(p,h,b=!0){if(f(p)===!0)throw new Error("first arg must be private key");if(f(h)===!1)throw new Error("second arg must be public key");let m=t.fromBytes(p);return r.fromBytes(h).multiply(m).toBytes(b)}let l={isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:a},d=go(a,c);return Object.freeze(l),Object.freeze(o),Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:d,Point:r,utils:l,lengths:o})}function Mu(r,e,t={}){let n=e;cr(n),Oe(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let o=t.randomBytes===void 0?nn:t.randomBytes,s=t.hmac===void 0?(B,E)=>Uo(n,B,E):t.hmac,{Fp:i,Fn:a}=r,{ORDER:c,BITS:f}=a,{keygen:u,getPublicKey:l,getSharedSecret:d,utils:p,lengths:h}=mm(r,t),b={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},m=c*Ou+kt<i.ORDER;function g(B){let E=c>>kt;return B>E}function w(B,E){if(!a.isValidNot0(E))throw new Error(`invalid signature ${B}: out of range 1..Point.Fn.ORDER`);return E}function x(){if(m)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function S(B,E){ka(E);let I=h.signature,L=E==="compact"?I:E==="recovered"?I+1:void 0;return $(B,L)}class C{r;s;recovery;constructor(E,I,L){if(this.r=w("r",E),this.s=w("s",I),L!=null){if(x(),![0,1,2,3].includes(L))throw new Error("invalid recovery id");this.recovery=L}Object.freeze(this)}static fromBytes(E,I=b.format){S(E,I);let L;if(I==="der"){let{r:P,s:z}=Ve.toSig($(E));return new C(P,z)}I==="recovered"&&(L=E[0],I="compact",E=E.subarray(1));let N=h.signature/2,R=E.subarray(0,N),O=E.subarray(N,N*2);return new C(a.fromBytes(R),a.fromBytes(O),L)}static fromHex(E,I){return this.fromBytes(lr(E),I)}assertRecovery(){let{recovery:E}=this;if(E==null)throw new Error("invalid recovery id: must be present");return E}addRecoveryBit(E){return new C(this.r,this.s,E)}recoverPublicKey(E){let{r:I,s:L}=this,N=this.assertRecovery(),R=N===2||N===3?I+c:I;if(!i.isValid(R))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let O=i.toBytes(R),P=r.fromBytes(ie(Vu((N&1)===0),O)),z=a.inv(R),M=T($(E,void 0,"msgHash")),se=a.create(-M*z),ae=a.create(L*z),ce=r.BASE.multiplyUnsafe(se).add(P.multiplyUnsafe(ae));if(ce.is0())throw new Error("invalid recovery: point at infinify");return ce.assertValidity(),ce}hasHighS(){return g(this.s)}toBytes(E=b.format){if(ka(E),E==="der")return lr(Ve.hexFromSig(this));let{r:I,s:L}=this,N=a.toBytes(I),R=a.toBytes(L);return E==="recovered"?(x(),ie(Uint8Array.of(this.assertRecovery()),N,R)):ie(N,R)}toHex(E){return ur(this.toBytes(E))}}Object.freeze(C.prototype),Object.freeze(C);let D=t.bits2int===void 0?function(E){if(E.length>8192)throw new Error("input is too large");let I=Kt(E),L=E.length*8-f;return L>0?I>>BigInt(L):I}:t.bits2int,T=t.bits2int_modN===void 0?function(E){return a.create(D(E))}:t.bits2int_modN,A=an(f);function F(B){return hr("num < 2^"+f,B,qe,A),a.toBytes(B)}function G(B,E){return $(B,void 0,"message"),E?$(n(B),void 0,"prehashed message"):B}function K(B,E,I){let{lowS:L,prehash:N,extraEntropy:R}=Sa(I,b);B=G(B,N);let O=T(B),P=a.fromBytes(E);if(!a.isValidNot0(P))throw new Error("invalid private key");let z=[F(P),F(O)];if(R!=null&&R!==!1){let ce=R===!0?o(h.secretKey):R;z.push($(ce,void 0,"extraEntropy"))}let M=ie(...z),se=O;function ae(ce){let ee=D(ce);if(!a.isValidNot0(ee))return;let xe=a.inv(ee),Xt=r.BASE.multiply(ee).toAffine(),Kr=a.create(Xt.x);if(Kr===qe)return;let jn=a.create(xe*a.create(se+Kr*P));if(jn===qe)return;let uc=(Xt.x===Kr?0:2)|Number(Xt.y&kt),lc=jn;return L&&g(jn)&&(lc=a.neg(jn),uc^=1),new C(Kr,lc,m?void 0:uc)}return{seed:M,k2sig:ae}}function y(B,E,I={}){let{seed:L,k2sig:N}=K(B,E,I);return df(n.outputLen,a.BYTES,s)(L,N).toBytes(I.format)}function v(B,E,I,L={}){let{lowS:N,prehash:R,format:O}=Sa(L,b);if(I=$(I,void 0,"publicKey"),E=G(E,R),!Vt(B)){let P=B instanceof C?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+P)}S(B,O);try{let P=C.fromBytes(B,O),z=r.fromBytes(I);if(N&&P.hasHighS())return!1;let{r:M,s:se}=P,ae=T(E),ce=a.inv(se),ee=a.create(ae*ce),xe=a.create(M*ce),Xt=r.BASE.multiplyUnsafe(ee).add(z.multiplyUnsafe(xe));return Xt.is0()?!1:a.create(Xt.x)===M}catch{return!1}}function k(B,E,I={}){let{prehash:L}=Sa(I,b);return E=G(E,L),C.fromBytes(B,"recovered").recoverPublicKey(E).toBytes()}return Object.freeze({keygen:u,getPublicKey:l,getSharedSecret:d,utils:p,lengths:h,Point:r,sign:y,verify:v,recoverPublicKey:k,Signature:C,hash:n})}var Ta={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},gm={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Hu=BigInt(2);function ym(r){let e=Ta.p,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=Y(u,t,e)*u%e,d=Y(l,t,e)*u%e,p=Y(d,Hu,e)*f%e,h=Y(p,o,e)*p%e,b=Y(h,s,e)*h%e,m=Y(b,a,e)*b%e,g=Y(m,c,e)*m%e,w=Y(g,a,e)*b%e,x=Y(w,t,e)*u%e,S=Y(x,i,e)*h%e,C=Y(S,n,e)*f%e,D=Y(C,Hu,e);if(!Ia.eql(Ia.sqr(D),r))throw new Error("Cannot find square root");return D}var Ia=pr(Ta.p,{sqrt:ym}),bm=Fu(Ta,{Fp:Ia,endo:gm}),je=Mu(bm,gt);var Pu=32;function $u(r,e,t){let n=sr.digest(e instanceof Uint8Array?e:e.subarray());if(xr(n))return n.then(({digest:o})=>(t?.signal?.throwIfAborted(),je.sign(o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new Hr(String(o))});try{return je.sign(n.digest,r,{prehash:!1,format:"der"})}catch(o){throw new Hr(String(o))}}function qu(r,e,t,n){let o=sr.digest(t instanceof Uint8Array?t:t.subarray());if(xr(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),je.verify(e,s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new Pr(String(s))});try{return n?.signal?.throwIfAborted(),je.verify(e,o.digest,r,{prehash:!1,format:"der"})}catch(s){throw new Pr(String(s))}}var Do=class{type="secp256k1";raw;_key;constructor(e){this._key=Gu(e),this.raw=ju(this._key)}toMultihash(){return Lt.digest(ar(this))}toCID(){return ke.createV1(114,this.toMultihash())}toString(){return oe.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}verify(e,t,n){return qu(this._key,t,e,n)}},Ro=class{type="secp256k1";raw;publicKey;constructor(e,t){this.raw=zu(e),this.publicKey=new Do(t??Zu(e))}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Ce(this.raw,e.raw)}sign(e,t){return $u(this.raw,e,t)}};function Na(r){return new Ro(r)}function ju(r){return je.Point.fromBytes(r).toBytes()}function zu(r){try{return je.getPublicKey(r,!0),r}catch(e){throw new $r(String(e))}}function Gu(r){try{return je.Point.fromBytes(r),r}catch(e){throw new Wt(String(e))}}function Zu(r){try{return je.getPublicKey(r,!0)}catch(e){throw new $r(String(e))}}function ar(r){return St.encode({Type:re[r.type],Data:r.raw})}function Yu(r){let e=En.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case re.RSA:return Ea(t);case re.Ed25519:return Oi(t);case re.secp256k1:return Na(t);case re.ECDSA:return Gc(t);default:throw new Qt}}function Ju(r){if(r.byteLength===Te)return Oi(r);if(r.byteLength===Pu)return Na(r);let e=Ue(r),t=e[2]?.[0];if(t===Uc||t===Lc||t===Dc)return si(e);if(e.length>8)return To(e);throw new _("Could not extract private key from raw bytes")}function zt(r){return En.encode({Type:re[r.type],Data:r.raw})}var Sn=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),Ct=new Uint32Array(80),Ua=class extends _t{A=Sn[0]|0;B=Sn[1]|0;C=Sn[2]|0;D=Sn[3]|0;E=Sn[4]|0;constructor(){super(64,20,8,!1)}get(){let{A:e,B:t,C:n,D:o,E:s}=this;return[e,t,n,o,s]}set(e,t,n,o,s){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|0}process(e,t){for(let c=0;c<16;c++,t+=4)Ct[c]=e.getUint32(t,!1);for(let c=16;c<80;c++)Ct[c]=ro(Ct[c-3]^Ct[c-8]^Ct[c-14]^Ct[c-16],1);let{A:n,B:o,C:s,D:i,E:a}=this;for(let c=0;c<80;c++){let f,u;c<20?(f=so(o,s,i),u=1518500249):c<40?(f=o^s^i,u=1859775393):c<60?(f=io(o,s,i),u=2400959708):(f=o^s^i,u=3395469782);let l=ro(n,5)+f+a+u+Ct[c]|0;a=i,i=s,s=ro(o,30),o=n,n=l}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,o,s,i,a)}roundClean(){Ee(Ct)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0),Ee(this.buffer)}},Xu=en(()=>new Ua);function Wu(r,e,t,n){cr(r);let o=ef({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(Ie(s,"c"),Ie(i,"dkLen"),Ie(a,"asyncTick"),s<1)throw new Error("iterations (c) must be >= 1");if(i<1)throw new Error('"dkLen" must be >= 1');if(i>(2**32-1)*r.outputLen)throw new Error("derived key too long");let c=ai(e,"password"),f=ai(t,"salt"),u=new Uint8Array(i),l=Uo.create(r,c),d=l._cloneInto().update(f);return{c:s,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:d}}function Qu(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),Ee(o),t}function el(r,e,t,n){let{c:o,dkLen:s,DK:i,PRF:a,PRFSalt:c}=Wu(r,e,t,n),f,u=new Uint8Array(4),l=Rt(u),d=new Uint8Array(a.outputLen);for(let p=1,h=0;h<s;p++,h+=a.outputLen){let b=i.subarray(h,h+a.outputLen);l.setInt32(0,p,!1),(f=c._cloneInto(f)).update(u).digestInto(d),b.set(d.subarray(0,b.length));for(let m=1;m<o;m++){a._cloneInto(f).update(d).digestInto(d);for(let g=0;g<b.length;g++)b[g]^=d[g]}}return Qu(a,c,i,f,d)}async function _o(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Wu(r,e,t,n),u,l=new Uint8Array(4),d=Rt(l),p=new Uint8Array(c.outputLen);for(let h=1,b=0;b<s;h++,b+=c.outputLen){let m=a.subarray(b,b+c.outputLen);d.setInt32(0,h,!1),(u=f._cloneInto(u)).update(l).digestInto(p),m.set(p.subarray(0,m.length)),await Qc(o-1,i,()=>{c._cloneInto(u).update(p).digestInto(p);for(let g=0;g<m.length;g++)m[g]^=p[g]})}return Qu(c,f,a,u,p)}var tl={sha1:Xu,"sha2-256":gt,"sha2-512":He};function kn(r,e,t,n,o){if(o!=="sha1"&&o!=="sha2-256"&&o!=="sha2-512"){let a=Object.keys(tl).join(" / ");throw new _(`Hash '${o}' is unknown or not supported. Must be ${a}`)}let s=tl[o],i=el(s,r,e,{c:t,dkLen:n});return Dt.encode(i).substring(1)}var Oa={};V(Oa,{base10:()=>Sm});var Rv=new Uint8Array(0);function rl(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 nt(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 nl(r){return new TextEncoder().encode(r)}function ol(r){return new TextDecoder().decode(r)}function wm(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 o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var b=0,m=0,g=0,w=h.length;g!==w&&h[g]===0;)g++,b++;for(var x=(w-g)*u+1>>>0,S=new Uint8Array(x);g!==w;){for(var C=h[g],D=0,T=x-1;(C!==0||D<m)&&T!==-1;T--,D++)C+=256*S[T]>>>0,S[T]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");m=D,g++}for(var A=x-m;A!==x&&S[A]===0;)A++;for(var F=c.repeat(b);A<x;++A)F+=r.charAt(S[A]);return F}function d(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var b=0;if(h[b]!==" "){for(var m=0,g=0;h[b]===c;)m++,b++;for(var w=(h.length-b)*f+1>>>0,x=new Uint8Array(w);h[b];){var S=t[h.charCodeAt(b)];if(S===255)return;for(var C=0,D=w-1;(S!==0||C<g)&&D!==-1;D--,C++)S+=a*x[D]>>>0,x[D]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");g=C,b++}if(h[b]!==" "){for(var T=w-g;T!==w&&x[T]===0;)T++;for(var A=new Uint8Array(m+(w-T)),F=m;T!==w;)A[F++]=x[T++];return A}}}function p(h){var b=d(h);if(b)return b;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:d,decode:p}}var xm=wm,vm=xm,il=vm;var La=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")}},Da=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let o=t.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,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 al(this,e)}},Ra=class{decoders;constructor(e){this.decoders=e}or(e){return al(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 al(r,e){return new Ra({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var _a=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new La(e,t,n),this.decoder=new Da(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Ir({name:r,prefix:e,encode:t,decode:n}){return new _a(r,e,t,n)}function It({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=il(t,r);return Ir({prefix:e,name:r,encode:n,decode:s=>nt(o(s))})}function Em(r,e,t,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*t/8|0),i=0,a=0,c=0;for(let f=0;f<o;++f){let u=e[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|u,i+=t,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function Bm(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;(s.length*t&7)!==0;)s+="=";return s}function Am(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function Q({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let o=Am(n);return Ir({prefix:e,name:r,encode(s){return Bm(s,n,t)},decode(s){return Em(s,o,t,r)}})}var Sm=It({prefix:"9",name:"base10",alphabet:"0123456789"});var Fa={};V(Fa,{base16:()=>km,base16upper:()=>Cm});var km=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Cm=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Va={};V(Va,{base2:()=>Im});var Im=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ka={};V(Ka,{base256emoji:()=>Dm});var cl=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}"),Tm=cl.reduce((r,e,t)=>(r[t]=e,r),[]),Nm=cl.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Um(r){return r.reduce((e,t)=>(e+=Tm[t],e),"")}function Lm(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let o=Nm[n];if(o==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(o)}return new Uint8Array(e)}var Dm=Ir({prefix:"\u{1F680}",name:"base256emoji",encode:Um,decode:Lm});var Ma={};V(Ma,{base32:()=>Tr,base32hex:()=>Fm,base32hexpad:()=>Km,base32hexpadupper:()=>Mm,base32hexupper:()=>Vm,base32pad:()=>_m,base32padupper:()=>Om,base32upper:()=>Rm,base32z:()=>Hm});var Tr=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Rm=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),_m=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Om=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Fm=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Vm=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Km=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Mm=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Hm=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ha={};V(Ha,{base36:()=>Cn,base36upper:()=>Pm});var Cn=It({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Pm=It({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Pa={};V(Pa,{base58btc:()=>ze,base58flickr:()=>$m});var ze=It({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),$m=It({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var $a={};V($a,{base64:()=>qm,base64pad:()=>jm,base64url:()=>zm,base64urlpad:()=>Gm});var qm=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),jm=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),zm=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Gm=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var qa={};V(qa,{base8:()=>Zm});var Zm=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ja={};V(ja,{identity:()=>Ym});var Ym=Ir({prefix:"\0",name:"identity",encode:r=>ol(r),decode:r=>nl(r)});var Jv=new TextEncoder,Xv=new TextDecoder;var Ga={};V(Ga,{identity:()=>bg});var Wm=ll,fl=128,Qm=127,eg=~Qm,tg=Math.pow(2,31);function ll(r,e,t){e=e||[],t=t||0;for(var n=t;r>=tg;)e[t++]=r&255|fl,r/=128;for(;r⪚)e[t++]=r&255|fl,r>>>=7;return e[t]=r|0,ll.bytes=t-n+1,e}var rg=za,ng=128,ul=127;function za(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw za.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&ul)<<o:(i&ul)*Math.pow(2,o),o+=7}while(i>=ng);return za.bytes=s-n,t}var og=Math.pow(2,7),sg=Math.pow(2,14),ig=Math.pow(2,21),ag=Math.pow(2,28),cg=Math.pow(2,35),fg=Math.pow(2,42),ug=Math.pow(2,49),lg=Math.pow(2,56),hg=Math.pow(2,63),dg=function(r){return r<og?1:r<sg?2:r<ig?3:r<ag?4:r<cg?5:r<fg?6:r<ug?7:r<lg?8:r<hg?9:10},pg={encode:Wm,decode:rg,encodingLength:dg},mg=pg,In=mg;function Tn(r,e=0){return[In.decode(r,e),In.decode.bytes]}function Nr(r,e,t=0){return In.encode(r,e,t),e}function Ur(r){return In.encodingLength(r)}function Dr(r,e){let t=e.byteLength,n=Ur(r),o=n+Ur(t),s=new Uint8Array(o+t);return Nr(r,s,0),Nr(t,s,n),s.set(e,o),new Lr(r,t,e,s)}function hl(r){let e=nt(r),[t,n]=Tn(e),[o,s]=Tn(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Lr(t,o,i,e)}function dl(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&rl(r.bytes,t.bytes)}}var Lr=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};var pl=0,gg="identity",ml=nt;function yg(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return Dr(pl,ml(r))}var bg={code:pl,name:gg,encode:ml,digest:yg};var Ja={};V(Ja,{sha256:()=>xg,sha512:()=>vg});var wg=20;function Ya({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:o}){return new Za(r,e,t,n,o)}var Za=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,o,s){this.name=e,this.code=t,this.encode=n,this.minDigestLength=o??wg,this.maxDigestLength=s}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?gl(n,this.code,t?.truncate):n.then(o=>gl(o,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function gl(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return Dr(e,r)}function bl(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var xg=Ya({name:"sha2-256",code:18,encode:bl("SHA-256")}),vg=Ya({name:"sha2-512",code:19,encode:bl("SHA-512")});function wl(r,e){let{bytes:t,version:n}=r;return n===0?Bg(t,Xa(r),e??ze.encoder):Ag(t,Xa(r),e??Tr.encoder)}var xl=new WeakMap;function Xa(r){let e=xl.get(r);if(e==null){let t=new Map;return xl.set(r,t),t}return e}var Fo=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,this.multihash=n,this.bytes=o,this["/"]=o}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!==Un)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Sg)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=Dr(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&&dl(e.multihash,n.multihash)}toString(e){return wl(this,e)}toJSON(){return{"/":wl(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:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??vl(n,o,s.bytes))}else if(t[kg]===!0){let{version:n,multihash:o,code:s}=t,i=hl(o);return r.create(n,s,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!==Un)throw new Error(`Version 0 CID must use dag-pb (code: ${Un}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=vl(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Un,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,o=nt(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new Lr(t.multihashCode,t.digestSize,s,o);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,d]=Tn(e.subarray(t));return t+=d,l},o=n(),s=Un;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=Eg(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Xa(s).set(n,e),s}};function Eg(r,e){switch(r[0]){case"Q":{let t=e??ze;return[ze.prefix,t.decode(`${ze.prefix}${r}`)]}case ze.prefix:{let t=e??ze;return[ze.prefix,t.decode(r)]}case Tr.prefix:{let t=e??Tr;return[Tr.prefix,t.decode(r)]}case Cn.prefix:{let t=e??Cn;return[Cn.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function Bg(r,e,t){let{prefix:n}=t;if(n!==ze.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function Ag(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var Un=112,Sg=18;function vl(r,e,t){let n=Ur(r),o=n+Ur(e),s=new Uint8Array(o+t.byteLength);return Nr(r,s,0),Nr(e,s,n),s.set(t,o),s}var kg=Symbol.for("@ipld/js-cid/CID");var Wa={...ja,...Va,...qa,...Oa,...Fa,...Ma,...Ha,...Pa,...$a,...Ka},wE={...Ja,...Ga};function El(r=0){return new Uint8Array(r)}function Al(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Bl=Al("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Qa=Al("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=El(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Cg={utf8:Bl,"utf-8":Bl,hex:Wa.base16,latin1:Qa,ascii:Qa,binary:Qa,...Wa},Vo=Cg;function Sl(r,e="utf8"){let t=Vo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function kl(r,e="utf8"){let t=Vo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var ot="/",Cl=new TextEncoder().encode(ot),Ko=Cl[0],Ln=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=Sl(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Ko)throw new Error("Invalid key")}toString(e="utf8"){return kl(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(ot))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=Cl),this._buf[0]!==Ko){let e=new Uint8Array(this._buf.byteLength+1);e.fill(Ko,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Ko;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(ot).slice(1)}type(){return Ig(this.baseNamespace())}name(){return Tg(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(ot)||(e+=ot),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(ot):new r(e.slice(0,-1).join(ot))}child(e){return this.toString()===ot?e:e.toString()===ot?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...Ng(e.map(t=>t.namespaces()))])}};function Ig(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Tg(r){let e=r.split(":");return e[e.length-1]}function Ng(r){return[].concat(...r)}var Ch=dc(Ol(),1);var ec={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var Rr={};V(Rr,{create:()=>$g,derivedEmptyPasswordKey:()=>Mo});var Mo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function $g(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=ne.get();t*=8;async function c(l,d){let p=a.getRandomValues(new Uint8Array(s)),h=a.getRandomValues(new Uint8Array(n)),b={name:e,iv:h};typeof d=="string"&&(d=q(d));let m;if(d.length===0){m=await a.subtle.importKey("jwk",Mo,{name:"AES-GCM"},!0,["encrypt"]);try{let w={name:"PBKDF2",salt:p,iterations:i,hash:{name:o}},x=await a.subtle.importKey("raw",Z(d),{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(w,x,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",Mo,{name:"AES-GCM"},!0,["encrypt"])}}else{let w={name:"PBKDF2",salt:p,iterations:i,hash:{name:o}},x=await a.subtle.importKey("raw",Z(d),{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(w,x,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(b,m,Z(l));return _i([p,b.iv,new Uint8Array(g)])}async function f(l,d){let p=l.subarray(0,s),h=l.subarray(s,s+n),b=l.subarray(s+n),m={name:e,iv:h};typeof d=="string"&&(d=q(d));let g;if(d.length===0)try{let x={name:"PBKDF2",salt:p,iterations:i,hash:{name:o}},S=await a.subtle.importKey("raw",Z(d),{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(x,S,{name:e,length:t},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",Mo,{name:"AES-GCM"},!0,["decrypt"])}else{let x={name:"PBKDF2",salt:p,iterations:i,hash:{name:o}},S=await a.subtle.importKey("raw",Z(d),{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(x,S,{name:e,length:t},!0,["decrypt"])}let w=await a.subtle.decrypt(m,g,Z(b));return new Uint8Array(w)}return{encrypt:c,decrypt:f}}var H=dc(Fl());function Gt(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 Tt(r,e,t=-1){let n=t,o=r,s=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),s=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),s=n}let f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[s-u-1]=Math.floor(o/l),o-=f[s-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function $o(...r){let e=0,t=0;for(let s of r)e+=s.length;let n=new ArrayBuffer(e),o=new Uint8Array(n);for(let s of r)o.set(s,t),t+=s.length;return o}function rc(){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=Gt(t,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Gt(s,8)-n}function Vl(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=Tt(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Tt(e,8,n),s=new Uint8Array(o);if(s[0]&128){let i=o.slice(0),a=new Uint8Array(i);o=new ArrayBuffer(o.byteLength+1),s=new Uint8Array(o);for(let c=0;c<i.byteLength;c++)s[c+1]=a[c];s[0]=0}return o}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function Kl(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<t.length;o++)if(t[o]!==n[o])return!1;return!0}function Be(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(t)}var $E=Math.log(2);function qo(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function nc(r){let e=0,t=0;for(let o=0;o<r.length;o++){let s=r[o];e+=s.byteLength}let n=new Uint8Array(e);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),t),t+=s.byteLength}return n.buffer}function ut(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 _n=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return nc(this.items)}},Dn=[new Uint8Array([1])],Ml="0123456789";var Or="",Ye=new ArrayBuffer(0),oc=new Uint8Array(0),On="EndOfContent",Pl="OCTET STRING",$l="BIT STRING";function lt(r){var e;return e=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?H.BufferSourceConverter.toUint8Array(s.valueHex):oc}fromBER(n,o,s,i){let a=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ut(this,a,o,s))return-1;let c=o+s;return this.valueHexView=a.subarray(o,c),this.valueHexView.length?(this.blockLength=s,c):(this.warnings.push("Zero buffer length"),o)}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",Ye)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:H.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var it=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}constructor({blockLength:e=0,error:t=Or,warnings:n=[],valueBeforeDecode:o=oc}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=H.BufferSourceConverter.toUint8Array(o)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:H.Convert.ToHex(this.valueBeforeDecodeView)}}};it.NAME="baseBlock";var de=class extends it{fromBER(e,t,n,o){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'")}};de.NAME="valueBlock";var jo=class extends lt(it){constructor({idBlock:e={}}={}){var t,n,o,s;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?H.BufferSourceConverter.toUint8Array(e.valueHex):oc,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=e.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=e.isConstructed)!==null&&s!==void 0?s:!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",Ye}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!e){let s=this.tagNumber;s&=31,t|=s,o[0]=t}return o.buffer}if(!this.isHexOnly){let o=Tt(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){for(let c=0;c<i-1;c++)a[c+1]=s[c]|128;a[i]=s[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=t|31,!e){let o=this.valueHexView;for(let s=0;s<o.length-1;s++)n[s+1]=o[s]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(e,t,n){let o=H.BufferSourceConverter.toUint8Array(e);if(!ut(this,o,t,n))return-1;let s=o.subarray(t,t+n);if(s.length===0)return this.error="Zero buffer length",-1;switch(s[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=(s[0]&32)===32,this.isHexOnly=!1;let a=s[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=0;for(;;){let u=c+1;if(u>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c++,(s[u]&128)===0)break}this.blockLength=c+1;let f=this.valueHexView=new Uint8Array(c);for(let u=0;u<c;u++)f[u]=s[u+1]&127;this.blockLength<=9?this.tagNumber=Gt(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}}};jo.NAME="identificationBlock";var zo=class extends it{constructor({lenBlock:e={}}={}){var t,n,o;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=(o=e.length)!==null&&o!==void 0?o:0}fromBER(e,t,n){let o=H.BufferSourceConverter.toUint8Array(e);if(!ut(this,o,t,n))return-1;let s=o.subarray(t,t+n);if(s.length===0)return this.error="Zero buffer length",-1;if(s[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=s[0]===128,this.isIndefiniteForm)return this.blockLength=1,t+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,t+this.blockLength;let i=s[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>s.length)return this.error="End of input reached before message was fully decoded",-1;let a=t+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Gt(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 o=Tt(this.length,8);if(o.byteLength>127)return this.error="Too big length",Ye;if(t=new ArrayBuffer(o.byteLength+1),e)return t;let s=new Uint8Array(o);n=new Uint8Array(t),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[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}}};zo.NAME="lengthBlock";var U={},ue=class extends it{constructor({name:e=Or,optional:t=!1,primitiveSchema:n,...o}={},s){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new jo(o),this.lenBlock=new zo(o),this.valueBlock=s?new s(o):new de(o)}fromBER(e,t,n,o){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length,o);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 _n;t||ql(this);let o=this.idBlock.toBER(e);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(e);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(s)}return t?Ye:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():H.Convert.ToHex(this.toBER())}onAsciiEncoding(){let e=this.constructor.NAME,t=H.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${e} : ${t}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return Kl(t,n)}};ue.NAME="BaseBlock";function ql(r){var e;if(r instanceof U.Constructed)for(let t of r.valueBlock.value)ql(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((e=r.lenBlock)===null||e===void 0)&&e.isIndefiniteForm)}var Go=class extends ue{getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}constructor({value:e=Or,...t}={},n){super(t,n),e&&this.fromString(e)}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(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),o)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Go.NAME="BaseStringBlock";var Zo=class extends lt(de){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};Zo.NAME="PrimitiveValueBlock";var jl,Yo=class extends ue{constructor(e={}){super(e,Zo),this.idBlock.isConstructed=!1}};jl=Yo;U.Primitive=jl;Yo.NAME="PRIMITIVE";var Wg=100,Qg=1e4,ey=16*1024*1024,ty="Maximum ASN.1 nesting depth exceeded",ry="Maximum ASN.1 node count exceeded",ny="Maximum ASN.1 content length exceeded";function Pn(r={}){var e,t,n;return{depth:0,maxDepth:(e=r.maxDepth)!==null&&e!==void 0?e:Wg,nodesCount:0,maxNodes:(t=r.maxNodes)!==null&&t!==void 0?t:Qg,maxContentLength:(n=r.maxContentLength)!==null&&n!==void 0?n:ey}}function oy(r){let e=new ue({},de);return e.error=r,{offset:-1,result:e}}function sy(r){if(r.nodesCount+=1,r.nodesCount>r.maxNodes)return ry}function iy(r,e){if(r>e.maxContentLength)return ny}function sc(r,e,t,n){let o=n.depth+1;if(o>n.maxDepth)return oy(ty);n.depth=o;try{return zl(r,e,t,n)}finally{n.depth-=1}}function ay(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 zl(r,e=0,t=r.length,n=Pn()){let o=e,s=new ue({},de),i=new it;if(!ut(i,r,e,t))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let c=sy(n);if(c)return s.error=c,{offset:-1,result:s};let f=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),f===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=f,t-=s.idBlock.blockLength,f=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),f===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};e=f,t-=s.lenBlock.blockLength;let u=s.lenBlock.isIndefiniteForm?t:s.lenBlock.length,l=iy(u,n);if(l)return s.error=l,{offset:-1,result:s};if(!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let d=ue;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};d=U.EndOfContent;break;case 1:d=U.Boolean;break;case 2:d=U.Integer;break;case 3:d=U.BitString;break;case 4:d=U.OctetString;break;case 5:d=U.Null;break;case 6:d=U.ObjectIdentifier;break;case 10:d=U.Enumerated;break;case 12:d=U.Utf8String;break;case 13:d=U.RelativeObjectIdentifier;break;case 14:d=U.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:d=U.Sequence;break;case 17:d=U.Set;break;case 18:d=U.NumericString;break;case 19:d=U.PrintableString;break;case 20:d=U.TeletexString;break;case 21:d=U.VideotexString;break;case 22:d=U.IA5String;break;case 23:d=U.UTCTime;break;case 24:d=U.GeneralizedTime;break;case 25:d=U.GraphicString;break;case 26:d=U.VisibleString;break;case 27:d=U.GeneralString;break;case 28:d=U.UniversalString;break;case 29:d=U.CharacterString;break;case 30:d=U.BmpString;break;case 31:d=U.DATE;break;case 32:d=U.TimeOfDay;break;case 33:d=U.DateTime;break;case 34:d=U.Duration;break;default:{let p=s.idBlock.isConstructed?new U.Constructed:new U.Primitive;p.idBlock=s.idBlock,p.lenBlock=s.lenBlock,p.warnings=s.warnings,s=p}}break;default:d=s.idBlock.isConstructed?U.Constructed:U.Primitive}return s=ay(s,d),f=s.fromBER(r,e,u,n),s.valueBeforeDecodeView=r.subarray(o,o+s.blockLength),{offset:f,result:s}}function Ts(r,e={}){if(!r.byteLength){let t=new ue({},de);return t.error="Input buffer has zero length",{offset:-1,result:t}}return zl(H.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength,Pn(e))}function cy(r,e){return r?1:e}var Ge=class extends de{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n,o){let s=H.BufferSourceConverter.toUint8Array(e),i=o??Pn();if(!ut(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 a=t;for(;cy(this.isIndefiniteForm,n)>0;){let c=sc(s,a,n,i);if(c.offset===-1)return this.error=c.result.error,this.warnings.concat(c.result.warnings),-1;if(a=c.offset,this.blockLength+=c.result.blockLength,n-=c.result.blockLength,this.value.push(c.result),this.isIndefiniteForm&&c.result.constructor.NAME===On)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===On?this.value.pop():this.warnings.push("No EndOfContent block encoded")),a}toBER(e,t){let n=t||new _n;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?Ye:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};Ge.NAME="ConstructedValueBlock";var Gl,Nt=class extends ue{constructor(e={}){super(e,Ge),this.idBlock.isConstructed=!0}fromBER(e,t,n,o){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length,o);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(o=>` ${o}`).join(`
|
|
4
4
|
`));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
|
|
5
5
|
${e.join(`
|
|
6
|
-
`)}`:`${t} :`}};xu=vt;I.Constructed=xu;vt.NAME="CONSTRUCTED";var ls=class extends ue{fromBER(e,t,n){return t}toBER(e){return $e}};ls.override="EndOfContentValueBlock";var vu,hs=class extends ie{constructor(e={}){super(e,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};vu=hs;I.EndOfContent=vu;hs.NAME=nn;var Eu,Kt=class extends ie{constructor(e={}){super(e,ue),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}`}};Eu=Kt;I.Null=Eu;Kt.NAME="NULL";var ds=class extends ot(ue){get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}fromBER(e,t,n){let s=M.BufferSourceConverter.toUint8Array(e);return st(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,ki.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ds.NAME="BooleanValueBlock";var Bu,ps=class extends ie{getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}constructor(e={}){super(e,ds),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Bu=ps;I.Boolean=Bu;ps.NAME="BOOLEAN";var gs=class extends ot(je){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n,s){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=je.prototype.fromBER.call(this,e,t,n,s),o===-1)return o;for(let i=0;i<this.value.length;i++){let a=this.value[i].constructor.NAME;if(a===nn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(a!==gu)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(e,t,n),this.blockLength=n;return o}toBER(e,t){return this.isConstructed?je.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};gs.NAME="OctetStringValueBlock";var Ni,tt=class extends ie{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},gs),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n,s){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let i=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(i.byteLength){let a=s??fn(),c=Ti(i,0,i.byteLength,a);c.offset!==-1&&c.offset===n&&(this.valueBlock.value=[c.result])}}catch{}}return super.fromBER(e,t,n,s)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return vt.prototype.onAsciiEncoding.call(this);let e=this.constructor.NAME,t=M.Convert.ToHex(this.valueBlock.valueHexView);return`${e} : ${t}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof Ni&&e.push(t.valueBlock.valueHexView);return M.BufferSourceConverter.concat(e)}};Ni=tt;I.OctetString=Ni;tt.NAME=gu;var ms=class extends ot(je){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,s){if(!n)return t;let o=-1;if(this.isConstructed){if(o=je.prototype.fromBER.call(this,e,t,n,s),o===-1)return o;for(let c of this.value){let u=c.constructor.NAME;if(u===nn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(u!==mu)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=c.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return o}let i=M.BufferSourceConverter.toUint8Array(e);if(!st(this,i,t,n))return-1;let a=i.subarray(t,t+n);if(this.unusedBits=a[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let c=a.subarray(1);try{if(c.byteLength){let u=s??fn(),l=Ti(c,0,c.byteLength,u);l.offset!==-1&&l.offset===n-1&&(this.value=[l.result])}}catch{}}return this.valueHexView=a.subarray(1),this.blockLength=a.length,t+n}toBER(e,t){if(this.isConstructed)return je.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength){let s=new Uint8Array(1);return s[0]=0,s.buffer}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}}};ms.NAME="BitStringValueBlock";var Au,ys=class extends ie{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},ms),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n,s){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n,s)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return vt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let i of t)e.push(i.toString(2).padStart(8,"0"));let n=e.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};Au=ys;I.BitString=Au;ys.NAME=mu;var Su;function md(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,u=0,l=c<i?i:c,f=0;for(let h=l;h>=0;h--,f++)!0===f<a.length?u=o[i-f]+a[c-f]+t[0]:u=o[i-f]+t[0],t[0]=u/10,!0===f>=o.length?o=ss(new Uint8Array([u%10]),o):o[i-f]=u%10;return t[0]>0&&(o=ss(t,o)),o}function pu(r){if(r>=en.length)for(let e=en.length;e<=r;e++){let t=new Uint8Array([0]),n=en[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=ss(t,n)),en.push(n)}return en[r]}function yd(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,u,l=0;for(let f=c;f>=0;f--,l++)u=o[i-l]-a[c-l]-t,!0===u<0?(t=1,o[i-l]=u+10):(t=0,o[i-l]=u);if(t>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-t,u<0)t=1,o[i-l]=u+10;else{t=0,o[i-l]=u;break}return o.slice()}var sn=class extends ot(ue){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=ki.call(this)))}constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(lu(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)!==0?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 u=0;u<8;u++)(s&1)===1&&(n===e?(t=yd(pu(n),t),i="-"):t=md(t,pu(n))),n++,s>>=1}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=du.charAt(t[c]));return a===!1&&(i+=du.charAt(0)),i}};Su=sn;sn.NAME="IntegerValueBlock";Object.defineProperty(Su.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var tn,rt=class extends ie{constructor(e={}){super(e,sn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return os(),BigInt(this.valueBlock.toString())}static fromBigInt(e){os();let t=BigInt(e),n=new rn,s=t.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(t<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${M.Convert.ToHex(a)}`)+t,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new tn({valueHex:n.final()})}convertToDER(){let e=new tn({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new tn({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};tn=rt;I.Integer=tn;rt.NAME="INTEGER";var ku,bs=class extends rt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ku=bs;I.Enumerated=ku;bs.NAME="ENUMERATED";var on=class extends ot(ue){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=M.BufferSourceConverter.toUint8Array(e);if(!st(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)!==0);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)!==0?(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=Ot(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){os();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=xt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",$e;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),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=M.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}}};on.NAME="sidBlock";var ws=class extends ue{constructor({value:e=gr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new on;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,$e;t.push(s)}return Ii(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 on;if(s>Number.MAX_SAFE_INTEGER){os();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}};ws.NAME="ObjectIdentifierValueBlock";var Iu,qe=class extends ie{getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}constructor(e={}){super(e,ws),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Iu=qe;I.ObjectIdentifier=Iu;qe.NAME="OBJECT IDENTIFIER";var an=class extends ot(et){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=M.BufferSourceConverter.toUint8Array(e);if(!st(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)!==0);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)!==0?(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=Ot(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=xt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",$e;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),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=M.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};an.NAME="relativeSidBlock";var xs=class extends ue{constructor({value:e=gr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let o=new an;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,$e;n.push(o)}return Ii(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 an;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}};xs.NAME="RelativeObjectIdentifierValueBlock";var Cu,vs=class extends ie{getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}constructor(e={}){super(e,xs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Cu=vs;I.RelativeObjectIdentifier=Cu;vs.NAME="RelativeObjectIdentifier";var Tu,Ee=class extends vt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Tu=Ee;I.Sequence=Tu;Ee.NAME="SEQUENCE";var Nu,Es=class extends vt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Nu=Es;I.Set=Nu;Es.NAME="SET";var Bs=class extends ot(ue){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=gr}toJSON(){return{...super.toJSON(),value:this.value}}};Bs.NAME="StringValueBlock";var As=class extends Bs{};As.NAME="SimpleStringValueBlock";var me=class extends cs{constructor({...e}={}){super(e,As)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,M.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 Ss=class extends me{fromBuffer(e){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=M.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Ss.NAME="Utf8StringValueBlock";var _u,nt=class extends Ss{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};_u=nt;I.Utf8String=_u;nt.NAME="UTF8String";var ks=class extends me{fromBuffer(e){this.valueBlock.value=M.Convert.ToUtf16String(e),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(e))}};ks.NAME="BmpStringValueBlock";var Lu,Is=class extends ks{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Lu=Is;I.BmpString=Lu;Is.NAME="BMPString";var Cs=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=xt(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}};Cs.NAME="UniversalStringValueBlock";var Ru,Ts=class extends Cs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ru=Ts;I.UniversalString=Ru;Ts.NAME="UniversalString";var Uu,Ns=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Uu=Ns;I.NumericString=Uu;Ns.NAME="NumericString";var Du,_s=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Du=_s;I.PrintableString=Du;_s.NAME="PrintableString";var Fu,Ls=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Fu=Ls;I.TeletexString=Fu;Ls.NAME="TeletexString";var Ou,Rs=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ou=Rs;I.VideotexString=Ou;Rs.NAME="VideotexString";var Ku,Us=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ku=Us;I.IA5String=Ku;Us.NAME="IA5String";var Vu,Ds=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Vu=Ds;I.GraphicString=Vu;Ds.NAME="GraphicString";var Hu,cn=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Hu=cn;I.VisibleString=Hu;cn.NAME="VisibleString";var Mu,Fs=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Mu=Fs;I.GeneralString=Mu;Fs.NAME="GeneralString";var Pu,Os=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Pu=Os;I.CharacterString=Pu;Os.NAME="CharacterString";var ju,un=class extends cn{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,M.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]=ve(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=ve(this.month,2),t[2]=ve(this.day,2),t[3]=ve(this.hour,2),t[4]=ve(this.minute,2),t[5]=ve(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}}};ju=un;I.UTCTime=ju;un.NAME="UTCTime";var qu,Ks=class extends un{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(){let e=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(e)}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 f=new Number(e[e.length-1]);if(isNaN(f.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 f=1,h=n.indexOf("+"),d="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(d=n.substring(h+1),n=n.substring(0,h),d.length!==2&&d.length!==4)throw new Error("Wrong input string for conversion");let m=parseInt(d.substring(0,2),10);if(isNaN(m.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*m,d.length===4){if(m=parseInt(d.substring(2,4),10),isNaN(m.valueOf()))throw new Error("Wrong input string for conversion");c=f*m}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,u)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-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,u!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(ve(this.year,4)),t.push(ve(this.month,2)),t.push(ve(this.day,2)),t.push(ve(this.hour,2)),t.push(ve(this.minute,2)),t.push(ve(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(ve(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};qu=Ks;I.GeneralizedTime=qu;Ks.NAME="GeneralizedTime";var $u,Vs=class extends nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};$u=Vs;I.DATE=$u;Vs.NAME="DATE";var zu,Hs=class extends nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};zu=Hs;I.TimeOfDay=zu;Hs.NAME="TimeOfDay";var Gu,Ms=class extends nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Gu=Ms;I.DateTime=Gu;Ms.NAME="DateTime";var Zu,Ps=class extends nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Zu=Ps;I.Duration=Zu;Ps.NAME="Duration";var Yu,js=class extends nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Yu=js;I.TIME=Yu;js.NAME="TIME";async function $s(r,e){let n=await dr.create().encrypt(r,e);return Bt.encode(n)}async function _i(r,e,t){if(r.type==="RSA")return vd(r,e,t);if(r.type==="Ed25519")return bd(r,e,t);if(r.type==="secp256k1")return wd(r,e,t);if(r.type==="ECDSA")return xd(r,e,t);throw new jt}async function bd(r,e,t="libp2p-key"){if(t==="libp2p-key")return $s(Ft(r),e);throw new U(`export format '${t}' is not supported`)}async function wd(r,e,t="libp2p-key"){if(t==="libp2p-key")return $s(Ft(r),e);throw new U("Export format is not supported")}async function xd(r,e,t="libp2p-key"){if(t==="libp2p-key")return $s(Ft(r),e);throw new U(`export format '${t}' is not supported`)}async function vd(r,e,t="pkcs-8"){if(t==="pkcs-8")return Ed(r,e);if(t==="libp2p-key")return $s(Ft(r),e);throw new U("Export format is not supported")}async function Ed(r,e){let t=Q.get(),s=new Ee({value:[new rt({value:0}),new Ee({value:[new qe({value:"1.2.840.113549.1.1.1"}),new Kt]}),new tt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Dt(16),a=await Qn(Ve,e,i,{c:1e4,dkLen:32}),c=Dt(16),u=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await t.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new Ee({value:[new tt({valueHex:i}),new rt({value:1e4}),new rt({value:32}),new Ee({value:[new qe({value:"1.2.840.113549.2.11"}),new Kt]})]}),h=new Ee({value:[new qe({value:"1.2.840.113549.1.5.13"}),new Ee({value:[new Ee({value:[new qe({value:"1.2.840.113549.1.5.12"}),f]}),new Ee({value:[new qe({value:"2.16.840.1.101.3.4.1.42"}),new tt({valueHex:c})]})]})]}),m=new Ee({value:[h,new tt({valueHex:l})]}).toBER(),x=new Uint8Array(m,0,m.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(x,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function
|
|
6
|
+
`)}`:`${t} :`}};Gl=Nt;U.Constructed=Gl;Nt.NAME="CONSTRUCTED";var Jo=class extends de{fromBER(e,t,n){return t}toBER(e){return Ye}};Jo.override="EndOfContentValueBlock";var Zl,Xo=class extends ue{constructor(e={}){super(e,Jo),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Zl=Xo;U.EndOfContent=Zl;Xo.NAME=On;var Yl,Zt=class extends ue{constructor(e={}){super(e,de),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 o=new Uint8Array(n);o[0]=5,o[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Yl=Zt;U.Null=Yl;Zt.NAME="NULL";var Wo=class extends lt(de){get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=H.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}fromBER(e,t,n){let o=H.BufferSourceConverter.toUint8Array(e);return ut(this,o,t,n)?(this.valueHexView=o.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,rc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Wo.NAME="BooleanValueBlock";var Jl,Qo=class extends ue{getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}constructor(e={}){super(e,Wo),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Jl=Qo;U.Boolean=Jl;Qo.NAME="BOOLEAN";var es=class extends lt(Ge){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n,o){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Ge.prototype.fromBER.call(this,e,t,n,o),s===-1)return s;for(let i=0;i<this.value.length;i++){let a=this.value[i].constructor.NAME;if(a===On){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(a!==Pl)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?Ge.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};es.NAME="OctetStringValueBlock";var ic,at=class extends ue{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},es),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n,o){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let i=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(i.byteLength){let a=o??Pn(),c=sc(i,0,i.byteLength,a);c.offset!==-1&&c.offset===n&&(this.valueBlock.value=[c.result])}}catch{}}return super.fromBER(e,t,n,o)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Nt.prototype.onAsciiEncoding.call(this);let e=this.constructor.NAME,t=H.Convert.ToHex(this.valueBlock.valueHexView);return`${e} : ${t}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof ic&&e.push(t.valueBlock.valueHexView);return H.BufferSourceConverter.concat(e)}};ic=at;U.OctetString=ic;at.NAME=Pl;var ts=class extends lt(Ge){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,o){if(!n)return t;let s=-1;if(this.isConstructed){if(s=Ge.prototype.fromBER.call(this,e,t,n,o),s===-1)return s;for(let c of this.value){let f=c.constructor.NAME;if(f===On){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(f!==$l)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=c.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return s}let i=H.BufferSourceConverter.toUint8Array(e);if(!ut(this,i,t,n))return-1;let a=i.subarray(t,t+n);if(this.unusedBits=a[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let c=a.subarray(1);try{if(c.byteLength){let f=o??Pn(),u=sc(c,0,c.byteLength,f);u.offset!==-1&&u.offset===n-1&&(this.value=[u.result])}}catch{}}return this.valueHexView=a.subarray(1),this.blockLength=a.length,t+n}toBER(e,t){if(this.isConstructed)return Ge.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength){let o=new Uint8Array(1);return o[0]=0,o.buffer}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}}};ts.NAME="BitStringValueBlock";var Xl,rs=class extends ue{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n,o){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n,o)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Nt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let i of t)e.push(i.toString(2).padStart(8,"0"));let n=e.join(""),o=this.constructor.NAME,s=n.substring(0,n.length-this.valueBlock.unusedBits);return`${o} : ${s}`}}};Xl=rs;U.BitString=Xl;rs.NAME=$l;var Wl;function fy(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let d=u;d>=0;d--,l++)!0===l<a.length?f=s[i-l]+a[c-l]+t[0]:f=s[i-l]+t[0],t[0]=f/10,!0===l>=s.length?s=$o(new Uint8Array([f%10]),s):s[i-l]=f%10;return t[0]>0&&(s=$o(t,s)),s}function Hl(r){if(r>=Dn.length)for(let e=Dn.length;e<=r;e++){let t=new Uint8Array([0]),n=Dn[e-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+t[0]]);t[0]=s[0]/10,n[o]=s[0]%10}t[0]>0&&(n=$o(t,n)),Dn.push(n)}return Dn[r]}function uy(r,e){let t=0,n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)f=s[i-u]-a[c-u]-t,!0===f<0?(t=1,s[i-u]=f+10):(t=0,s[i-u]=f);if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=s[i-u]-t,f<0)t=1,s[i-u]=f+10;else{t=0,s[i-u]=f;break}return s.slice()}var Fn=class extends lt(de){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=rc.call(this)))}constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Vl(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,o=0){let s=this.fromBER(e,t,n);if(s===-1)return s;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):o!==0&&i.length<o&&(o-i.length>1&&(o=i.length+1),this.valueHexView=i.subarray(o-i.length)),s}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 o=super.fromBER(e,t,n);return o===-1||this.setValueHex(),o}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,o,s=this.valueHexView,i="",a=!1;for(let c=s.byteLength-1;c>=0;c--){o=s[c];for(let f=0;f<8;f++)(o&1)===1&&(n===e?(t=uy(Hl(n),t),i="-"):t=fy(t,Hl(n))),n++,o>>=1}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=Ml.charAt(t[c]));return a===!1&&(i+=Ml.charAt(0)),i}};Wl=Fn;Fn.NAME="IntegerValueBlock";Object.defineProperty(Wl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Rn,ct=class extends ue{constructor(e={}){super(e,Fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return qo(),BigInt(this.valueBlock.toString())}static fromBigInt(e){qo();let t=BigInt(e),n=new _n,o=t.toString(16).replace(/^-/,""),s=new Uint8Array(H.Convert.FromHex(o));if(t<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${H.Convert.ToHex(a)}`)+t,u=H.BufferSourceConverter.toUint8Array(H.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new Rn({valueHex:n.final()})}convertToDER(){let e=new Rn({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new Rn({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Rn=ct;U.Integer=Rn;ct.NAME="INTEGER";var Ql,ns=class extends ct{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Ql=ns;U.Enumerated=Ql;ns.NAME="ENUMERATED";var Vn=class extends lt(de){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 o=H.BufferSourceConverter.toUint8Array(e);if(!ut(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,(s[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(s[this.blockLength-1]&128)!==0?(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=Gt(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){qo();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(t.slice(o*7,o*7+7),2)+(o+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 o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let t=Tt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Ye;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let e="";if(this.isHexOnly)e=H.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Vn.NAME="sidBlock";var os=class extends de{constructor({value:e=Or,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new Vn;if(o=s.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.value.length===0&&(s.isFirstSid=!0),this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(e){let t=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(e);if(o.byteLength===0)return this.error=this.value[n].error,Ye;t.push(o)}return nc(t)}fromString(e){this.value=[];let t=0,n=0,o="",s=!1;do if(n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1,s){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(o,10);if(isNaN(c))return;i.valueDec=c+a,s=!1}else{let i=new Vn;if(o>Number.MAX_SAFE_INTEGER){qo();let a=BigInt(o);i.valueBigInt=a}else if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,s=!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 o=this.value[n].toString();n!==0&&(e=`${e}.`),t?(o=`{${o}}`,this.value[n].isFirstSid?e=`2.{${o} - 80}`:e+=o):e+=o}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}};os.NAME="ObjectIdentifierValueBlock";var eh,Ze=class extends ue{getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}constructor(e={}){super(e,os),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};eh=Ze;U.ObjectIdentifier=eh;Ze.NAME="OBJECT IDENTIFIER";var Kn=class extends lt(it){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let o=H.BufferSourceConverter.toUint8Array(e);if(!ut(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,(s[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(s[this.blockLength-1]&128)!==0?(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=Gt(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 o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let t=Tt(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",Ye;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let e="";return this.isHexOnly?e=H.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Kn.NAME="relativeSidBlock";var ss=class extends de{constructor({value:e=Or,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new Kn;if(o=s.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(e,t){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(e);if(s.byteLength===0)return this.error=this.value[o].error,Ye;n.push(s)}return nc(n)}fromString(e){this.value=[];let t=0,n=0,o="";do{n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1;let s=new Kn;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}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 o=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(o=`{${o}}`),e+=o}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}};ss.NAME="RelativeObjectIdentifierValueBlock";var th,is=class extends ue{getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}constructor(e={}){super(e,ss),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};th=is;U.RelativeObjectIdentifier=th;is.NAME="RelativeObjectIdentifier";var rh,Ae=class extends Nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};rh=Ae;U.Sequence=rh;Ae.NAME="SEQUENCE";var nh,as=class extends Nt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};nh=as;U.Set=nh;as.NAME="SET";var cs=class extends lt(de){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Or}toJSON(){return{...super.toJSON(),value:this.value}}};cs.NAME="StringValueBlock";var fs=class extends cs{};fs.NAME="SimpleStringValueBlock";var we=class extends Go{constructor({...e}={}){super(e,fs)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,H.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);this.valueBlock.value=e}};we.NAME="SIMPLE STRING";var us=class extends we{fromBuffer(e){this.valueBlock.valueHexView=H.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=H.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=H.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(H.Convert.FromUtf8String(e)),this.valueBlock.value=e}};us.NAME="Utf8StringValueBlock";var oh,ft=class extends us{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};oh=ft;U.Utf8String=oh;ft.NAME="UTF8String";var ls=class extends we{fromBuffer(e){this.valueBlock.value=H.Convert.ToUtf16String(e),this.valueBlock.valueHexView=H.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(H.Convert.FromUtf16String(e))}};ls.NAME="BmpStringValueBlock";var sh,hs=class extends ls{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};sh=hs;U.BmpString=sh;hs.NAME="BMPString";var ds=class extends we{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);for(let o=0;o<n.length;o+=4)n[o]=n[o+3],n[o+1]=n[o+2],n[o+2]=0,n[o+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 o=0;o<t;o++){let s=Tt(e.charCodeAt(o),8),i=new Uint8Array(s);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[o*4+c+a]=i[c]}this.valueBlock.value=e}};ds.NAME="UniversalStringValueBlock";var ih,ps=class extends ds{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ih=ps;U.UniversalString=ih;ps.NAME="UniversalString";var ah,ms=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ah=ms;U.NumericString=ah;ms.NAME="NumericString";var ch,gs=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ch=gs;U.PrintableString=ch;gs.NAME="PrintableString";var fh,ys=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};fh=ys;U.TeletexString=fh;ys.NAME="TeletexString";var uh,bs=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};uh=bs;U.VideotexString=uh;bs.NAME="VideotexString";var lh,ws=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};lh=ws;U.IA5String=lh;ws.NAME="IA5String";var hh,xs=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};hh=xs;U.GraphicString=hh;xs.NAME="GraphicString";var dh,Mn=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};dh=Mn;U.VisibleString=dh;Mn.NAME="VisibleString";var ph,vs=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ph=vs;U.GeneralString=ph;vs.NAME="GeneralString";var mh,Es=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};mh=Es;U.CharacterString=mh;Es.NAME="CharacterString";var gh,Hn=class extends Mn{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 o=0;o<e.length;o++)this.valueBlock.valueHexView[o]=e.charCodeAt(o)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,H.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);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 o=parseInt(n[1],10);o>=50?this.year=1900+o:this.year=2e3+o,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]=Be(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Be(this.month,2),t[2]=Be(this.day,2),t[3]=Be(this.hour,2),t[4]=Be(this.minute,2),t[5]=Be(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}}};gh=Hn;U.UTCTime=gh;Hn.NAME="UTCTime";var yh,Bs=class extends Hn{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(){let e=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(e)}fromString(e){let t=!1,n="",o="",s=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,d=n.indexOf("+"),p="";if(d===-1&&(d=n.indexOf("-"),l=-1),d!==-1){if(p=n.substring(d+1),n=n.substring(0,d),p.length!==2&&p.length!==4)throw new Error("Wrong input string for conversion");let h=parseInt(p.substring(0,2),10);if(isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*h,p.length===4){if(h=parseInt(p.substring(2,4),10),isNaN(h.valueOf()))throw new Error("Wrong input string for conversion");c=l*h}}}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");s=l.valueOf(),o=n.substring(0,f)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*s;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 o.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*s;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(o);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(Be(this.year,4)),t.push(Be(this.month,2)),t.push(Be(this.day,2)),t.push(Be(this.hour,2)),t.push(Be(this.minute,2)),t.push(Be(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Be(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};yh=Bs;U.GeneralizedTime=yh;Bs.NAME="GeneralizedTime";var bh,As=class extends ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};bh=As;U.DATE=bh;As.NAME="DATE";var wh,Ss=class extends ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};wh=Ss;U.TimeOfDay=wh;Ss.NAME="TimeOfDay";var xh,ks=class extends ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};xh=ks;U.DateTime=xh;ks.NAME="DateTime";var vh,Cs=class extends ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};vh=Cs;U.Duration=vh;Cs.NAME="Duration";var Eh,Is=class extends ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Eh=Is;U.TIME=Eh;Is.NAME="TIME";async function Ns(r,e){let n=await Rr.create().encrypt(r,e);return Dt.encode(n)}async function ac(r,e,t){if(r.type==="RSA")return py(r,e,t);if(r.type==="Ed25519")return ly(r,e,t);if(r.type==="secp256k1")return hy(r,e,t);if(r.type==="ECDSA")return dy(r,e,t);throw new Qt}async function ly(r,e,t="libp2p-key"){if(t==="libp2p-key")return Ns(zt(r),e);throw new _(`export format '${t}' is not supported`)}async function hy(r,e,t="libp2p-key"){if(t==="libp2p-key")return Ns(zt(r),e);throw new _("Export format is not supported")}async function dy(r,e,t="libp2p-key"){if(t==="libp2p-key")return Ns(zt(r),e);throw new _(`export format '${t}' is not supported`)}async function py(r,e,t="pkcs-8"){if(t==="pkcs-8")return my(r,e);if(t==="libp2p-key")return Ns(zt(r),e);throw new _("Export format is not supported")}async function my(r,e){let t=ne.get(),o=new Ae({value:[new ct({value:0}),new Ae({value:[new Ze({value:"1.2.840.113549.1.1.1"}),new Zt]}),new at({valueHex:r.raw})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=jt(16),a=await _o(He,e,i,{c:1e4,dkLen:32}),c=jt(16),f=await t.subtle.importKey("raw",Z(a),"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:Z(c)},f,Z(s)),l=new Ae({value:[new at({valueHex:i}),new ct({value:1e4}),new ct({value:32}),new Ae({value:[new Ze({value:"1.2.840.113549.2.11"}),new Zt]})]}),d=new Ae({value:[new Ze({value:"1.2.840.113549.1.5.13"}),new Ae({value:[new Ae({value:[new Ze({value:"1.2.840.113549.1.5.12"}),l]}),new Ae({value:[new Ze({value:"2.16.840.1.101.3.4.1.42"}),new at({valueHex:c})]})]})]}),h=new Ae({value:[d,new at({valueHex:u})]}).toBER(),b=new Uint8Array(h,0,h.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(b,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function cc(r,e){try{let t=await gy(r,e);return Yu(t)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file");return yy(r,e)}async function gy(r,e){let t=Dt.decode(r);return Rr.create().decrypt(t,e)}async function yy(r,e){let t=ne.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ts(s),{iv:a,salt:c,iterations:f,keySize:u,cipherText:l}=by(i),d=await _o(He,e,c,{c:f,dkLen:u}),p=await t.subtle.importKey("raw",Z(d),"AES-CBC",!1,["decrypt"]),h=$n(await t.subtle.decrypt({name:"AES-CBC",iv:Z(a)},p,Z(l))),{result:b}=Ts(h);n=kh(b)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ts(s);n=kh(i)}else throw new _("Could not parse private key from PEM data");let o=Ju(n);if(o.type!=="RSA")throw new _("Could not parse RSA private key from PEM data");return o}function by(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new _("Only pkcs5PBES2 encrypted private keys are supported");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 _("Only pkcs5PBKDF2 key derivation functions are supported");let s=n.valueBlock.value[1],i=$n(s.valueBlock.value[0].getValue()),a=1e4,c=32;if(s.valueBlock.value.length===3)a=Number(s.valueBlock.value[1].toBigInt()),c=Number(s.valueBlock.value[2].toBigInt());else if(s.valueBlock.value.length===2)throw new _("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");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 _("Only AES-CBC encryption schemes are supported")}}}}let l=$n(f.valueBlock.value[1].getValue());return{cipherText:$n(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function kh(r){return $n(r.valueBlock.value[2].getValue())}function $n(r){return new Uint8Array(r,0,r.byteLength)}var wy="/pkcs8/",fc="/info/",qn=new WeakMap,Yt={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3};function Fr(r){return r==null||typeof r!="string"?!1:r===(0,Ch.default)(r.trim())&&r.length>0}async function pe(){let t=Math.random()*800+200;await new Promise(n=>setTimeout(n,t))}function Jt(r){return new Ln(wy+r)}function Vr(r){return new Ln(fc+r)}async function xy(r){let e=zt(r),t=await sr.digest(e);return oe.encode(t.bytes).substring(1)}var Us=class{components;init;log;self;constructor(e,t){if(this.components=e,this.log=e.logger.forComponent("libp2p:keychain"),this.init={...t,dek:{...ec,...t.dek}},this.self=t.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<Yt.minKeyLength)throw new Error(`dek.keyLength must be least ${Yt.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Yt.minSaltLength)throw new Error(`dek.saltLength must be least ${Yt.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Yt.minIterationCount)throw new Error(`dek.iterationCount must be least ${Yt.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?kn(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";qn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[pc]=["@libp2p/keychain"];static generateOptions(){let e=Object.assign({},this.options),t=Math.ceil(Yt.minSaltLength/3)*3;return e.dek!=null&&(e.dek.salt=j(jt(t),"base64")),e}static get options(){return{dek:{...ec}}}async findKeyByName(e){if(!Fr(e))throw await pe(),new _(`Invalid key name '${e}'`);let t=Vr(e);try{let n=await this.components.datastore.get(t);return JSON.parse(j(n))}catch(n){throw await pe(),this.log.error("could not read key from datastore - %e",n),new Zn(`Key '${e}' does not exist.`)}}async findKeyById(e){try{let t={prefix:fc};for await(let n of this.components.datastore.query(t)){let o=JSON.parse(j(n.value));if(o.id===e)return o}throw new _(`Key with id '${e}' does not exist.`)}catch(t){throw await pe(),t}}async importKey(e,t){if(!Fr(e))throw await pe(),new _(`Invalid key name '${e}'`);if(t==null)throw await pe(),new _("Key is required");let n=Jt(e);if(await this.components.datastore.has(n))throw await pe(),new _(`Key '${e}' already exists`);let s,i;try{s=await xy(t);let f=qn.get(this);if(f==null)throw new _("dek missing");let u=f.dek;i=await ac(t,u,t.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await pe(),f}let a={name:e,id:s},c=this.components.datastore.batch();return c.put(n,q(i)),c.put(Vr(e),q(JSON.stringify(a))),await c.commit(),a}async exportKey(e){if(!Fr(e))throw await pe(),new _(`Invalid key name '${e}'`);let t=Jt(e);try{let n=await this.components.datastore.get(t),o=j(n),s=qn.get(this);if(s==null)throw new _("dek missing");let i=s.dek;return await cc(o,i)}catch(n){throw await pe(),n}}async removeKey(e){if(!Fr(e)||e===this.self)throw await pe(),new _(`Invalid key name '${e}'`);let t=Jt(e),n=await this.findKeyByName(e),o=this.components.datastore.batch();return o.delete(t),o.delete(Vr(e)),await o.commit(),n}async listKeys(){let e={prefix:fc},t=[];for await(let n of this.components.datastore.query(e))t.push(JSON.parse(j(n.value)));return t}async renameKey(e,t){if(!Fr(e)||e===this.self)throw await pe(),new _(`Invalid old key name '${e}'`);if(!Fr(t)||t===this.self)throw await pe(),new _(`Invalid new key name '${t}'`);let n=Jt(e),o=Jt(t),s=Vr(e),i=Vr(t);if(await this.components.datastore.has(o))throw await pe(),new _(`Key '${t}' already exists`);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(s),u=JSON.parse(j(f));u.name=t;let l=this.components.datastore.batch();return l.put(o,c),l.put(i,q(JSON.stringify(u))),l.delete(n),l.delete(s),await l.commit(),u}catch(c){throw await pe(),c}}async rotateKeychainPass(e,t){if(typeof e!="string")throw await pe(),new _(`Invalid old pass type '${typeof e}'`);if(typeof t!="string")throw await pe(),new _(`Invalid new pass type '${typeof t}'`);if(t.length<20)throw await pe(),new _(`Invalid pass length ${t.length}`);this.log("recreating keychain");let n=qn.get(this);if(n==null)throw new _("dek missing");let o=n.dek;this.init.pass=t;let s=t!=null&&this.init.dek?.salt!=null?kn(t,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";qn.set(this,{dek:s});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Jt(a.name)),f=j(c),u=await cc(f,o),l=s.toString(),d=await ac(u,l,u.type==="RSA"?"pkcs-8":"libp2p-key"),p=this.components.datastore.batch(),h={name:a.name,id:a.id};p.put(Jt(a.name),q(d)),p.put(Vr(a.name),q(JSON.stringify(h))),await p.commit()}this.log("keychain reconstructed")}};function vy(r={}){return e=>new Us(e,r)}function Ey(r){return r==null?!1:typeof r.findKeyByName=="function"&&typeof r.findKeyById=="function"&&typeof r.importKey=="function"&&typeof r.exportKey=="function"&&typeof r.removeKey=="function"&&typeof r.renameKey=="function"&&typeof r.listKeys=="function"&&typeof r.rotateKeychainPass=="function"}return Dh(By);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|