@libp2p/crypto 4.1.6-a8ec2bcb7 → 4.1.7-944935f8d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PCrypto = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PCrypto=(()=>{var tc=Object.create;var Nr=Object.defineProperty;var ec=Object.getOwnPropertyDescriptor;var rc=Object.getOwnPropertyNames;var nc=Object.getPrototypeOf,sc=Object.prototype.hasOwnProperty;var oc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)Nr(r,e,{get:t[e],enumerable:!0})},vo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of rc(t))!sc.call(r,s)&&s!==e&&Nr(r,s,{get:()=>t[s],enumerable:!(n=ec(t,s))||n.enumerable});return r};var ic=(r,t,e)=>(e=r!=null?tc(nc(r)):{},vo(t||!r||!r.__esModule?Nr(e,"default",{value:r,enumerable:!0}):e,r)),ac=r=>vo(Nr({},"__esModule",{value:!0}),r);var Pi=oc(nr=>{"use strict";var Ou="[object ArrayBuffer]",Wt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Ou}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},zs="string",Pu=/^[0-9a-f]+$/i,Ku=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Mu=/^[a-zA-Z0-9-_]+$/,tn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Wt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Wt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},en=class r{static isHex(t){return typeof t===zs&&Pu.test(t)}static isBase64(t){return typeof t===zs&&Ku.test(t)}static isBase64Url(t){return typeof t===zs&&Mu.test(t)}static ToString(t,e="utf8"){let n=Wt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Wt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return tn.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return tn.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Wt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Wt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};en.DEFAULT_UTF8_ENCODING="utf8";function Fu(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function $u(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function qu(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}nr.BufferSourceConverter=Wt;nr.Convert=en;nr.assign=Fu;nr.combine=$u;nr.isEqual=qu});var Rf={};et(Rf,{hmac:()=>Rr,keys:()=>uo,pbkdf2:()=>ho,randomBytes:()=>Yt});var Rr={};et(Rr,{create:()=>Gn});var z={get(r=globalThis){let t=r.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var Eo={SHA1:20,SHA256:32,SHA512:64};var cc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},lc=async(r,t)=>{let e=await z.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Gn(r,t){let e=cc[r],n=await z.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return lc(n,s)},length:Eo[r]}}var uo={};et(uo,{Ed25519PrivateKey:()=>Zt,Ed25519PublicKey:()=>_e,MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,Secp256k1PrivateKey:()=>Oe,Secp256k1PublicKey:()=>De,generateEphemeralKeyPair:()=>_i,generateKeyPair:()=>Ef,generateKeyPairFromSeed:()=>Af,importKey:()=>Nf,keyStretcher:()=>Vi,keysPBM:()=>er,marshalPrivateKey:()=>If,marshalPublicKey:()=>Sf,supportedKeys:()=>ne,unmarshalPrivateKey:()=>$a,unmarshalPublicKey:()=>kf});var _=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var qs={};et(qs,{Ed25519PrivateKey:()=>Zt,Ed25519PublicKey:()=>_e,generateKeyPair:()=>Lu,generateKeyPairFromSeed:()=>$s,unmarshalEd25519PrivateKey:()=>_u,unmarshalEd25519PublicKey:()=>Uu});var Jn={};et(Jn,{base58btc:()=>vt,base58flickr:()=>pc});var Hf=new Uint8Array(0);function Ao(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(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 ko(r){return new TextEncoder().encode(r)}function So(r){return new TextDecoder().decode(r)}function uc(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var h=0,p=0,y=0,B=g.length;y!==B&&g[y]===0;)y++,h++;for(var b=(B-y)*l+1>>>0,C=new Uint8Array(b);y!==B;){for(var x=g[y],A=0,N=b-1;(x!==0||A<p)&&N!==-1;N--,A++)x+=256*C[N]>>>0,C[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");p=A,y++}for(var R=b-p;R!==b&&C[R]===0;)R++;for(var q=c.repeat(h);R<b;++R)q+=r.charAt(C[R]);return q}function d(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var h=0;if(g[h]!==" "){for(var p=0,y=0;g[h]===c;)p++,h++;for(var B=(g.length-h)*f+1>>>0,b=new Uint8Array(B);g[h];){var C=e[g.charCodeAt(h)];if(C===255)return;for(var x=0,A=B-1;(C!==0||x<y)&&A!==-1;A--,x++)C+=a*b[A]>>>0,b[A]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");y=x,h++}if(g[h]!==" "){for(var N=B-y;N!==B&&b[N]===0;)N++;for(var R=new Uint8Array(p+(B-N)),q=p;N!==B;)R[q++]=b[N++];return R}}}function w(g){var h=d(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:w}}var fc=uc,hc=fc,No=hc;var zn=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Zn=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ro(this,t)}},Yn=class{decoders;constructor(t){this.decoders=t}or(t){return Ro(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ro(r,t){return new Yn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Wn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new zn(t,e,n),this.decoder=new Zn(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Pe({name:r,prefix:t,encode:e,decode:n}){return new Wn(r,t,e,n)}function se({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=No(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Mt(s(o))})}function dc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function gc(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pe({prefix:t,name:r,encode(s){return gc(s,n,e)},decode(s){return dc(s,n,e,r)}})}var vt=se({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pc=se({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ts={};et(ts,{identity:()=>Qn});var yc=_o,Co=128,mc=127,bc=~mc,wc=Math.pow(2,31);function _o(r,t,e){t=t||[],e=e||0;for(var n=e;r>=wc;)t[e++]=r&255|Co,r/=128;for(;r&bc;)t[e++]=r&255|Co,r>>>=7;return t[e]=r|0,_o.bytes=e-n+1,t}var xc=Xn,Bc=128,To=127;function Xn(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Xn.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&To)<<s:(i&To)*Math.pow(2,s),s+=7}while(i>=Bc);return Xn.bytes=o-n,e}var vc=Math.pow(2,7),Ec=Math.pow(2,14),Ac=Math.pow(2,21),kc=Math.pow(2,28),Sc=Math.pow(2,35),Ic=Math.pow(2,42),Nc=Math.pow(2,49),Rc=Math.pow(2,56),Cc=Math.pow(2,63),Tc=function(r){return r<vc?1:r<Ec?2:r<Ac?3:r<kc?4:r<Sc?5:r<Ic?6:r<Nc?7:r<Rc?8:r<Cc?9:10},_c={encode:yc,decode:xc,encodingLength:Tc},Uc=_c,cr=Uc;function lr(r,t=0){return[cr.decode(r,t),cr.decode.bytes]}function Ke(r,t,e=0){return cr.encode(r,t,e),t}function Me(r){return cr.encodingLength(r)}function Ee(r,t){let e=t.byteLength,n=Me(r),s=n+Me(e),o=new Uint8Array(s+e);return Ke(r,o,0),Ke(e,o,n),o.set(t,s),new Fe(r,e,t,o)}function Uo(r){let t=Mt(r),[e,n]=lr(t),[s,o]=lr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Fe(e,s,i,t)}function Lo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ao(r.bytes,e.bytes)}}var Fe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Vo=0,Lc="identity",Ho=Mt;function Vc(r){return Ee(Vo,Ho(r))}var Qn={code:Vo,name:Lc,encode:Ho,digest:Vc};var ns={};et(ns,{sha256:()=>bt,sha512:()=>Hc});function rs({name:r,code:t,encode:e}){return new es(r,t,e)}var es=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Ee(this.code,e):e.then(n=>Ee(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Oo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var bt=rs({name:"sha2-256",code:18,encode:Oo("SHA-256")}),Hc=rs({name:"sha2-512",code:19,encode:Oo("SHA-512")});function St(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Vt(r=0){return new Uint8Array(r)}function Ft(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Vt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var ss={};et(ss,{base10:()=>Dc});var Dc=se({prefix:"9",name:"base10",alphabet:"0123456789"});var os={};et(os,{base16:()=>Oc,base16upper:()=>Pc});var Oc=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Pc=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var is={};et(is,{base2:()=>Kc});var Kc=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var as={};et(as,{base256emoji:()=>jc});var Po=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}"),Mc=Po.reduce((r,t,e)=>(r[e]=t,r),[]),Fc=Po.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function $c(r){return r.reduce((t,e)=>(t+=Mc[e],t),"")}function qc(r){let t=[];for(let e of r){let n=Fc[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var jc=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:$c,decode:qc});var cs={};et(cs,{base32:()=>$e,base32hex:()=>Yc,base32hexpad:()=>Jc,base32hexpadupper:()=>Xc,base32hexupper:()=>Wc,base32pad:()=>zc,base32padupper:()=>Zc,base32upper:()=>Gc,base32z:()=>Qc});var $e=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Gc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),zc=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Zc=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Yc=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Wc=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Jc=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Xc=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Qc=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ls={};et(ls,{base36:()=>tl,base36upper:()=>el});var tl=se({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),el=se({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var us={};et(us,{base64:()=>Ae,base64pad:()=>rl,base64url:()=>nl,base64urlpad:()=>sl});var Ae=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),rl=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),nl=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),sl=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var fs={};et(fs,{base8:()=>ol});var ol=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var hs={};et(hs,{identity:()=>il});var il=Pe({prefix:"\0",name:"identity",encode:r=>So(r),decode:r=>ko(r)});var uh=new TextEncoder,fh=new TextDecoder;function Ko(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return ul(e,ds(r),t??vt.encoder);default:return fl(e,ds(r),t??$e.encoder)}}var Mo=new WeakMap;function ds(r){let t=Mo.get(r);if(t==null){let e=new Map;return Mo.set(r,e),e}return t}var Tr=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==fr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==hl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Ee(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Lo(t.multihash,n.multihash)}toString(t){return Ko(this,t)}toJSON(){return{"/":Ko(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??Fo(n,s,o.bytes))}else if(e[dl]===!0){let{version:n,multihash:s,code:o}=e,i=Uo(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==fr)throw new Error(`Version 0 CID must use dag-pb (code: ${fr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Fo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,fr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Mt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Fe(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,d]=lr(t.subarray(e));return e+=d,u},s=n(),o=fr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=ll(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ds(o).set(n,t),o}};function ll(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case $e.prefix:{let e=t??$e;return[$e.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function ul(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function fl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var fr=112,hl=18;function Fo(r,t,e){let n=Me(r),s=n+Me(t),o=new Uint8Array(s+e.byteLength);return Ke(r,o,0),Ke(t,o,n),o.set(e,s),o}var dl=Symbol.for("@ipld/js-cid/CID");var gs={...hs,...is,...fs,...ss,...os,...cs,...ls,...Jn,...us,...as},Ih={...ns,...ts};function qo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var $o=qo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ps=qo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Vt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),gl={utf8:$o,"utf-8":$o,hex:gs.base16,latin1:ps,ascii:ps,binary:ps,...gs},_r=gl;function Z(r,t="utf8"){let e=_r[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function ys(r,t){let e=Z(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Ft([new Uint8Array(t-e.length),e])}return e}function Et(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function qe(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function pl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function je(r,...t){if(!pl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Ur(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");qe(r.outputLen),qe(r.blockLen)}function Ge(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function jo(r,t){je(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Lr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var ke=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t,Vr=(r,t)=>r<<t|r>>>32-t>>>0,Mh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var yl=async()=>{};async function Go(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await yl(),n+=o)}}function zo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function oe(r){return typeof r=="string"&&(r=zo(r)),je(r),r}function ms(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];je(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var ze=class{clone(){return this._cloneInto()}},ml={}.toString;function Zo(r,t){if(t!==void 0&&ml.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Ze(r){let t=n=>r().update(oe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ye(r=32){if(Lr&&typeof Lr.getRandomValues=="function")return Lr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function bl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}var Hr=(r,t,e)=>r&t^~r&e,Dr=(r,t,e)=>r&t^r&e^t&e,ie=class extends ze{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=ke(this.buffer)}update(t){Ge(this);let{view:e,buffer:n,blockLen:s}=this;t=oe(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=ke(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ge(this),jo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;bl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ke(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Or=BigInt(4294967295),bs=BigInt(32);function Yo(r,t=!1){return t?{h:Number(r&Or),l:Number(r>>bs&Or)}:{h:Number(r>>bs&Or)|0,l:Number(r&Or)|0}}function wl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Yo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var xl=(r,t)=>BigInt(r>>>0)<<bs|BigInt(t>>>0),Bl=(r,t,e)=>r>>>e,vl=(r,t,e)=>r<<32-e|t>>>e,El=(r,t,e)=>r>>>e|t<<32-e,Al=(r,t,e)=>r<<32-e|t>>>e,kl=(r,t,e)=>r<<64-e|t>>>e-32,Sl=(r,t,e)=>r>>>e-32|t<<64-e,Il=(r,t)=>t,Nl=(r,t)=>r,Rl=(r,t,e)=>r<<e|t>>>32-e,Cl=(r,t,e)=>t<<e|r>>>32-e,Tl=(r,t,e)=>t<<e-32|r>>>64-e,_l=(r,t,e)=>r<<e-32|t>>>64-e;function Ul(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Ll=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Vl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Hl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Dl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Ol=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Pl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Kl={fromBig:Yo,split:wl,toBig:xl,shrSH:Bl,shrSL:vl,rotrSH:El,rotrSL:Al,rotrBH:kl,rotrBL:Sl,rotr32H:Il,rotr32L:Nl,rotlSH:Rl,rotlSL:Cl,rotlBH:Tl,rotlBL:_l,add:Ul,add3L:Ll,add3H:Vl,add4L:Hl,add4H:Dl,add5H:Pl,add5L:Ol},L=Kl;var[Ml,Fl]=L.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ae=new Uint32Array(80),ce=new Uint32Array(80),ws=class extends ie{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:d,Gh:w,Gl:g,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,f,l,u,d,w,g,h,p]}set(t,e,n,s,o,i,a,c,f,l,u,d,w,g,h,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=d|0,this.Gh=w|0,this.Gl=g|0,this.Hh=h|0,this.Hl=p|0}process(t,e){for(let b=0;b<16;b++,e+=4)ae[b]=t.getUint32(e),ce[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let C=ae[b-15]|0,x=ce[b-15]|0,A=L.rotrSH(C,x,1)^L.rotrSH(C,x,8)^L.shrSH(C,x,7),N=L.rotrSL(C,x,1)^L.rotrSL(C,x,8)^L.shrSL(C,x,7),R=ae[b-2]|0,q=ce[b-2]|0,M=L.rotrSH(R,q,19)^L.rotrBH(R,q,61)^L.shrSH(R,q,6),V=L.rotrSL(R,q,19)^L.rotrBL(R,q,61)^L.shrSL(R,q,6),rt=L.add4L(N,V,ce[b-7],ce[b-16]),tt=L.add4H(rt,A,M,ae[b-7],ae[b-16]);ae[b]=tt|0,ce[b]=rt|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:d,Fh:w,Fl:g,Gh:h,Gl:p,Hh:y,Hl:B}=this;for(let b=0;b<80;b++){let C=L.rotrSH(u,d,14)^L.rotrSH(u,d,18)^L.rotrBH(u,d,41),x=L.rotrSL(u,d,14)^L.rotrSL(u,d,18)^L.rotrBL(u,d,41),A=u&w^~u&h,N=d&g^~d&p,R=L.add5L(B,x,N,Fl[b],ce[b]),q=L.add5H(R,y,C,A,Ml[b],ae[b]),M=R|0,V=L.rotrSH(n,s,28)^L.rotrBH(n,s,34)^L.rotrBH(n,s,39),rt=L.rotrSL(n,s,28)^L.rotrBL(n,s,34)^L.rotrBL(n,s,39),tt=n&o^n&a^o&a,Bt=s&i^s&c^i&c;y=h|0,B=p|0,h=w|0,p=g|0,w=u|0,g=d|0,{h:u,l:d}=L.add(f|0,l|0,q|0,M|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=L.add3L(M,rt,Bt);n=L.add3H(v,q,V,tt),s=v|0}({h:n,l:s}=L.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=L.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=L.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=L.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:d}=L.add(this.Eh|0,this.El|0,u|0,d|0),{h:w,l:g}=L.add(this.Fh|0,this.Fl|0,w|0,g|0),{h,l:p}=L.add(this.Gh|0,this.Gl|0,h|0,p|0),{h:y,l:B}=L.add(this.Hh|0,this.Hl|0,y|0,B|0),this.set(n,s,o,i,a,c,f,l,u,d,w,g,h,p,y,B)}roundClean(){ae.fill(0),ce.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Se=Ze(()=>new ws);var Kr={};et(Kr,{abytes:()=>We,bitGet:()=>Yl,bitLen:()=>Zl,bitMask:()=>hr,bitSet:()=>Wl,bytesToHex:()=>qt,bytesToNumberBE:()=>jt,bytesToNumberLE:()=>ue,concatBytes:()=>Gt,createHmacDrbg:()=>vs,ensureBytes:()=>Q,equalBytes:()=>Gl,hexToBytes:()=>Ie,hexToNumber:()=>Bs,isBytes:()=>le,numberToBytesBE:()=>fe,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>Qo,numberToVarBytesBE:()=>jl,utf8ToBytes:()=>zl,validateObject:()=>Ht});var Xo=BigInt(0),Pr=BigInt(1),$l=BigInt(2);function le(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function We(r){if(!le(r))throw new Error("Uint8Array expected")}var ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qt(r){We(r);let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}function Qo(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Bs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var $t={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Wo(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t._A&&r<=$t._F)return r-($t._A-10);if(r>=$t._a&&r<=$t._f)return r-($t._a-10)}function Ie(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=Wo(r.charCodeAt(o)),a=Wo(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function jt(r){return Bs(qt(r))}function ue(r){return We(r),Bs(qt(Uint8Array.from(r).reverse()))}function fe(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return fe(r,t).reverse()}function jl(r){return Ie(Qo(r))}function Q(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(le(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function Gt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];We(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Gl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function zl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Zl(r){let t;for(t=0;r>Xo;r>>=Pr,t+=1);return t}function Yl(r,t){return r>>BigInt(t)&Pr}function Wl(r,t,e){return r|(e?Pr:Xo)<<BigInt(t)}var hr=r=>($l<<BigInt(r-1))-Pr,xs=r=>new Uint8Array(r),Jo=r=>Uint8Array.from(r);function vs(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=xs(r),s=xs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=xs())=>{s=a(Jo([0]),u),n=a(),u.length!==0&&(s=a(Jo([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let w=n.slice();d.push(w),u+=n.length}return Gt(...d)};return(u,d)=>{i(),c(u);let w;for(;!(w=d(f()));)c();return i(),w}}var Jl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||le(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ht(r,t,e={}){let n=(s,o,i)=>{let a=Jl[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var at=BigInt(0),Y=BigInt(1),Re=BigInt(2),Xl=BigInt(3),Es=BigInt(4),ti=BigInt(5),ei=BigInt(8),Ql=BigInt(9),tu=BigInt(16);function j(r,t){let e=r%t;return e>=at?e:t+e}function eu(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Y)return at;let n=Y;for(;t>at;)t&Y&&(n=n*r%e),r=r*r%e,t>>=Y;return n}function W(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function Mr(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=j(r,t),n=t,s=at,o=Y,i=Y,a=at;for(;e!==at;){let f=n/e,l=n%e,u=s-i*f,d=o-a*f;n=e,e=l,s=i,o=a,i=u,a=d}if(n!==Y)throw new Error("invert: does not exist");return j(s,t)}function ru(r){let t=(r-Y)/Re,e,n,s;for(e=r-Y,n=0;e%Re===at;e/=Re,n++);for(s=Re;s<r&&eu(s,t,r)!==r-Y;s++);if(n===1){let i=(r+Y)/Es;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+Y)/Re;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(d);w<f&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(l,Y<<BigInt(f-w-1));l=a.sqr(g),u=a.mul(u,g),d=a.mul(d,l),f=w}return u}}function nu(r){if(r%Es===Xl){let t=(r+Y)/Es;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%ei===ti){let t=(r-ti)/ei;return function(n,s){let o=n.mul(s,Re),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Re),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%tu,ru(r)}var ri=(r,t)=>(j(r,t)&Y)===Y,su=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function As(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=su.reduce((n,s)=>(n[s]="function",n),t);return Ht(r,e)}function ou(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Y)return t;let n=r.ONE,s=t;for(;e>at;)e&Y&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Y;return n}function iu(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function ks(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Fr(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=ks(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=nu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:hr(s),ZERO:at,ONE:Y,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Y)===Y,neg:c=>j(-c,r),eql:(c,f)=>c===f,sqr:c=>j(c*c,r),add:(c,f)=>j(c+f,r),sub:(c,f)=>j(c-f,r),mul:(c,f)=>j(c*f,r),pow:(c,f)=>ou(a,c,f),div:(c,f)=>j(c*Mr(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Mr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>iu(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Ne(c,o):fe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?ue(c):jt(c)}});return Object.freeze(a)}function ni(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Ss(r){let t=ni(r);return t+Math.ceil(t/2)}function si(r,t,e=!1){let n=r.length,s=ni(t),o=Ss(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?jt(r):ue(r),a=j(i,t-Y)+Y;return e?Ne(a,s):fe(a,s)}var cu=BigInt(0),Is=BigInt(1);function $r(r,t){let e=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(t/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:e,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>cu;)o&Is&&(i=i.add(a)),a=a.double(),o>>=Is;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],f=s,l=f;for(let u=0;u<i;u++){l=f,c.push(l);for(let d=1;d<a;d++)l=l.add(f),c.push(l);f=l.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),f=r.ZERO,l=r.BASE,u=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,p=Number(i&u);i>>=w,p>c&&(p-=d,i+=Is);let y=h,B=h+Math.abs(p)-1,b=g%2!==0,C=p<0;p===0?l=l.add(e(b,o[y])):f=f.add(e(C,o[B]))}return{p:f,f:l}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,f=o.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&o.set(s,a(f))),this.wNAF(c,f,i)}}}function dr(r){return As(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ks(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),wt=BigInt(1),qr=BigInt(2),lu=BigInt(8),uu={zip215:!0};function fu(r){let t=dr(r);return Ht(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function oi(r){let t=fu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=qr<<BigInt(a*8)-wt,l=e.create,u=t.uvRatio||((E,m)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(m))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(E=>E),w=t.domain||((E,m,S)=>{if(m.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),g=E=>typeof E=="bigint"&&Nt<E,h=(E,m)=>g(E)&&g(m)&&E<m,p=E=>E===Nt||h(E,f);function y(E,m){if(h(E,m))return E;throw new Error(`Expected valid scalar < ${m}, got ${typeof E} ${E}`)}function B(E){return E===Nt?E:y(E,n)}let b=new Map;function C(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(m,S,T,U){if(this.ex=m,this.ey=S,this.ez=T,this.et=U,!p(m))throw new Error("x required");if(!p(S))throw new Error("y required");if(!p(T))throw new Error("z required");if(!p(U))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(m){if(m instanceof x)throw new Error("extended point not allowed");let{x:S,y:T}=m||{};if(!p(S)||!p(T))throw new Error("invalid affine point");return new x(S,T,wt,l(S*T))}static normalizeZ(m){let S=e.invertBatch(m.map(T=>T.ez));return m.map((T,U)=>T.toAffine(S[U])).map(x.fromAffine)}_setWindowSize(m){this._WINDOW_SIZE=m,b.delete(this)}assertValidity(){let{a:m,d:S}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:T,ey:U,ez:D,et:O}=this,$=l(T*T),K=l(U*U),F=l(D*D),nt=l(F*F),J=l($*m),lt=l(F*l(J+K)),ut=l(nt+l(S*l($*K)));if(lt!==ut)throw new Error("bad point: equation left != right (1)");let it=l(T*U),ht=l(D*O);if(it!==ht)throw new Error("bad point: equation left != right (2)")}equals(m){C(m);let{ex:S,ey:T,ez:U}=this,{ex:D,ey:O,ez:$}=m,K=l(S*$),F=l(D*U),nt=l(T*$),J=l(O*U);return K===F&&nt===J}is0(){return this.equals(x.ZERO)}negate(){return new x(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:m}=t,{ex:S,ey:T,ez:U}=this,D=l(S*S),O=l(T*T),$=l(qr*l(U*U)),K=l(m*D),F=S+T,nt=l(l(F*F)-D-O),J=K+O,lt=J-$,ut=K-O,it=l(nt*lt),ht=l(J*ut),Kt=l(nt*ut),ve=l(lt*J);return new x(it,ht,ve,Kt)}add(m){C(m);let{a:S,d:T}=t,{ex:U,ey:D,ez:O,et:$}=this,{ex:K,ey:F,ez:nt,et:J}=m;if(S===BigInt(-1)){let po=l((D-U)*(F+K)),yo=l((D+U)*(F-K)),jn=l(yo-po);if(jn===Nt)return this.double();let mo=l(O*qr*J),bo=l($*qr*nt),wo=bo+mo,xo=yo+po,Bo=bo-mo,Wa=l(wo*jn),Ja=l(xo*Bo),Xa=l(wo*Bo),Qa=l(jn*xo);return new x(Wa,Ja,Qa,Xa)}let lt=l(U*K),ut=l(D*F),it=l($*T*J),ht=l(O*nt),Kt=l((U+D)*(K+F)-lt-ut),ve=ht-it,ar=ht+it,go=l(ut-S*lt),Ga=l(Kt*ve),za=l(ar*go),Za=l(Kt*go),Ya=l(ve*ar);return new x(Ga,za,Ya,Za)}subtract(m){return this.add(m.negate())}wNAF(m){return R.wNAFCached(this,b,m,x.normalizeZ)}multiply(m){let{p:S,f:T}=this.wNAF(y(m,n));return x.normalizeZ([S,T])[0]}multiplyUnsafe(m){let S=B(m);return S===Nt?N:this.equals(N)||S===wt?this:this.equals(A)?this.wNAF(S).p:R.unsafeLadder(this,S)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(m){let{ex:S,ey:T,ez:U}=this,D=this.is0();m==null&&(m=D?lu:e.inv(U));let O=l(S*m),$=l(T*m),K=l(U*m);if(D)return{x:Nt,y:wt};if(K!==wt)throw new Error("invZ was invalid");return{x:O,y:$}}clearCofactor(){let{h:m}=t;return m===wt?this:this.multiplyUnsafe(m)}static fromHex(m,S=!1){let{d:T,a:U}=t,D=e.BYTES;m=Q("pointHex",m,D);let O=m.slice(),$=m[D-1];O[D-1]=$&-129;let K=ue(O);K===Nt||(S?y(K,f):y(K,e.ORDER));let F=l(K*K),nt=l(F-wt),J=l(T*F-U),{isValid:lt,value:ut}=u(nt,J);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let it=(ut&wt)===wt,ht=($&128)!==0;if(!S&&ut===Nt&&ht)throw new Error("Point.fromHex: x=0 and x_0=1");return ht!==it&&(ut=l(-ut)),x.fromAffine({x:ut,y:K})}static fromPrivateKey(m){return V(m).point}toRawBytes(){let{x:m,y:S}=this.toAffine(),T=Ne(S,e.BYTES);return T[T.length-1]|=m&wt?128:0,T}toHex(){return qt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,wt,l(t.Gx*t.Gy)),x.ZERO=new x(Nt,wt,wt,Nt);let{BASE:A,ZERO:N}=x,R=$r(x,a*8);function q(E){return j(E,n)}function M(E){return q(ue(E))}function V(E){let m=a;E=Q("private key",E,m);let S=Q("hashed private key",o(E),2*m),T=d(S.slice(0,m)),U=S.slice(m,2*m),D=M(T),O=A.multiply(D),$=O.toRawBytes();return{head:T,prefix:U,scalar:D,point:O,pointBytes:$}}function rt(E){return V(E).pointBytes}function tt(E=new Uint8Array,...m){let S=Gt(...m);return M(o(w(S,Q("context",E),!!s)))}function Bt(E,m,S={}){E=Q("message",E),s&&(E=s(E));let{prefix:T,scalar:U,pointBytes:D}=V(m),O=tt(S.context,T,E),$=A.multiply(O).toRawBytes(),K=tt(S.context,$,D,E),F=q(O+K*U);B(F);let nt=Gt($,Ne(F,e.BYTES));return Q("result",nt,a*2)}let v=uu;function I(E,m,S,T=v){let{context:U,zip215:D}=T,O=e.BYTES;E=Q("signature",E,2*O),m=Q("message",m),s&&(m=s(m));let $=ue(E.slice(O,2*O)),K,F,nt;try{K=x.fromHex(S,D),F=x.fromHex(E.slice(0,O),D),nt=A.multiplyUnsafe($)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let J=tt(U,F.toRawBytes(),K.toRawBytes(),m);return F.add(K.multiplyUnsafe(J)).subtract(nt).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:Bt,verify:I,ExtendedPoint:x,utils:{getExtendedPublicKey:V,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,m=x.BASE){return m._setWindowSize(E),m.multiply(BigInt(3)),m}}}}var Ns=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ii=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),ud=BigInt(0),hu=BigInt(1),ai=BigInt(2),fd=BigInt(3),du=BigInt(5),gu=BigInt(8);function pu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ns,a=r*r%o*r%o,c=W(a,ai,o)*a%o,f=W(c,hu,o)*r%o,l=W(f,du,o)*f%o,u=W(l,t,o)*l%o,d=W(u,e,o)*u%o,w=W(d,n,o)*d%o,g=W(w,s,o)*w%o,h=W(g,s,o)*w%o,p=W(h,t,o)*l%o;return{pow_p_5_8:W(p,ai,o)*r%o,b2:a}}function yu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function mu(r,t){let e=Ns,n=j(t*t*t,e),s=j(n*n*t,e),o=pu(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,f=j(i*ii,e),l=a===r,u=a===j(-r,e),d=a===j(-r*ii,e);return l&&(i=c),(u||d)&&(i=f),ri(i,e)&&(i=j(-i,e)),{isValid:l||u,value:i}}var bu=Fr(Ns,void 0,!0),wu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:bu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:gu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Se,randomBytes:Ye,adjustScalarBytes:yu,uvRatio:mu},Je=oi(wu);var Xe=32,zt=64,jr=32;function ci(){let r=Je.utils.randomPrivateKey(),t=Je.getPublicKey(r);return{privateKey:hi(r,t),publicKey:t}}function li(r){if(r.length!==jr)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=Je.getPublicKey(t);return{privateKey:hi(t,e),publicKey:e}}function ui(r,t){let e=r.subarray(0,jr);return Je.sign(t instanceof Uint8Array?t:t.subarray(),e)}function fi(r,t,e){return Je.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function hi(r,t){let e=new Uint8Array(zt);for(let n=0;n<jr;n++)e[n]=r[n],e[jr+n]=t[n];return e}var Rs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Gr(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=z.get();e*=8;async function c(u,d){let w=a.getRandomValues(new Uint8Array(o)),g=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:g};typeof d=="string"&&(d=Z(d));let p;if(d.length===0){p=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}let y=await a.subtle.encrypt(h,p,u);return Ft([w,h.iv,new Uint8Array(y)])}async function f(u,d){let w=u.subarray(0,o),g=u.subarray(o,o+n),h=u.subarray(o+n),p={name:t,iv:g};typeof d=="string"&&(d=Z(d));let y;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(b,C,{name:t,length:e},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(b,C,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(p,y,h);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}async function Qe(r,t){let n=await Gr().encrypt(r,t);return Ae.encode(n)}var er={};et(er,{KeyType:()=>G,PrivateKey:()=>Tt,PublicKey:()=>Ct});var Bu=Math.pow(2,7),vu=Math.pow(2,14),Eu=Math.pow(2,21),gi=Math.pow(2,28),pi=Math.pow(2,35),yi=Math.pow(2,42),mi=Math.pow(2,49),pt=128,he=127;function gr(r){if(r<Bu)return 1;if(r<vu)return 2;if(r<Eu)return 3;if(r<gi)return 4;if(r<pi)return 5;if(r<yi)return 6;if(r<mi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function bi(r,t,e=0){switch(gr(r)){case 8:t[e++]=r&255|pt,r/=128;case 7:t[e++]=r&255|pt,r/=128;case 6:t[e++]=r&255|pt,r/=128;case 5:t[e++]=r&255|pt,r/=128;case 4:t[e++]=r&255|pt,r>>>=7;case 3:t[e++]=r&255|pt,r>>>=7;case 2:t[e++]=r&255|pt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function wi(r,t){let e=r[t],n=0;if(n+=e&he,e<pt||(e=r[t+1],n+=(e&he)<<7,e<pt)||(e=r[t+2],n+=(e&he)<<14,e<pt)||(e=r[t+3],n+=(e&he)<<21,e<pt)||(e=r[t+4],n+=(e&he)*gi,e<pt)||(e=r[t+5],n+=(e&he)*pi,e<pt)||(e=r[t+6],n+=(e&he)*yi,e<pt)||(e=r[t+7],n+=(e&he)*mi,e<pt))return n;throw new RangeError("Could not decode varint")}var Cs=new Float32Array([-0]),de=new Uint8Array(Cs.buffer);function xi(r,t,e){Cs[0]=r,t[e]=de[0],t[e+1]=de[1],t[e+2]=de[2],t[e+3]=de[3]}function Bi(r,t){return de[0]=r[t],de[1]=r[t+1],de[2]=r[t+2],de[3]=r[t+3],Cs[0]}var Ts=new Float64Array([-0]),dt=new Uint8Array(Ts.buffer);function vi(r,t,e){Ts[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function Ei(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],Ts[0]}var Au=BigInt(Number.MAX_SAFE_INTEGER),ku=BigInt(Number.MIN_SAFE_INTEGER),xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Ce;if(t<Au&&t>ku)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ai&&(s=0n,++n>Ai&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ce;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Ce}},Ce=new xt(0,0);Ce.toBigInt=function(){return 0n};Ce.zzEncode=Ce.zzDecode=function(){return this};Ce.length=function(){return 1};var Ai=4294967296n;function ki(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Si(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&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 _s(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Rt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function zr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Us=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Rt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Rt(this,4);return zr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Rt(this,4);return zr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Rt(this,4);let t=Bi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Rt(this,4);let t=Ei(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Rt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Si(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Rt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Rt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Rt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Rt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Rt(this,8);let t=zr(this.buf,this.pos+=4),e=zr(this.buf,this.pos+=4);return new xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=wi(this.buf,this.pos);return this.pos+=gr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Ls(r){return new Us(r instanceof Uint8Array?r:r.subarray())}function Zr(r,t,e){let n=Ls(r);return t.decode(n,void 0,e)}function Vs(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Vt(i);s+i>t&&(n=Vt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Te=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Hs(){}var Os=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Su=Vs();function Iu(r){return globalThis.Buffer!=null?Vt(r):Su(r)}var yr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Te(Hs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Te(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ps((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Yr,10,xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=xt.fromBigInt(t);return this._push(Yr,e.length(),e)}uint64Number(t){return this._push(bi,gr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=xt.fromBigInt(t).zzEncode();return this._push(Yr,e.length(),e)}sint64Number(t){let e=xt.fromNumber(t).zzEncode();return this._push(Yr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ds,1,t?1:0)}fixed32(t){return this._push(pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=xt.fromBigInt(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64Number(t){let e=xt.fromNumber(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(xi,4,t)}double(t){return this._push(vi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ds,1,0):this.uint32(e)._push(Ru,e,t)}string(t){let e=ki(t);return e!==0?this.uint32(e)._push(_s,e,t):this._push(Ds,1,0)}fork(){return this.states=new Os(this),this.head=this.tail=new Te(Hs,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 Te(Hs,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Iu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ds(r,t,e){t[e]=r&255}function Nu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ps=class extends Te{next;constructor(t,e){super(Nu,t,e),this.next=void 0}};function Yr(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function pr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ru(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(yr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Cu,t,r),this},yr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Tu,t,r),this});function Cu(r,t,e){t.set(r,e)}function Tu(r,t,e){r.length<40?_s(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function Ks(){return new yr}function Wr(r,t){let e=Ks();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function Jr(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ms(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Jr("enum",tr.VARINT,e,n)}function Xr(r,t){return Jr("message",tr.LENGTH_DELIMITED,r,t)}var G;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(G||(G={}));var Fs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Fs||(Fs={}));(function(r){r.codec=()=>Ms(Fs)})(G||(G={}));var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=Xr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Wr(e,r.codec()),r.decode=e=>Zr(e,r.codec())})(Ct||(Ct={}));var Tt;(function(r){let t;r.codec=()=>(t==null&&(t=Xr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Wr(e,r.codec()),r.decode=e=>Zr(e,r.codec())})(Tt||(Tt={}));var _e=class{_key;constructor(t){this._key=rr(t,Xe)}verify(t,e){return fi(this._key,e,t)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}},Zt=class{_key;_publicKey;constructor(t,e){this._key=rr(t,zt),this._publicKey=rr(e,Xe)}sign(t){return ui(this._key,t)}get public(){return new _e(this._publicKey)}marshal(){return this._key}get bytes(){return Tt.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Et(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Qn.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Qe(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function _u(r){if(r.length>zt){r=rr(r,zt+Xe);let n=r.subarray(0,zt),s=r.subarray(zt,r.length);return new Zt(n,s)}r=rr(r,zt);let t=r.subarray(0,zt),e=r.subarray(Xe);return new Zt(t,e)}function Uu(r){return r=rr(r,Xe),new _e(r)}async function Lu(){let{privateKey:r,publicKey:t}=ci();return new Zt(r,t)}async function $s(r){let{privateKey:t,publicKey:e}=li(r);return new Zt(t,e)}function rr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function st(r,t="utf8"){let e=_r[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ni={"P-256":256,"P-384":384,"P-521":521},Vu=Object.keys(Ni),js=Vu.join(" / ");async function Ri(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${js}`,"ERR_INVALID_CURVE");let t=await z.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(o,i)=>{let a;i!=null?a=await z.get().subtle.importKey("jwk",Du(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await z.get().subtle.importKey("jwk",Ti(r,o),{name:"ECDH",namedCurve:r},!1,[]),f=await z.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ni[r]);return new Uint8Array(f,0,f.byteLength)},n=await z.get().subtle.exportKey("jwk",t.publicKey);return{key:Hu(n),genSharedKey:e}}var Ci={"P-256":32,"P-384":48,"P-521":66};function Hu(r){if(r.crv==null||r.x==null||r.y==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new _(`Unknown curve: ${r.crv}. Must be ${js}`,"ERR_INVALID_CURVE");let t=Ci[r.crv];return Ft([Uint8Array.from([4]),ys(r.x,t),ys(r.y,t)],1+t*2)}function Ti(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${js}`,"ERR_INVALID_CURVE");let e=Ci[r];if(!St(t.subarray(0,1),Uint8Array.from([4])))throw new _("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:st(t.subarray(1,e+1),"base64url"),y:st(t.subarray(1+e),"base64url"),ext:!0}}var Du=(r,t)=>({...Ti(r,t.public),d:st(t.private,"base64url")});var _i=Ri;async function Ui(r,t){let e=Ae.decode(r);return Gr().decrypt(e,t)}var Li={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Vi(r,t,e){let n=Li[r];if(n==null){let B=Object.keys(Li).join(" / ");throw new _(`unknown cipher type '${r}'. Must be ${B}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new _("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,o=n.ivSize,i=20,a=Z("key expansion"),c=2*(o+s+i),f=await Gn(t,e),l=await f.digest(a),u=[],d=0;for(;d<c;){let B=await f.digest(Ft([l,a])),b=B.length;d+b>c&&(b=c-d),u.push(B),d+=b,l=await f.digest(l)}let w=c/2,g=Ft(u),h=g.subarray(0,w),p=g.subarray(w,c),y=B=>({iv:B.subarray(0,o),cipherKey:B.subarray(o,o+s),macKey:B.subarray(o+s)});return{k1:y(h),k2:y(p)}}var ro={};et(ro,{MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,fromJwk:()=>cf,generateKeyPair:()=>lf,unmarshalRsaPrivateKey:()=>to,unmarshalRsaPublicKey:()=>af});function Yt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Ye(r)}var me={};et(me,{exportToPem:()=>rf,importFromPem:()=>Qs,jwkToPkcs1:()=>Xu,jwkToPkix:()=>tf,pkcs1ToJwk:()=>Ju,pkixToJwk:()=>Qu});var Qr=class extends ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Ur(t);let n=oe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ge(this),this.iHash.update(t),this}digestInto(t){Ge(this),je(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},mr=(r,t,e)=>new Qr(r,t).update(e).digest();mr.create=(r,t)=>new Qr(r,t);function Hi(r,t,e,n){Ur(r);let s=Zo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(qe(o),qe(i),qe(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=oe(t),f=oe(e),l=new Uint8Array(i),u=mr.create(r,c),d=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:d}}function Di(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Oi(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Hi(r,t,e,n),f,l=new Uint8Array(4),u=ke(l),d=new Uint8Array(a.outputLen);for(let w=1,g=0;g<o;w++,g+=a.outputLen){let h=i.subarray(g,g+a.outputLen);u.setInt32(0,w,!1),(f=c._cloneInto(f)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let p=1;p<s;p++){a._cloneInto(f).update(d).digestInto(d);for(let y=0;y<h.length;y++)h[y]^=d[y]}}return Di(a,c,i,f,d)}async function Gs(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Hi(r,t,e,n),l,u=new Uint8Array(4),d=ke(u),w=new Uint8Array(c.outputLen);for(let g=1,h=0;h<o;g++,h+=c.outputLen){let p=a.subarray(h,h+c.outputLen);d.setInt32(0,g,!1),(l=f._cloneInto(l)).update(u).digestInto(w),p.set(w.subarray(0,p.length)),await Go(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let y=0;y<p.length;y++)p[y]^=w[y]})}return Di(c,f,a,l,w)}var P=ic(Pi());function Ue(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ge(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function rn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function Zs(){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 t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Ue(e,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,Ue(o,8)-n}function Ki(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=ge(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ge(t,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}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Mi(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function mt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var L0=Math.log(2);function nn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ys(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function te(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var wr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ys(this.items)}},br=[new Uint8Array([1])],Fi="0123456789";var or="",Ut=new ArrayBuffer(0),Ws=new Uint8Array(0),xr="EndOfContent",qi="OCTET STRING",ji="BIT STRING";function ee(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?P.BufferSourceConverter.toUint8Array(o.valueHex):Ws}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!te(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Jt=class{constructor({blockLength:t=0,error:e=or,warnings:n=[],valueBeforeDecode:s=Ws}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};Jt.NAME="baseBlock";var gt=class extends Jt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};gt.NAME="valueBlock";var sn=class extends ee(Jt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?P.BufferSourceConverter.toUint8Array(t.valueHex):Ws,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Ut}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ge(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){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]=e|31,!t){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(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!te(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let d=new Uint8Array(l);for(let w=0;w<f.length;w++)d[w]=f[w];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=f[d];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Ue(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};sn.NAME="identificationBlock";var on=class extends Jt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!te(this,s,e,n))return-1;let o=s.subarray(e,e+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,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+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=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ue(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ut;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};on.NAME="lengthBlock";var k={},ft=class extends Jt{constructor({name:t=or,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new sn(s),this.lenBlock=new on(s),this.valueBlock=o?new o(s):new gt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new wr;e||Gi(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():P.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Mi(e,n)}};ft.NAME="BaseBlock";function Gi(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)Gi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var an=class extends ft{constructor({value:t=or,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};an.NAME="BaseStringBlock";var cn=class extends ee(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};cn.NAME="PrimitiveValueBlock";var zi,ln=class extends ft{constructor(t={}){super(t,cn),this.idBlock.isConstructed=!1}};zi=ln;k.Primitive=zi;ln.NAME="PRIMITIVE";function Gu(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Fn(r,t=0,e=r.length){let n=t,s=new ft({},gt),o=new Jt;if(!te(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ft;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let f=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Gu(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ir(r){if(!r.byteLength){let t=new ft({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Fn(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function zu(r,t){return r?1:t}var Dt=class extends gt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!te(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;zu(this.isIndefiniteForm,n)>0;){let i=Fn(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===xr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===xr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new wr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Dt.NAME="ConstructedValueBlock";var Zi,pe=class extends ft{constructor(t={}){super(t,Dt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
2
|
+
"use strict";var Libp2PCrypto=(()=>{var tc=Object.create;var Nr=Object.defineProperty;var ec=Object.getOwnPropertyDescriptor;var rc=Object.getOwnPropertyNames;var nc=Object.getPrototypeOf,sc=Object.prototype.hasOwnProperty;var oc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)Nr(r,e,{get:t[e],enumerable:!0})},vo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of rc(t))!sc.call(r,s)&&s!==e&&Nr(r,s,{get:()=>t[s],enumerable:!(n=ec(t,s))||n.enumerable});return r};var ic=(r,t,e)=>(e=r!=null?tc(nc(r)):{},vo(t||!r||!r.__esModule?Nr(e,"default",{value:r,enumerable:!0}):e,r)),ac=r=>vo(Nr({},"__esModule",{value:!0}),r);var Pi=oc(nr=>{"use strict";var Ou="[object ArrayBuffer]",Wt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Ou}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},zs="string",Pu=/^[0-9a-f]+$/i,Ku=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Mu=/^[a-zA-Z0-9-_]+$/,tn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Wt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Wt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},en=class r{static isHex(t){return typeof t===zs&&Pu.test(t)}static isBase64(t){return typeof t===zs&&Ku.test(t)}static isBase64Url(t){return typeof t===zs&&Mu.test(t)}static ToString(t,e="utf8"){let n=Wt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Wt.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return tn.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return tn.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Wt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Wt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};en.DEFAULT_UTF8_ENCODING="utf8";function Fu(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function $u(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function qu(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}nr.BufferSourceConverter=Wt;nr.Convert=en;nr.assign=Fu;nr.combine=$u;nr.isEqual=qu});var Rf={};et(Rf,{hmac:()=>Rr,keys:()=>uo,pbkdf2:()=>ho,randomBytes:()=>Yt});var Rr={};et(Rr,{create:()=>Gn});var z={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var Eo={SHA1:20,SHA256:32,SHA512:64};var cc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},lc=async(r,t)=>{let e=await z.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Gn(r,t){let e=cc[r],n=await z.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return lc(n,s)},length:Eo[r]}}var uo={};et(uo,{Ed25519PrivateKey:()=>Zt,Ed25519PublicKey:()=>_e,MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,Secp256k1PrivateKey:()=>Oe,Secp256k1PublicKey:()=>De,generateEphemeralKeyPair:()=>_i,generateKeyPair:()=>Ef,generateKeyPairFromSeed:()=>Af,importKey:()=>Nf,keyStretcher:()=>Vi,keysPBM:()=>er,marshalPrivateKey:()=>If,marshalPublicKey:()=>Sf,supportedKeys:()=>ne,unmarshalPrivateKey:()=>$a,unmarshalPublicKey:()=>kf});var _=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var qs={};et(qs,{Ed25519PrivateKey:()=>Zt,Ed25519PublicKey:()=>_e,generateKeyPair:()=>Lu,generateKeyPairFromSeed:()=>$s,unmarshalEd25519PrivateKey:()=>_u,unmarshalEd25519PublicKey:()=>Uu});var Jn={};et(Jn,{base58btc:()=>vt,base58flickr:()=>pc});var Hf=new Uint8Array(0);function Ao(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(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 ko(r){return new TextEncoder().encode(r)}function So(r){return new TextDecoder().decode(r)}function uc(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var h=0,p=0,y=0,B=g.length;y!==B&&g[y]===0;)y++,h++;for(var b=(B-y)*l+1>>>0,C=new Uint8Array(b);y!==B;){for(var x=g[y],A=0,N=b-1;(x!==0||A<p)&&N!==-1;N--,A++)x+=256*C[N]>>>0,C[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");p=A,y++}for(var R=b-p;R!==b&&C[R]===0;)R++;for(var q=c.repeat(h);R<b;++R)q+=r.charAt(C[R]);return q}function d(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var h=0;if(g[h]!==" "){for(var p=0,y=0;g[h]===c;)p++,h++;for(var B=(g.length-h)*f+1>>>0,b=new Uint8Array(B);g[h];){var C=e[g.charCodeAt(h)];if(C===255)return;for(var x=0,A=B-1;(C!==0||x<y)&&A!==-1;A--,x++)C+=a*b[A]>>>0,b[A]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");y=x,h++}if(g[h]!==" "){for(var N=B-y;N!==B&&b[N]===0;)N++;for(var R=new Uint8Array(p+(B-N)),q=p;N!==B;)R[q++]=b[N++];return R}}}function w(g){var h=d(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:w}}var fc=uc,hc=fc,No=hc;var zn=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Zn=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ro(this,t)}},Yn=class{decoders;constructor(t){this.decoders=t}or(t){return Ro(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ro(r,t){return new Yn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Wn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new zn(t,e,n),this.decoder=new Zn(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Pe({name:r,prefix:t,encode:e,decode:n}){return new Wn(r,t,e,n)}function se({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=No(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Mt(s(o))})}function dc(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function gc(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pe({prefix:t,name:r,encode(s){return gc(s,n,e)},decode(s){return dc(s,n,e,r)}})}var vt=se({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pc=se({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ts={};et(ts,{identity:()=>Qn});var yc=_o,Co=128,mc=127,bc=~mc,wc=Math.pow(2,31);function _o(r,t,e){t=t||[],e=e||0;for(var n=e;r>=wc;)t[e++]=r&255|Co,r/=128;for(;r&bc;)t[e++]=r&255|Co,r>>>=7;return t[e]=r|0,_o.bytes=e-n+1,t}var xc=Xn,Bc=128,To=127;function Xn(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Xn.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&To)<<s:(i&To)*Math.pow(2,s),s+=7}while(i>=Bc);return Xn.bytes=o-n,e}var vc=Math.pow(2,7),Ec=Math.pow(2,14),Ac=Math.pow(2,21),kc=Math.pow(2,28),Sc=Math.pow(2,35),Ic=Math.pow(2,42),Nc=Math.pow(2,49),Rc=Math.pow(2,56),Cc=Math.pow(2,63),Tc=function(r){return r<vc?1:r<Ec?2:r<Ac?3:r<kc?4:r<Sc?5:r<Ic?6:r<Nc?7:r<Rc?8:r<Cc?9:10},_c={encode:yc,decode:xc,encodingLength:Tc},Uc=_c,cr=Uc;function lr(r,t=0){return[cr.decode(r,t),cr.decode.bytes]}function Ke(r,t,e=0){return cr.encode(r,t,e),t}function Me(r){return cr.encodingLength(r)}function Ee(r,t){let e=t.byteLength,n=Me(r),s=n+Me(e),o=new Uint8Array(s+e);return Ke(r,o,0),Ke(e,o,n),o.set(t,s),new Fe(r,e,t,o)}function Uo(r){let t=Mt(r),[e,n]=lr(t),[s,o]=lr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Fe(e,s,i,t)}function Lo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ao(r.bytes,e.bytes)}}var Fe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Vo=0,Lc="identity",Ho=Mt;function Vc(r){return Ee(Vo,Ho(r))}var Qn={code:Vo,name:Lc,encode:Ho,digest:Vc};var ns={};et(ns,{sha256:()=>bt,sha512:()=>Hc});function rs({name:r,code:t,encode:e}){return new es(r,t,e)}var es=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Ee(this.code,e):e.then(n=>Ee(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Oo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var bt=rs({name:"sha2-256",code:18,encode:Oo("SHA-256")}),Hc=rs({name:"sha2-512",code:19,encode:Oo("SHA-512")});function St(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Vt(r=0){return new Uint8Array(r)}function Ft(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Vt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var ss={};et(ss,{base10:()=>Dc});var Dc=se({prefix:"9",name:"base10",alphabet:"0123456789"});var os={};et(os,{base16:()=>Oc,base16upper:()=>Pc});var Oc=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Pc=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var is={};et(is,{base2:()=>Kc});var Kc=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var as={};et(as,{base256emoji:()=>jc});var Po=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}"),Mc=Po.reduce((r,t,e)=>(r[e]=t,r),[]),Fc=Po.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function $c(r){return r.reduce((t,e)=>(t+=Mc[e],t),"")}function qc(r){let t=[];for(let e of r){let n=Fc[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var jc=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:$c,decode:qc});var cs={};et(cs,{base32:()=>$e,base32hex:()=>Yc,base32hexpad:()=>Jc,base32hexpadupper:()=>Xc,base32hexupper:()=>Wc,base32pad:()=>zc,base32padupper:()=>Zc,base32upper:()=>Gc,base32z:()=>Qc});var $e=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Gc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),zc=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Zc=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Yc=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Wc=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Jc=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Xc=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Qc=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ls={};et(ls,{base36:()=>tl,base36upper:()=>el});var tl=se({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),el=se({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var us={};et(us,{base64:()=>Ae,base64pad:()=>rl,base64url:()=>nl,base64urlpad:()=>sl});var Ae=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),rl=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),nl=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),sl=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var fs={};et(fs,{base8:()=>ol});var ol=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var hs={};et(hs,{identity:()=>il});var il=Pe({prefix:"\0",name:"identity",encode:r=>So(r),decode:r=>ko(r)});var uh=new TextEncoder,fh=new TextDecoder;function Ko(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return ul(e,ds(r),t??vt.encoder);default:return fl(e,ds(r),t??$e.encoder)}}var Mo=new WeakMap;function ds(r){let t=Mo.get(r);if(t==null){let e=new Map;return Mo.set(r,e),e}return t}var Tr=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==fr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==hl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Ee(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Lo(t.multihash,n.multihash)}toString(t){return Ko(this,t)}toJSON(){return{"/":Ko(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??Fo(n,s,o.bytes))}else if(e[dl]===!0){let{version:n,multihash:s,code:o}=e,i=Uo(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==fr)throw new Error(`Version 0 CID must use dag-pb (code: ${fr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Fo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,fr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Mt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Fe(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,d]=lr(t.subarray(e));return e+=d,u},s=n(),o=fr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=ll(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ds(o).set(n,t),o}};function ll(r,t){switch(r[0]){case"Q":{let e=t??vt;return[vt.prefix,e.decode(`${vt.prefix}${r}`)]}case vt.prefix:{let e=t??vt;return[vt.prefix,e.decode(r)]}case $e.prefix:{let e=t??$e;return[$e.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function ul(r,t,e){let{prefix:n}=e;if(n!==vt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function fl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var fr=112,hl=18;function Fo(r,t,e){let n=Me(r),s=n+Me(t),o=new Uint8Array(s+e.byteLength);return Ke(r,o,0),Ke(t,o,n),o.set(e,s),o}var dl=Symbol.for("@ipld/js-cid/CID");var gs={...hs,...is,...fs,...ss,...os,...cs,...ls,...Jn,...us,...as},Ih={...ns,...ts};function qo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var $o=qo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ps=qo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Vt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),gl={utf8:$o,"utf-8":$o,hex:gs.base16,latin1:ps,ascii:ps,binary:ps,...gs},_r=gl;function Z(r,t="utf8"){let e=_r[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function ys(r,t){let e=Z(r,"base64urlpad");if(t!=null){if(e.length>t)throw new Error("byte array longer than desired length");e=Ft([new Uint8Array(t-e.length),e])}return e}function Et(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function qe(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function pl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function je(r,...t){if(!pl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Ur(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");qe(r.outputLen),qe(r.blockLen)}function Ge(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function jo(r,t){je(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Lr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var ke=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t,Vr=(r,t)=>r<<t|r>>>32-t>>>0,Mh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var yl=async()=>{};async function Go(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await yl(),n+=o)}}function zo(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function oe(r){return typeof r=="string"&&(r=zo(r)),je(r),r}function ms(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];je(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var ze=class{clone(){return this._cloneInto()}},ml={}.toString;function Zo(r,t){if(t!==void 0&&ml.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Ze(r){let t=n=>r().update(oe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ye(r=32){if(Lr&&typeof Lr.getRandomValues=="function")return Lr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function bl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}var Hr=(r,t,e)=>r&t^~r&e,Dr=(r,t,e)=>r&t^r&e^t&e,ie=class extends ze{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=ke(this.buffer)}update(t){Ge(this);let{view:e,buffer:n,blockLen:s}=this;t=oe(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=ke(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ge(this),jo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;bl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ke(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Or=BigInt(4294967295),bs=BigInt(32);function Yo(r,t=!1){return t?{h:Number(r&Or),l:Number(r>>bs&Or)}:{h:Number(r>>bs&Or)|0,l:Number(r&Or)|0}}function wl(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=Yo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var xl=(r,t)=>BigInt(r>>>0)<<bs|BigInt(t>>>0),Bl=(r,t,e)=>r>>>e,vl=(r,t,e)=>r<<32-e|t>>>e,El=(r,t,e)=>r>>>e|t<<32-e,Al=(r,t,e)=>r<<32-e|t>>>e,kl=(r,t,e)=>r<<64-e|t>>>e-32,Sl=(r,t,e)=>r>>>e-32|t<<64-e,Il=(r,t)=>t,Nl=(r,t)=>r,Rl=(r,t,e)=>r<<e|t>>>32-e,Cl=(r,t,e)=>t<<e|r>>>32-e,Tl=(r,t,e)=>t<<e-32|r>>>64-e,_l=(r,t,e)=>r<<e-32|t>>>64-e;function Ul(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Ll=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Vl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Hl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Dl=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Ol=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Pl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Kl={fromBig:Yo,split:wl,toBig:xl,shrSH:Bl,shrSL:vl,rotrSH:El,rotrSL:Al,rotrBH:kl,rotrBL:Sl,rotr32H:Il,rotr32L:Nl,rotlSH:Rl,rotlSL:Cl,rotlBH:Tl,rotlBL:_l,add:Ul,add3L:Ll,add3H:Vl,add4L:Hl,add4H:Dl,add5H:Pl,add5L:Ol},L=Kl;var[Ml,Fl]=L.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ae=new Uint32Array(80),ce=new Uint32Array(80),ws=class extends ie{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:d,Gh:w,Gl:g,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,f,l,u,d,w,g,h,p]}set(t,e,n,s,o,i,a,c,f,l,u,d,w,g,h,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=d|0,this.Gh=w|0,this.Gl=g|0,this.Hh=h|0,this.Hl=p|0}process(t,e){for(let b=0;b<16;b++,e+=4)ae[b]=t.getUint32(e),ce[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let C=ae[b-15]|0,x=ce[b-15]|0,A=L.rotrSH(C,x,1)^L.rotrSH(C,x,8)^L.shrSH(C,x,7),N=L.rotrSL(C,x,1)^L.rotrSL(C,x,8)^L.shrSL(C,x,7),R=ae[b-2]|0,q=ce[b-2]|0,M=L.rotrSH(R,q,19)^L.rotrBH(R,q,61)^L.shrSH(R,q,6),V=L.rotrSL(R,q,19)^L.rotrBL(R,q,61)^L.shrSL(R,q,6),rt=L.add4L(N,V,ce[b-7],ce[b-16]),tt=L.add4H(rt,A,M,ae[b-7],ae[b-16]);ae[b]=tt|0,ce[b]=rt|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:d,Fh:w,Fl:g,Gh:h,Gl:p,Hh:y,Hl:B}=this;for(let b=0;b<80;b++){let C=L.rotrSH(u,d,14)^L.rotrSH(u,d,18)^L.rotrBH(u,d,41),x=L.rotrSL(u,d,14)^L.rotrSL(u,d,18)^L.rotrBL(u,d,41),A=u&w^~u&h,N=d&g^~d&p,R=L.add5L(B,x,N,Fl[b],ce[b]),q=L.add5H(R,y,C,A,Ml[b],ae[b]),M=R|0,V=L.rotrSH(n,s,28)^L.rotrBH(n,s,34)^L.rotrBH(n,s,39),rt=L.rotrSL(n,s,28)^L.rotrBL(n,s,34)^L.rotrBL(n,s,39),tt=n&o^n&a^o&a,Bt=s&i^s&c^i&c;y=h|0,B=p|0,h=w|0,p=g|0,w=u|0,g=d|0,{h:u,l:d}=L.add(f|0,l|0,q|0,M|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let v=L.add3L(M,rt,Bt);n=L.add3H(v,q,V,tt),s=v|0}({h:n,l:s}=L.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=L.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=L.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=L.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:d}=L.add(this.Eh|0,this.El|0,u|0,d|0),{h:w,l:g}=L.add(this.Fh|0,this.Fl|0,w|0,g|0),{h,l:p}=L.add(this.Gh|0,this.Gl|0,h|0,p|0),{h:y,l:B}=L.add(this.Hh|0,this.Hl|0,y|0,B|0),this.set(n,s,o,i,a,c,f,l,u,d,w,g,h,p,y,B)}roundClean(){ae.fill(0),ce.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Se=Ze(()=>new ws);var Kr={};et(Kr,{abytes:()=>We,bitGet:()=>Yl,bitLen:()=>Zl,bitMask:()=>hr,bitSet:()=>Wl,bytesToHex:()=>qt,bytesToNumberBE:()=>jt,bytesToNumberLE:()=>ue,concatBytes:()=>Gt,createHmacDrbg:()=>vs,ensureBytes:()=>Q,equalBytes:()=>Gl,hexToBytes:()=>Ie,hexToNumber:()=>Bs,isBytes:()=>le,numberToBytesBE:()=>fe,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>Qo,numberToVarBytesBE:()=>jl,utf8ToBytes:()=>zl,validateObject:()=>Ht});var Xo=BigInt(0),Pr=BigInt(1),$l=BigInt(2);function le(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function We(r){if(!le(r))throw new Error("Uint8Array expected")}var ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qt(r){We(r);let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}function Qo(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Bs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var $t={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Wo(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t._A&&r<=$t._F)return r-($t._A-10);if(r>=$t._a&&r<=$t._f)return r-($t._a-10)}function Ie(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=Wo(r.charCodeAt(o)),a=Wo(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function jt(r){return Bs(qt(r))}function ue(r){return We(r),Bs(qt(Uint8Array.from(r).reverse()))}function fe(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return fe(r,t).reverse()}function jl(r){return Ie(Qo(r))}function Q(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(le(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function Gt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];We(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Gl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function zl(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Zl(r){let t;for(t=0;r>Xo;r>>=Pr,t+=1);return t}function Yl(r,t){return r>>BigInt(t)&Pr}function Wl(r,t,e){return r|(e?Pr:Xo)<<BigInt(t)}var hr=r=>($l<<BigInt(r-1))-Pr,xs=r=>new Uint8Array(r),Jo=r=>Uint8Array.from(r);function vs(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=xs(r),s=xs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=xs())=>{s=a(Jo([0]),u),n=a(),u.length!==0&&(s=a(Jo([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let w=n.slice();d.push(w),u+=n.length}return Gt(...d)};return(u,d)=>{i(),c(u);let w;for(;!(w=d(f()));)c();return i(),w}}var Jl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||le(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ht(r,t,e={}){let n=(s,o,i)=>{let a=Jl[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var at=BigInt(0),Y=BigInt(1),Re=BigInt(2),Xl=BigInt(3),Es=BigInt(4),ti=BigInt(5),ei=BigInt(8),Ql=BigInt(9),tu=BigInt(16);function j(r,t){let e=r%t;return e>=at?e:t+e}function eu(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Y)return at;let n=Y;for(;t>at;)t&Y&&(n=n*r%e),r=r*r%e,t>>=Y;return n}function W(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function Mr(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=j(r,t),n=t,s=at,o=Y,i=Y,a=at;for(;e!==at;){let f=n/e,l=n%e,u=s-i*f,d=o-a*f;n=e,e=l,s=i,o=a,i=u,a=d}if(n!==Y)throw new Error("invert: does not exist");return j(s,t)}function ru(r){let t=(r-Y)/Re,e,n,s;for(e=r-Y,n=0;e%Re===at;e/=Re,n++);for(s=Re;s<r&&eu(s,t,r)!==r-Y;s++);if(n===1){let i=(r+Y)/Es;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+Y)/Re;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(d);w<f&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(l,Y<<BigInt(f-w-1));l=a.sqr(g),u=a.mul(u,g),d=a.mul(d,l),f=w}return u}}function nu(r){if(r%Es===Xl){let t=(r+Y)/Es;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%ei===ti){let t=(r-ti)/ei;return function(n,s){let o=n.mul(s,Re),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Re),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%tu,ru(r)}var ri=(r,t)=>(j(r,t)&Y)===Y,su=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function As(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=su.reduce((n,s)=>(n[s]="function",n),t);return Ht(r,e)}function ou(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Y)return t;let n=r.ONE,s=t;for(;e>at;)e&Y&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Y;return n}function iu(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function ks(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Fr(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=ks(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=nu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:hr(s),ZERO:at,ONE:Y,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Y)===Y,neg:c=>j(-c,r),eql:(c,f)=>c===f,sqr:c=>j(c*c,r),add:(c,f)=>j(c+f,r),sub:(c,f)=>j(c-f,r),mul:(c,f)=>j(c*f,r),pow:(c,f)=>ou(a,c,f),div:(c,f)=>j(c*Mr(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Mr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>iu(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Ne(c,o):fe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?ue(c):jt(c)}});return Object.freeze(a)}function ni(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Ss(r){let t=ni(r);return t+Math.ceil(t/2)}function si(r,t,e=!1){let n=r.length,s=ni(t),o=Ss(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?jt(r):ue(r),a=j(i,t-Y)+Y;return e?Ne(a,s):fe(a,s)}var cu=BigInt(0),Is=BigInt(1);function $r(r,t){let e=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(t/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:e,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>cu;)o&Is&&(i=i.add(a)),a=a.double(),o>>=Is;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],f=s,l=f;for(let u=0;u<i;u++){l=f,c.push(l);for(let d=1;d<a;d++)l=l.add(f),c.push(l);f=l.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),f=r.ZERO,l=r.BASE,u=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,p=Number(i&u);i>>=w,p>c&&(p-=d,i+=Is);let y=h,B=h+Math.abs(p)-1,b=g%2!==0,C=p<0;p===0?l=l.add(e(b,o[y])):f=f.add(e(C,o[B]))}return{p:f,f:l}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,f=o.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&o.set(s,a(f))),this.wNAF(c,f,i)}}}function dr(r){return As(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ks(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),wt=BigInt(1),qr=BigInt(2),lu=BigInt(8),uu={zip215:!0};function fu(r){let t=dr(r);return Ht(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function oi(r){let t=fu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=qr<<BigInt(a*8)-wt,l=e.create,u=t.uvRatio||((E,m)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(m))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(E=>E),w=t.domain||((E,m,S)=>{if(m.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),g=E=>typeof E=="bigint"&&Nt<E,h=(E,m)=>g(E)&&g(m)&&E<m,p=E=>E===Nt||h(E,f);function y(E,m){if(h(E,m))return E;throw new Error(`Expected valid scalar < ${m}, got ${typeof E} ${E}`)}function B(E){return E===Nt?E:y(E,n)}let b=new Map;function C(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(m,S,T,U){if(this.ex=m,this.ey=S,this.ez=T,this.et=U,!p(m))throw new Error("x required");if(!p(S))throw new Error("y required");if(!p(T))throw new Error("z required");if(!p(U))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(m){if(m instanceof x)throw new Error("extended point not allowed");let{x:S,y:T}=m||{};if(!p(S)||!p(T))throw new Error("invalid affine point");return new x(S,T,wt,l(S*T))}static normalizeZ(m){let S=e.invertBatch(m.map(T=>T.ez));return m.map((T,U)=>T.toAffine(S[U])).map(x.fromAffine)}_setWindowSize(m){this._WINDOW_SIZE=m,b.delete(this)}assertValidity(){let{a:m,d:S}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:T,ey:U,ez:D,et:O}=this,$=l(T*T),K=l(U*U),F=l(D*D),nt=l(F*F),J=l($*m),lt=l(F*l(J+K)),ut=l(nt+l(S*l($*K)));if(lt!==ut)throw new Error("bad point: equation left != right (1)");let it=l(T*U),ht=l(D*O);if(it!==ht)throw new Error("bad point: equation left != right (2)")}equals(m){C(m);let{ex:S,ey:T,ez:U}=this,{ex:D,ey:O,ez:$}=m,K=l(S*$),F=l(D*U),nt=l(T*$),J=l(O*U);return K===F&&nt===J}is0(){return this.equals(x.ZERO)}negate(){return new x(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:m}=t,{ex:S,ey:T,ez:U}=this,D=l(S*S),O=l(T*T),$=l(qr*l(U*U)),K=l(m*D),F=S+T,nt=l(l(F*F)-D-O),J=K+O,lt=J-$,ut=K-O,it=l(nt*lt),ht=l(J*ut),Kt=l(nt*ut),ve=l(lt*J);return new x(it,ht,ve,Kt)}add(m){C(m);let{a:S,d:T}=t,{ex:U,ey:D,ez:O,et:$}=this,{ex:K,ey:F,ez:nt,et:J}=m;if(S===BigInt(-1)){let po=l((D-U)*(F+K)),yo=l((D+U)*(F-K)),jn=l(yo-po);if(jn===Nt)return this.double();let mo=l(O*qr*J),bo=l($*qr*nt),wo=bo+mo,xo=yo+po,Bo=bo-mo,Wa=l(wo*jn),Ja=l(xo*Bo),Xa=l(wo*Bo),Qa=l(jn*xo);return new x(Wa,Ja,Qa,Xa)}let lt=l(U*K),ut=l(D*F),it=l($*T*J),ht=l(O*nt),Kt=l((U+D)*(K+F)-lt-ut),ve=ht-it,ar=ht+it,go=l(ut-S*lt),Ga=l(Kt*ve),za=l(ar*go),Za=l(Kt*go),Ya=l(ve*ar);return new x(Ga,za,Ya,Za)}subtract(m){return this.add(m.negate())}wNAF(m){return R.wNAFCached(this,b,m,x.normalizeZ)}multiply(m){let{p:S,f:T}=this.wNAF(y(m,n));return x.normalizeZ([S,T])[0]}multiplyUnsafe(m){let S=B(m);return S===Nt?N:this.equals(N)||S===wt?this:this.equals(A)?this.wNAF(S).p:R.unsafeLadder(this,S)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(m){let{ex:S,ey:T,ez:U}=this,D=this.is0();m==null&&(m=D?lu:e.inv(U));let O=l(S*m),$=l(T*m),K=l(U*m);if(D)return{x:Nt,y:wt};if(K!==wt)throw new Error("invZ was invalid");return{x:O,y:$}}clearCofactor(){let{h:m}=t;return m===wt?this:this.multiplyUnsafe(m)}static fromHex(m,S=!1){let{d:T,a:U}=t,D=e.BYTES;m=Q("pointHex",m,D);let O=m.slice(),$=m[D-1];O[D-1]=$&-129;let K=ue(O);K===Nt||(S?y(K,f):y(K,e.ORDER));let F=l(K*K),nt=l(F-wt),J=l(T*F-U),{isValid:lt,value:ut}=u(nt,J);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let it=(ut&wt)===wt,ht=($&128)!==0;if(!S&&ut===Nt&&ht)throw new Error("Point.fromHex: x=0 and x_0=1");return ht!==it&&(ut=l(-ut)),x.fromAffine({x:ut,y:K})}static fromPrivateKey(m){return V(m).point}toRawBytes(){let{x:m,y:S}=this.toAffine(),T=Ne(S,e.BYTES);return T[T.length-1]|=m&wt?128:0,T}toHex(){return qt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,wt,l(t.Gx*t.Gy)),x.ZERO=new x(Nt,wt,wt,Nt);let{BASE:A,ZERO:N}=x,R=$r(x,a*8);function q(E){return j(E,n)}function M(E){return q(ue(E))}function V(E){let m=a;E=Q("private key",E,m);let S=Q("hashed private key",o(E),2*m),T=d(S.slice(0,m)),U=S.slice(m,2*m),D=M(T),O=A.multiply(D),$=O.toRawBytes();return{head:T,prefix:U,scalar:D,point:O,pointBytes:$}}function rt(E){return V(E).pointBytes}function tt(E=new Uint8Array,...m){let S=Gt(...m);return M(o(w(S,Q("context",E),!!s)))}function Bt(E,m,S={}){E=Q("message",E),s&&(E=s(E));let{prefix:T,scalar:U,pointBytes:D}=V(m),O=tt(S.context,T,E),$=A.multiply(O).toRawBytes(),K=tt(S.context,$,D,E),F=q(O+K*U);B(F);let nt=Gt($,Ne(F,e.BYTES));return Q("result",nt,a*2)}let v=uu;function I(E,m,S,T=v){let{context:U,zip215:D}=T,O=e.BYTES;E=Q("signature",E,2*O),m=Q("message",m),s&&(m=s(m));let $=ue(E.slice(O,2*O)),K,F,nt;try{K=x.fromHex(S,D),F=x.fromHex(E.slice(0,O),D),nt=A.multiplyUnsafe($)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let J=tt(U,F.toRawBytes(),K.toRawBytes(),m);return F.add(K.multiplyUnsafe(J)).subtract(nt).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:Bt,verify:I,ExtendedPoint:x,utils:{getExtendedPublicKey:V,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,m=x.BASE){return m._setWindowSize(E),m.multiply(BigInt(3)),m}}}}var Ns=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ii=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),ud=BigInt(0),hu=BigInt(1),ai=BigInt(2),fd=BigInt(3),du=BigInt(5),gu=BigInt(8);function pu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ns,a=r*r%o*r%o,c=W(a,ai,o)*a%o,f=W(c,hu,o)*r%o,l=W(f,du,o)*f%o,u=W(l,t,o)*l%o,d=W(u,e,o)*u%o,w=W(d,n,o)*d%o,g=W(w,s,o)*w%o,h=W(g,s,o)*w%o,p=W(h,t,o)*l%o;return{pow_p_5_8:W(p,ai,o)*r%o,b2:a}}function yu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function mu(r,t){let e=Ns,n=j(t*t*t,e),s=j(n*n*t,e),o=pu(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,f=j(i*ii,e),l=a===r,u=a===j(-r,e),d=a===j(-r*ii,e);return l&&(i=c),(u||d)&&(i=f),ri(i,e)&&(i=j(-i,e)),{isValid:l||u,value:i}}var bu=Fr(Ns,void 0,!0),wu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:bu,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:gu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Se,randomBytes:Ye,adjustScalarBytes:yu,uvRatio:mu},Je=oi(wu);var Xe=32,zt=64,jr=32;function ci(){let r=Je.utils.randomPrivateKey(),t=Je.getPublicKey(r);return{privateKey:hi(r,t),publicKey:t}}function li(r){if(r.length!==jr)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=Je.getPublicKey(t);return{privateKey:hi(t,e),publicKey:e}}function ui(r,t){let e=r.subarray(0,jr);return Je.sign(t instanceof Uint8Array?t:t.subarray(),e)}function fi(r,t,e){return Je.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function hi(r,t){let e=new Uint8Array(zt);for(let n=0;n<jr;n++)e[n]=r[n],e[jr+n]=t[n];return e}var Rs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Gr(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=z.get();e*=8;async function c(u,d){let w=a.getRandomValues(new Uint8Array(o)),g=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:g};typeof d=="string"&&(d=Z(d));let p;if(d.length===0){p=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(B,b,{name:t,length:e},!0,["encrypt"])}let y=await a.subtle.encrypt(h,p,u);return Ft([w,h.iv,new Uint8Array(y)])}async function f(u,d){let w=u.subarray(0,o),g=u.subarray(o,o+n),h=u.subarray(o+n),p={name:t,iv:g};typeof d=="string"&&(d=Z(d));let y;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(b,C,{name:t,length:e},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},C=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(b,C,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(p,y,h);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}async function Qe(r,t){let n=await Gr().encrypt(r,t);return Ae.encode(n)}var er={};et(er,{KeyType:()=>G,PrivateKey:()=>Tt,PublicKey:()=>Ct});var Bu=Math.pow(2,7),vu=Math.pow(2,14),Eu=Math.pow(2,21),gi=Math.pow(2,28),pi=Math.pow(2,35),yi=Math.pow(2,42),mi=Math.pow(2,49),pt=128,he=127;function gr(r){if(r<Bu)return 1;if(r<vu)return 2;if(r<Eu)return 3;if(r<gi)return 4;if(r<pi)return 5;if(r<yi)return 6;if(r<mi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function bi(r,t,e=0){switch(gr(r)){case 8:t[e++]=r&255|pt,r/=128;case 7:t[e++]=r&255|pt,r/=128;case 6:t[e++]=r&255|pt,r/=128;case 5:t[e++]=r&255|pt,r/=128;case 4:t[e++]=r&255|pt,r>>>=7;case 3:t[e++]=r&255|pt,r>>>=7;case 2:t[e++]=r&255|pt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function wi(r,t){let e=r[t],n=0;if(n+=e&he,e<pt||(e=r[t+1],n+=(e&he)<<7,e<pt)||(e=r[t+2],n+=(e&he)<<14,e<pt)||(e=r[t+3],n+=(e&he)<<21,e<pt)||(e=r[t+4],n+=(e&he)*gi,e<pt)||(e=r[t+5],n+=(e&he)*pi,e<pt)||(e=r[t+6],n+=(e&he)*yi,e<pt)||(e=r[t+7],n+=(e&he)*mi,e<pt))return n;throw new RangeError("Could not decode varint")}var Cs=new Float32Array([-0]),de=new Uint8Array(Cs.buffer);function xi(r,t,e){Cs[0]=r,t[e]=de[0],t[e+1]=de[1],t[e+2]=de[2],t[e+3]=de[3]}function Bi(r,t){return de[0]=r[t],de[1]=r[t+1],de[2]=r[t+2],de[3]=r[t+3],Cs[0]}var Ts=new Float64Array([-0]),dt=new Uint8Array(Ts.buffer);function vi(r,t,e){Ts[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function Ei(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],Ts[0]}var Au=BigInt(Number.MAX_SAFE_INTEGER),ku=BigInt(Number.MIN_SAFE_INTEGER),xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Ce;if(t<Au&&t>ku)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Ai&&(s=0n,++n>Ai&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ce;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Ce}},Ce=new xt(0,0);Ce.toBigInt=function(){return 0n};Ce.zzEncode=Ce.zzDecode=function(){return this};Ce.length=function(){return 1};var Ai=4294967296n;function ki(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Si(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&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 _s(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Rt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function zr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Us=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Rt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Rt(this,4);return zr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Rt(this,4);return zr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Rt(this,4);let t=Bi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Rt(this,4);let t=Ei(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Rt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Si(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Rt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Rt(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Rt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Rt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Rt(this,8);let t=zr(this.buf,this.pos+=4),e=zr(this.buf,this.pos+=4);return new xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=wi(this.buf,this.pos);return this.pos+=gr(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Ls(r){return new Us(r instanceof Uint8Array?r:r.subarray())}function Zr(r,t,e){let n=Ls(r);return t.decode(n,void 0,e)}function Vs(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Vt(i);s+i>t&&(n=Vt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Te=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Hs(){}var Os=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Su=Vs();function Iu(r){return globalThis.Buffer!=null?Vt(r):Su(r)}var yr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Te(Hs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Te(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ps((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Yr,10,xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=xt.fromBigInt(t);return this._push(Yr,e.length(),e)}uint64Number(t){return this._push(bi,gr(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=xt.fromBigInt(t).zzEncode();return this._push(Yr,e.length(),e)}sint64Number(t){let e=xt.fromNumber(t).zzEncode();return this._push(Yr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ds,1,t?1:0)}fixed32(t){return this._push(pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=xt.fromBigInt(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64Number(t){let e=xt.fromNumber(t);return this._push(pr,4,e.lo)._push(pr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(xi,4,t)}double(t){return this._push(vi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Ds,1,0):this.uint32(e)._push(Ru,e,t)}string(t){let e=ki(t);return e!==0?this.uint32(e)._push(_s,e,t):this._push(Ds,1,0)}fork(){return this.states=new Os(this),this.head=this.tail=new Te(Hs,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 Te(Hs,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Iu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Ds(r,t,e){t[e]=r&255}function Nu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ps=class extends Te{next;constructor(t,e){super(Nu,t,e),this.next=void 0}};function Yr(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function pr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ru(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(yr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Cu,t,r),this},yr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Tu,t,r),this});function Cu(r,t,e){t.set(r,e)}function Tu(r,t,e){r.length<40?_s(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function Ks(){return new yr}function Wr(r,t){let e=Ks();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function Jr(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ms(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Jr("enum",tr.VARINT,e,n)}function Xr(r,t){return Jr("message",tr.LENGTH_DELIMITED,r,t)}var G;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(G||(G={}));var Fs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Fs||(Fs={}));(function(r){r.codec=()=>Ms(Fs)})(G||(G={}));var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=Xr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Wr(e,r.codec()),r.decode=e=>Zr(e,r.codec())})(Ct||(Ct={}));var Tt;(function(r){let t;r.codec=()=>(t==null&&(t=Xr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),G.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=G.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Wr(e,r.codec()),r.decode=e=>Zr(e,r.codec())})(Tt||(Tt={}));var _e=class{_key;constructor(t){this._key=rr(t,Xe)}verify(t,e){return fi(this._key,e,t)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Et(t)?t.then(({bytes:e})=>e):t.bytes}},Zt=class{_key;_publicKey;constructor(t,e){this._key=rr(t,zt),this._publicKey=rr(e,Xe)}sign(t){return ui(this._key,t)}get public(){return new _e(this._publicKey)}marshal(){return this._key}get bytes(){return Tt.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Et(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Qn.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Qe(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function _u(r){if(r.length>zt){r=rr(r,zt+Xe);let n=r.subarray(0,zt),s=r.subarray(zt,r.length);return new Zt(n,s)}r=rr(r,zt);let t=r.subarray(0,zt),e=r.subarray(Xe);return new Zt(t,e)}function Uu(r){return r=rr(r,Xe),new _e(r)}async function Lu(){let{privateKey:r,publicKey:t}=ci();return new Zt(r,t)}async function $s(r){let{privateKey:t,publicKey:e}=li(r);return new Zt(t,e)}function rr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function st(r,t="utf8"){let e=_r[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ni={"P-256":256,"P-384":384,"P-521":521},Vu=Object.keys(Ni),js=Vu.join(" / ");async function Ri(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${js}`,"ERR_INVALID_CURVE");let t=await z.get().subtle.generateKey({name:"ECDH",namedCurve:r},!0,["deriveBits"]),e=async(o,i)=>{let a;i!=null?a=await z.get().subtle.importKey("jwk",Du(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await z.get().subtle.importKey("jwk",Ti(r,o),{name:"ECDH",namedCurve:r},!1,[]),f=await z.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ni[r]);return new Uint8Array(f,0,f.byteLength)},n=await z.get().subtle.exportKey("jwk",t.publicKey);return{key:Hu(n),genSharedKey:e}}var Ci={"P-256":32,"P-384":48,"P-521":66};function Hu(r){if(r.crv==null||r.x==null||r.y==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");if(r.crv!=="P-256"&&r.crv!=="P-384"&&r.crv!=="P-521")throw new _(`Unknown curve: ${r.crv}. Must be ${js}`,"ERR_INVALID_CURVE");let t=Ci[r.crv];return Ft([Uint8Array.from([4]),ys(r.x,t),ys(r.y,t)],1+t*2)}function Ti(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${js}`,"ERR_INVALID_CURVE");let e=Ci[r];if(!St(t.subarray(0,1),Uint8Array.from([4])))throw new _("Cannot unmarshal public key - invalid key format","ERR_INVALID_KEY_FORMAT");return{kty:"EC",crv:r,x:st(t.subarray(1,e+1),"base64url"),y:st(t.subarray(1+e),"base64url"),ext:!0}}var Du=(r,t)=>({...Ti(r,t.public),d:st(t.private,"base64url")});var _i=Ri;async function Ui(r,t){let e=Ae.decode(r);return Gr().decrypt(e,t)}var Li={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Vi(r,t,e){let n=Li[r];if(n==null){let B=Object.keys(Li).join(" / ");throw new _(`unknown cipher type '${r}'. Must be ${B}`,"ERR_INVALID_CIPHER_TYPE")}if(t==null)throw new _("missing hash type","ERR_MISSING_HASH_TYPE");let s=n.keySize,o=n.ivSize,i=20,a=Z("key expansion"),c=2*(o+s+i),f=await Gn(t,e),l=await f.digest(a),u=[],d=0;for(;d<c;){let B=await f.digest(Ft([l,a])),b=B.length;d+b>c&&(b=c-d),u.push(B),d+=b,l=await f.digest(l)}let w=c/2,g=Ft(u),h=g.subarray(0,w),p=g.subarray(w,c),y=B=>({iv:B.subarray(0,o),cipherKey:B.subarray(o,o+s),macKey:B.subarray(o+s)});return{k1:y(h),k2:y(p)}}var ro={};et(ro,{MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,fromJwk:()=>cf,generateKeyPair:()=>lf,unmarshalRsaPrivateKey:()=>to,unmarshalRsaPublicKey:()=>af});function Yt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Ye(r)}var me={};et(me,{exportToPem:()=>rf,importFromPem:()=>Qs,jwkToPkcs1:()=>Xu,jwkToPkix:()=>tf,pkcs1ToJwk:()=>Ju,pkixToJwk:()=>Qu});var Qr=class extends ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Ur(t);let n=oe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ge(this),this.iHash.update(t),this}digestInto(t){Ge(this),je(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},mr=(r,t,e)=>new Qr(r,t).update(e).digest();mr.create=(r,t)=>new Qr(r,t);function Hi(r,t,e,n){Ur(r);let s=Zo({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(qe(o),qe(i),qe(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=oe(t),f=oe(e),l=new Uint8Array(i),u=mr.create(r,c),d=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:d}}function Di(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Oi(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Hi(r,t,e,n),f,l=new Uint8Array(4),u=ke(l),d=new Uint8Array(a.outputLen);for(let w=1,g=0;g<o;w++,g+=a.outputLen){let h=i.subarray(g,g+a.outputLen);u.setInt32(0,w,!1),(f=c._cloneInto(f)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let p=1;p<s;p++){a._cloneInto(f).update(d).digestInto(d);for(let y=0;y<h.length;y++)h[y]^=d[y]}}return Di(a,c,i,f,d)}async function Gs(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Hi(r,t,e,n),l,u=new Uint8Array(4),d=ke(u),w=new Uint8Array(c.outputLen);for(let g=1,h=0;h<o;g++,h+=c.outputLen){let p=a.subarray(h,h+c.outputLen);d.setInt32(0,g,!1),(l=f._cloneInto(l)).update(u).digestInto(w),p.set(w.subarray(0,p.length)),await Go(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let y=0;y<p.length;y++)p[y]^=w[y]})}return Di(c,f,a,l,w)}var P=ic(Pi());function Ue(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ge(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function rn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function Zs(){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 t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Ue(e,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,Ue(o,8)-n}function Ki(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=ge(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ge(t,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}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Mi(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function mt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var L0=Math.log(2);function nn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ys(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function te(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var wr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ys(this.items)}},br=[new Uint8Array([1])],Fi="0123456789";var or="",Ut=new ArrayBuffer(0),Ws=new Uint8Array(0),xr="EndOfContent",qi="OCTET STRING",ji="BIT STRING";function ee(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?P.BufferSourceConverter.toUint8Array(o.valueHex):Ws}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!te(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Jt=class{constructor({blockLength:t=0,error:e=or,warnings:n=[],valueBeforeDecode:s=Ws}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};Jt.NAME="baseBlock";var gt=class extends Jt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};gt.NAME="valueBlock";var sn=class extends ee(Jt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?P.BufferSourceConverter.toUint8Array(t.valueHex):Ws,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Ut}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ge(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){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]=e|31,!t){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(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!te(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let d=new Uint8Array(l);for(let w=0;w<f.length;w++)d[w]=f[w];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=f[d];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Ue(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};sn.NAME="identificationBlock";var on=class extends Jt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!te(this,s,e,n))return-1;let o=s.subarray(e,e+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,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+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=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Ue(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ge(this.length,8);if(s.byteLength>127)return this.error="Too big length",Ut;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};on.NAME="lengthBlock";var k={},ft=class extends Jt{constructor({name:t=or,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new sn(s),this.lenBlock=new on(s),this.valueBlock=o?new o(s):new gt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new wr;e||Gi(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():P.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Mi(e,n)}};ft.NAME="BaseBlock";function Gi(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)Gi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var an=class extends ft{constructor({value:t=or,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};an.NAME="BaseStringBlock";var cn=class extends ee(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};cn.NAME="PrimitiveValueBlock";var zi,ln=class extends ft{constructor(t={}){super(t,cn),this.idBlock.isConstructed=!1}};zi=ln;k.Primitive=zi;ln.NAME="PRIMITIVE";function Gu(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Fn(r,t=0,e=r.length){let n=t,s=new ft({},gt),o=new Jt;if(!te(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=ft;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let f=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Gu(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function ir(r){if(!r.byteLength){let t=new ft({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Fn(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function zu(r,t){return r?1:t}var Dt=class extends gt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!te(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;zu(this.isIndefiniteForm,n)>0;){let i=Fn(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===xr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===xr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new wr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Dt.NAME="ConstructedValueBlock";var Zi,pe=class extends ft{constructor(t={}){super(t,Dt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
3
3
|
`).map(s=>` ${s}`).join(`
|
|
4
4
|
`));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
|
|
5
5
|
${t.join(`
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
export default {
|
|
5
5
|
get(win = globalThis) {
|
|
6
6
|
const nativeCrypto = win.crypto;
|
|
7
|
-
if (nativeCrypto
|
|
7
|
+
if (nativeCrypto?.subtle == null) {
|
|
8
8
|
throw Object.assign(new Error('Missing Web Crypto API. ' +
|
|
9
9
|
'The most likely cause of this error is that this page is being accessed ' +
|
|
10
10
|
'from an insecure context (i.e. not HTTPS). For more information and ' +
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webcrypto-browser.js","sourceRoot":"","sources":["../../src/webcrypto-browser.ts"],"names":[],"mappings":"AAAA,wBAAwB;AAExB,+EAA+E;AAC/E,6CAA6C;AAC7C,eAAe;IACb,GAAG,CAAE,GAAG,GAAG,UAAU;QACnB,MAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAA;QAE/B,IAAI,YAAY,
|
|
1
|
+
{"version":3,"file":"webcrypto-browser.js","sourceRoot":"","sources":["../../src/webcrypto-browser.ts"],"names":[],"mappings":"AAAA,wBAAwB;AAExB,+EAA+E;AAC/E,6CAA6C;AAC7C,eAAe;IACb,GAAG,CAAE,GAAG,GAAG,UAAU;QACnB,MAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAA;QAE/B,IAAI,YAAY,EAAE,MAAM,IAAI,IAAI,EAAE,CAAC;YACjC,MAAM,MAAM,CAAC,MAAM,CACjB,IAAI,KAAK,CACP,0BAA0B;gBAC1B,0EAA0E;gBAC1E,sEAAsE;gBACtE,2BAA2B;gBAC3B,wFAAwF,CACzF,EACD,EAAE,IAAI,EAAE,wBAAwB,EAAE,CACnC,CAAA;QACH,CAAC;QAED,OAAO,YAAY,CAAA;IACrB,CAAC;CACF,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/crypto",
|
|
3
|
-
"version": "4.1.
|
|
3
|
+
"version": "4.1.7-944935f8d",
|
|
4
4
|
"description": "Crypto primitives for libp2p",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/crypto#readme",
|
|
@@ -84,7 +84,7 @@
|
|
|
84
84
|
"generate": "protons ./src/keys/keys.proto"
|
|
85
85
|
},
|
|
86
86
|
"dependencies": {
|
|
87
|
-
"@libp2p/interface": "1.6.
|
|
87
|
+
"@libp2p/interface": "1.6.2-944935f8d",
|
|
88
88
|
"@noble/curves": "^1.4.0",
|
|
89
89
|
"@noble/hashes": "^1.4.0",
|
|
90
90
|
"asn1js": "^3.0.5",
|
|
@@ -95,7 +95,7 @@
|
|
|
95
95
|
},
|
|
96
96
|
"devDependencies": {
|
|
97
97
|
"@types/mocha": "^10.0.6",
|
|
98
|
-
"aegir": "^
|
|
98
|
+
"aegir": "^44.0.1",
|
|
99
99
|
"benchmark": "^2.1.4",
|
|
100
100
|
"protons": "^7.5.0"
|
|
101
101
|
},
|
package/src/webcrypto-browser.ts
CHANGED