@libp2p/crypto 4.0.0 → 4.0.1

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,10 +1,10 @@
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 Qa=Object.create;var Sr=Object.defineProperty;var tc=Object.getOwnPropertyDescriptor;var ec=Object.getOwnPropertyNames;var rc=Object.getPrototypeOf,nc=Object.prototype.hasOwnProperty;var sc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)Sr(r,e,{get:t[e],enumerable:!0})},Eo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ec(t))!nc.call(r,s)&&s!==e&&Sr(r,s,{get:()=>t[s],enumerable:!(n=tc(t,s))||n.enumerable});return r};var oc=(r,t,e)=>(e=r!=null?Qa(rc(r)):{},Eo(t||!r||!r.__esModule?Sr(e,"default",{value:r,enumerable:!0}):e,r)),ic=r=>Eo(Sr({},"__esModule",{value:!0}),r);var Oi=sc(er=>{"use strict";var Vu="[object ArrayBuffer]",Jt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Vu}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",Hu=/^[0-9a-f]+$/i,Du=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Ou=/^[a-zA-Z0-9-_]+$/,Wr=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=Jt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Et=class{static toString(t,e=!1){let n=Jt.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}},Jr=class r{static isHex(t){return typeof t===zs&&Hu.test(t)}static isBase64(t){return typeof t===zs&&Du.test(t)}static isBase64Url(t){return typeof t===zs&&Ou.test(t)}static ToString(t,e="utf8"){let n=Jt.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 Et.toString(n,!0);case"utf16":case"utf16be":return Et.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 Et.fromString(t,!0);case"utf16":case"utf16be":return Et.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Jt.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 Wr.fromString(t);case"utf16":case"utf16be":return Et.fromString(t);case"utf16le":case"usc2":return Et.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 Wr.toString(t);case"utf16":case"utf16be":return Et.toString(t);case"utf16le":case"usc2":return Et.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=Jt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Jt.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 Et.toString(t,e)}static FromUtf16String(t,e=!1){return Et.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,"")||""}};Jr.DEFAULT_UTF8_ENCODING="utf8";function Pu(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 Ku(...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 Mu(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}er.BufferSourceConverter=Jt;er.Convert=Jr;er.assign=Pu;er.combine=Ku;er.isEqual=Mu});var Tf={};et(Tf,{hmac:()=>Ir,keys:()=>uo,pbkdf2:()=>po,randomBytes:()=>Wt});var Ir={};et(Ir,{create:()=>Fn});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 Ao={SHA1:20,SHA256:32,SHA512:64};var ac={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},cc=async(r,t)=>{let e=await z.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Fn(r,t){let e=ac[r],n=await z.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return cc(n,s)},length:Ao[r]}}var uo={};et(uo,{Ed25519PrivateKey:()=>Yt,Ed25519PublicKey:()=>_e,MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,Secp256k1PrivateKey:()=>Oe,Secp256k1PublicKey:()=>De,generateEphemeralKeyPair:()=>Ci,generateKeyPair:()=>Bf,generateKeyPairFromSeed:()=>Ef,importKey:()=>If,keyStretcher:()=>Li,keysPBM:()=>Qe,marshalPrivateKey:()=>Sf,marshalPublicKey:()=>kf,supportedKeys:()=>se,unmarshalPrivateKey:()=>Fa,unmarshalPublicKey:()=>Af});var Hf=Symbol.for("@libp2p/connection");var Of=Symbol.for("@libp2p/content-routing");var Mf=Symbol.for("@libp2p/peer-discovery");var $f=Symbol.for("@libp2p/peer-id");var jf=Symbol.for("@libp2p/peer-routing");var ko;(function(r){r.Accept="accept",r.Ignore="ignore",r.Reject="reject"})(ko||(ko={}));var Yf=Symbol.for("@libp2p/transport");var So;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(So||(So={}));var _=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var $n=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},Xf=globalThis.CustomEvent??$n;var qs={};et(qs,{Ed25519PrivateKey:()=>Yt,Ed25519PublicKey:()=>_e,generateKeyPair:()=>Cu,generateKeyPairFromSeed:()=>$s,unmarshalEd25519PrivateKey:()=>Ru,unmarshalEd25519PublicKey:()=>Tu});var Zn={};et(Zn,{base58btc:()=>vt,base58flickr:()=>pc});var Nh=new Uint8Array(0);function Io(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 Kt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function No(r){return new TextEncoder().encode(r)}function Ro(r){return new TextDecoder().decode(r)}function lc(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),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,g=0,m=0,v=p.length;m!==v&&p[m]===0;)m++,h++;for(var b=(v-m)*l+1>>>0,T=new Uint8Array(b);m!==v;){for(var x=p[m],A=0,N=b-1;(x!==0||A<g)&&N!==-1;N--,A++)x+=256*T[N]>>>0,T[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");g=A,m++}for(var R=b-g;R!==b&&T[R]===0;)R++;for(var $=c.repeat(h);R<b;++R)$+=r.charAt(T[R]);return $}function d(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var g=0,m=0;p[h]===c;)g++,h++;for(var v=(p.length-h)*u+1>>>0,b=new Uint8Array(v);p[h];){var T=e[p.charCodeAt(h)];if(T===255)return;for(var x=0,A=v-1;(T!==0||x<m)&&A!==-1;A--,x++)T+=a*b[A]>>>0,b[A]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=x,h++}if(p[h]!==" "){for(var N=v-m;N!==v&&b[N]===0;)N++;for(var R=new Uint8Array(g+(v-N)),$=g;N!==v;)R[$++]=b[N++];return R}}}function w(p){var h=d(p);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:w}}var uc=lc,fc=uc,Co=fc;var qn=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")}},jn=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 _o(this,t)}},Gn=class{decoders;constructor(t){this.decoders=t}or(t){return _o(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 _o(r,t){return new Gn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var zn=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 qn(t,e,n),this.decoder=new jn(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 zn(r,t,e,n)}function oe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Co(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Kt(s(o))})}function hc(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,u=0;for(let l=0;l<o;++l){let f=s[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function dc(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 dc(s,n,e)},decode(s){return hc(s,n,e,r)}})}var vt=oe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pc=oe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Jn={};et(Jn,{identity:()=>Wn});var gc=Vo,Uo=128,yc=127,mc=~yc,bc=Math.pow(2,31);function Vo(r,t,e){t=t||[],e=e||0;for(var n=e;r>=bc;)t[e++]=r&255|Uo,r/=128;for(;r&mc;)t[e++]=r&255|Uo,r>>>=7;return t[e]=r|0,Vo.bytes=e-n+1,t}var wc=Yn,xc=128,Lo=127;function Yn(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Yn.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Lo)<<s:(i&Lo)*Math.pow(2,s),s+=7}while(i>=xc);return Yn.bytes=o-n,e}var vc=Math.pow(2,7),Bc=Math.pow(2,14),Ec=Math.pow(2,21),Ac=Math.pow(2,28),kc=Math.pow(2,35),Sc=Math.pow(2,42),Ic=Math.pow(2,49),Nc=Math.pow(2,56),Rc=Math.pow(2,63),Tc=function(r){return r<vc?1:r<Bc?2:r<Ec?3:r<Ac?4:r<kc?5:r<Sc?6:r<Ic?7:r<Nc?8:r<Rc?9:10},Cc={encode:gc,decode:wc,encodingLength:Tc},_c=Cc,ir=_c;function ar(r,t=0){return[ir.decode(r,t),ir.decode.bytes]}function Ke(r,t,e=0){return ir.encode(r,t,e),t}function Me(r){return ir.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 Ho(r){let t=Kt(r),[e,n]=ar(t),[s,o]=ar(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 Do(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Io(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 Oo=0,Uc="identity",Po=Kt;function Lc(r){return Ee(Oo,Po(r))}var Wn={code:Oo,name:Uc,encode:Po,digest:Lc};var ts={};et(ts,{sha256:()=>bt,sha512:()=>Vc});function Qn({name:r,code:t,encode:e}){return new Xn(r,t,e)}var Xn=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 Mo(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var bt=Qn({name:"sha2-256",code:18,encode:Mo("SHA-256")}),Vc=Qn({name:"sha2-512",code:19,encode:Mo("SHA-512")});function kt(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 Ae(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function Mt(r=0){return globalThis.Buffer?.allocUnsafe!=null?Ae(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function Ft(r,t){if(globalThis.Buffer!=null)return Ae(globalThis.Buffer.concat(r,t));t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Mt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return Ae(e)}var es={};et(es,{base10:()=>Hc});var Hc=oe({prefix:"9",name:"base10",alphabet:"0123456789"});var rs={};et(rs,{base16:()=>Dc,base16upper:()=>Oc});var Dc=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Oc=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ns={};et(ns,{base2:()=>Pc});var Pc=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ss={};et(ss,{base256emoji:()=>qc});var Fo=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}"),Kc=Fo.reduce((r,t,e)=>(r[e]=t,r),[]),Mc=Fo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Fc(r){return r.reduce((t,e)=>(t+=Kc[e],t),"")}function $c(r){let t=[];for(let e of r){let n=Mc[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var qc=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:Fc,decode:$c});var os={};et(os,{base32:()=>$e,base32hex:()=>Zc,base32hexpad:()=>Wc,base32hexpadupper:()=>Jc,base32hexupper:()=>Yc,base32pad:()=>Gc,base32padupper:()=>zc,base32upper:()=>jc,base32z:()=>Xc});var $e=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),jc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Gc=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),zc=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Zc=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Yc=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Wc=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Jc=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Xc=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var is={};et(is,{base36:()=>Qc,base36upper:()=>tl});var Qc=oe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),tl=oe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var as={};et(as,{base64:()=>ke,base64pad:()=>el,base64url:()=>rl,base64urlpad:()=>nl});var ke=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),el=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),rl=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),nl=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var cs={};et(cs,{base8:()=>sl});var sl=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ls={};et(ls,{identity:()=>ol});var ol=Pe({prefix:"\0",name:"identity",encode:r=>Ro(r),decode:r=>No(r)});var rd=new TextEncoder,nd=new TextDecoder;function $o(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return ll(e,us(r),t??vt.encoder);default:return ul(e,us(r),t??$e.encoder)}}var qo=new WeakMap;function us(r){let t=qo.get(r);if(t==null){let e=new Map;return qo.set(r,e),e}return t}var Rr=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!==lr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==fl)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&&Do(t.multihash,n.multihash)}toString(t){return $o(this,t)}toJSON(){return{"/":$o(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??jo(n,s,o.bytes))}else if(e[hl]===!0){let{version:n,multihash:s,code:o}=e,i=Ho(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!==lr)throw new Error(`Version 0 CID must use dag-pb (code: ${lr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=jo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,lr,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=Kt(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[f,d]=ar(t.subarray(e));return e+=d,f},s=n(),o=lr;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(),u=e+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,s]=cl(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 us(o).set(n,t),o}};function cl(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 ll(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 ul(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 lr=112,fl=18;function jo(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 hl=Symbol.for("@ipld/js-cid/CID");var fs={...ls,...ns,...cs,...es,...rs,...os,...is,...Zn,...as,...ss},wd={...ts,...Jn};function zo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Go=zo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),hs=zo("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=Mt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),dl={utf8:Go,"utf-8":Go,hex:fs.base16,latin1:hs,ascii:hs,binary:hs,...fs},Tr=dl;function Z(r,t="utf8"){let e=Tr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Ae(globalThis.Buffer.from(r,"utf-8")):e.decoder.decode(`${e.prefix}${r}`)}function ds(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 Bt(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(`Wrong positive integer: ${r}`)}function pl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function ps(r,...t){if(!pl(r))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(r.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${r.length}`)}function Cr(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 je(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 Zo(r,t){ps(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var _r=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Yo(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Se=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),St=(r,t)=>r<<32-t|r>>>t,gl=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!gl)throw new Error("Non little-endian hardware is not supported");var yl=async()=>{};async function Wo(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 gs(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ie(r){if(typeof r=="string"&&(r=gs(r)),!Yo(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function Ur(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];if(!Yo(s))throw new Error("Uint8Array expected");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 Ge=class{clone(){return this._cloneInto()}},ml={}.toString;function Jo(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(ie(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ze(r=32){if(_r&&typeof _r.getRandomValues=="function")return _r.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,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var ae=class extends Ge{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=Se(this.buffer)}update(t){je(this);let{view:e,buffer:n,blockLen:s}=this;t=ie(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=Se(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){je(this),Zo(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 f=i;f<s;f++)e[f]=0;bl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Se(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],o)}digest(){let{buffer: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 Lr=BigInt(4294967295),ys=BigInt(32);function Xo(r,t=!1){return t?{h:Number(r&Lr),l:Number(r>>ys&Lr)}:{h:Number(r>>ys&Lr)|0,l:Number(r&Lr)|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}=Xo(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var xl=(r,t)=>BigInt(r>>>0)<<ys|BigInt(t>>>0),vl=(r,t,e)=>r>>>e,Bl=(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,Tl=(r,t,e)=>t<<e|r>>>32-e,Cl=(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:Xo,split:wl,toBig:xl,shrSH:vl,shrSL:Bl,rotrSH:El,rotrSL:Al,rotrBH:kl,rotrBL:Sl,rotr32H:Il,rotr32L:Nl,rotlSH:Rl,rotlSL:Tl,rotlBH:Cl,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))),ce=new Uint32Array(80),le=new Uint32Array(80),ms=class extends ae{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:u,El:l,Fh:f,Fl:d,Gh:w,Gl:p,Hh:h,Hl:g}=this;return[t,e,n,s,o,i,a,c,u,l,f,d,w,p,h,g]}set(t,e,n,s,o,i,a,c,u,l,f,d,w,p,h,g){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=u|0,this.El=l|0,this.Fh=f|0,this.Fl=d|0,this.Gh=w|0,this.Gl=p|0,this.Hh=h|0,this.Hl=g|0}process(t,e){for(let b=0;b<16;b++,e+=4)ce[b]=t.getUint32(e),le[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=ce[b-15]|0,x=le[b-15]|0,A=L.rotrSH(T,x,1)^L.rotrSH(T,x,8)^L.shrSH(T,x,7),N=L.rotrSL(T,x,1)^L.rotrSL(T,x,8)^L.shrSL(T,x,7),R=ce[b-2]|0,$=le[b-2]|0,M=L.rotrSH(R,$,19)^L.rotrBH(R,$,61)^L.shrSH(R,$,6),V=L.rotrSL(R,$,19)^L.rotrBL(R,$,61)^L.shrSL(R,$,6),rt=L.add4L(N,V,le[b-7],le[b-16]),tt=L.add4H(rt,A,M,ce[b-7],ce[b-16]);ce[b]=tt|0,le[b]=rt|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:d,Fh:w,Fl:p,Gh:h,Gl:g,Hh:m,Hl:v}=this;for(let b=0;b<80;b++){let T=L.rotrSH(f,d,14)^L.rotrSH(f,d,18)^L.rotrBH(f,d,41),x=L.rotrSL(f,d,14)^L.rotrSL(f,d,18)^L.rotrBL(f,d,41),A=f&w^~f&h,N=d&p^~d&g,R=L.add5L(v,x,N,Fl[b],le[b]),$=L.add5H(R,m,T,A,Ml[b],ce[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,xt=s&i^s&c^i&c;m=h|0,v=g|0,h=w|0,g=p|0,w=f|0,p=d|0,{h:f,l:d}=L.add(u|0,l|0,$|0,M|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let B=L.add3L(M,rt,xt);n=L.add3H(B,$,V,tt),s=B|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:u,l}=L.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:d}=L.add(this.Eh|0,this.El|0,f|0,d|0),{h:w,l:p}=L.add(this.Fh|0,this.Fl|0,w|0,p|0),{h,l:g}=L.add(this.Gh|0,this.Gl|0,h|0,g|0),{h:m,l:v}=L.add(this.Hh|0,this.Hl|0,m|0,v|0),this.set(n,s,o,i,a,c,u,l,f,d,w,p,h,g,m,v)}roundClean(){ce.fill(0),le.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 ue=ze(()=>new ms);var Hr={};et(Hr,{bitGet:()=>Yl,bitLen:()=>Zl,bitMask:()=>ur,bitSet:()=>Wl,bytesToHex:()=>qt,bytesToNumberBE:()=>jt,bytesToNumberLE:()=>fe,concatBytes:()=>Gt,createHmacDrbg:()=>xs,ensureBytes:()=>Q,equalBytes:()=>Gl,hexToBytes:()=>Ie,hexToNumber:()=>ws,isBytes:()=>It,numberToBytesBE:()=>he,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>ri,numberToVarBytesBE:()=>jl,utf8ToBytes:()=>zl,validateObject:()=>Vt});var ei=BigInt(0),Vr=BigInt(1),$l=BigInt(2);function It(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qt(r){if(!It(r))throw new Error("Uint8Array expected");let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}function ri(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function ws(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 Qo(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=Qo(r.charCodeAt(o)),a=Qo(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 ws(qt(r))}function fe(r){if(!It(r))throw new Error("Uint8Array expected");return ws(qt(Uint8Array.from(r).reverse()))}function he(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return he(r,t).reverse()}function jl(r){return Ie(ri(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(It(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 s=0;s<r.length;s++){let o=r[s];if(!It(o))throw new Error("Uint8Array expected");t+=o.length}let e=new Uint8Array(t),n=0;for(let s=0;s<r.length;s++){let o=r[s];e.set(o,n),n+=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>ei;r>>=Vr,t+=1);return t}function Yl(r,t){return r>>BigInt(t)&Vr}var Wl=(r,t,e)=>r|(e?Vr:ei)<<BigInt(t),ur=r=>($l<<BigInt(r-1))-Vr,bs=r=>new Uint8Array(r),ti=r=>Uint8Array.from(r);function xs(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=bs(r),s=bs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=bs())=>{s=a(ti([0]),f),n=a(),f.length!==0&&(s=a(ti([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let w=n.slice();d.push(w),f+=n.length}return Gt(...d)};return(f,d)=>{i(),c(f);let w;for(;!(w=d(u()));)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"||It(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 Vt(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),vs=BigInt(4),ni=BigInt(5),si=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 Dr(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 u=n/e,l=n%e,f=s-i*u,d=o-a*u;n=e,e=l,s=i,o=a,i=f,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)/vs;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))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 u=n,l=a.pow(a.mul(a.ONE,s),e),f=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<u&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let p=a.pow(l,Y<<BigInt(u-w-1));l=a.sqr(p),f=a.mul(f,p),d=a.mul(d,l),u=w}return f}}function nu(r){if(r%vs===Xl){let t=(r+Y)/vs;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%si===ni){let t=(r-ni)/si;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),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),s))throw new Error("Cannot find square root");return u}}return r%tu,ru(r)}var oi=(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 Bs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=su.reduce((n,s)=>(n[s]="function",n),t);return Vt(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 Es(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Or(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Es(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:ur(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,u)=>c===u,sqr:c=>j(c*c,r),add:(c,u)=>j(c+u,r),sub:(c,u)=>j(c-u,r),mul:(c,u)=>j(c*u,r),pow:(c,u)=>ou(a,c,u),div:(c,u)=>j(c*Dr(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Dr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>iu(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Ne(c,o):he(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?fe(c):jt(c)}});return Object.freeze(a)}function ii(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function ai(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 As(r){let t=ai(r);return t+Math.ceil(t/2)}function ci(r,t,e=!1){let n=r.length,s=ai(t),o=As(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?jt(r):fe(r),a=j(i,t-Y)+Y;return e?Ne(a,s):he(a,s)}var cu=BigInt(0),ks=BigInt(1);function Pr(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&ks&&(i=i.add(a)),a=a.double(),o>>=ks;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],u=s,l=u;for(let f=0;f<i;f++){l=u,c.push(l);for(let d=1;d<a;d++)l=l.add(u),c.push(l);u=l.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),u=r.ZERO,l=r.BASE,f=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let p=0;p<a;p++){let h=p*c,g=Number(i&f);i>>=w,g>c&&(g-=d,i+=ks);let m=h,v=h+Math.abs(g)-1,b=p%2!==0,T=g<0;g===0?l=l.add(e(b,o[m])):u=u.add(e(T,o[v]))}return{p:u,f:l}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,u=o.get(s);return u||(u=this.precomputeWindow(s,c),c!==1&&o.set(s,a(u))),this.wNAF(c,u,i)}}}function fr(r){return Bs(r.Fp),Vt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Es(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),wt=BigInt(1),Kr=BigInt(2),lu=BigInt(8),uu={zip215:!0};function fu(r){let t=fr(r);return Vt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Mr(r){let t=fu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=Kr<<BigInt(a*8)-wt,l=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(E=>E),w=t.domain||((E,y,S)=>{if(y.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),p=E=>typeof E=="bigint"&&Nt<E,h=(E,y)=>p(E)&&p(y)&&E<y,g=E=>E===Nt||h(E,u);function m(E,y){if(h(E,y))return E;throw new Error(`Expected valid scalar < ${y}, got ${typeof E} ${E}`)}function v(E){return E===Nt?E:m(E,n)}let b=new Map;function T(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(y,S,C,U){if(this.ex=y,this.ey=S,this.ez=C,this.et=U,!g(y))throw new Error("x required");if(!g(S))throw new Error("y required");if(!g(C))throw new Error("z required");if(!g(U))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof x)throw new Error("extended point not allowed");let{x:S,y:C}=y||{};if(!g(S)||!g(C))throw new Error("invalid affine point");return new x(S,C,wt,l(S*C))}static normalizeZ(y){let S=e.invertBatch(y.map(C=>C.ez));return y.map((C,U)=>C.toAffine(S[U])).map(x.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:S}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:U,ez:D,et:O}=this,q=l(C*C),K=l(U*U),F=l(D*D),nt=l(F*F),J=l(q*y),lt=l(F*l(J+K)),ut=l(nt+l(S*l(q*K)));if(lt!==ut)throw new Error("bad point: equation left != right (1)");let it=l(C*U),ht=l(D*O);if(it!==ht)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:S,ey:C,ez:U}=this,{ex:D,ey:O,ez:q}=y,K=l(S*q),F=l(D*U),nt=l(C*q),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:y}=t,{ex:S,ey:C,ez:U}=this,D=l(S*S),O=l(C*C),q=l(Kr*l(U*U)),K=l(y*D),F=S+C,nt=l(l(F*F)-D-O),J=K+O,lt=J-q,ut=K-O,it=l(nt*lt),ht=l(J*ut),Pt=l(nt*ut),Be=l(lt*J);return new x(it,ht,Be,Pt)}add(y){T(y);let{a:S,d:C}=t,{ex:U,ey:D,ez:O,et:q}=this,{ex:K,ey:F,ez:nt,et:J}=y;if(S===BigInt(-1)){let yo=l((D-U)*(F+K)),mo=l((D+U)*(F-K)),Mn=l(mo-yo);if(Mn===Nt)return this.double();let bo=l(O*Kr*J),wo=l(q*Kr*nt),xo=wo+bo,vo=mo+yo,Bo=wo-bo,Ya=l(xo*Mn),Wa=l(vo*Bo),Ja=l(xo*Bo),Xa=l(Mn*vo);return new x(Ya,Wa,Xa,Ja)}let lt=l(U*K),ut=l(D*F),it=l(q*C*J),ht=l(O*nt),Pt=l((U+D)*(K+F)-lt-ut),Be=ht-it,or=ht+it,go=l(ut-S*lt),ja=l(Pt*Be),Ga=l(or*go),za=l(Pt*go),Za=l(Be*or);return new x(ja,Ga,Za,za)}subtract(y){return this.add(y.negate())}wNAF(y){return R.wNAFCached(this,b,y,x.normalizeZ)}multiply(y){let{p:S,f:C}=this.wNAF(m(y,n));return x.normalizeZ([S,C])[0]}multiplyUnsafe(y){let S=v(y);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(y){let{ex:S,ey:C,ez:U}=this,D=this.is0();y==null&&(y=D?lu:e.inv(U));let O=l(S*y),q=l(C*y),K=l(U*y);if(D)return{x:Nt,y:wt};if(K!==wt)throw new Error("invZ was invalid");return{x:O,y:q}}clearCofactor(){let{h:y}=t;return y===wt?this:this.multiplyUnsafe(y)}static fromHex(y,S=!1){let{d:C,a:U}=t,D=e.BYTES;y=Q("pointHex",y,D);let O=y.slice(),q=y[D-1];O[D-1]=q&-129;let K=fe(O);K===Nt||(S?m(K,u):m(K,e.ORDER));let F=l(K*K),nt=l(F-wt),J=l(C*F-U),{isValid:lt,value:ut}=f(nt,J);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let it=(ut&wt)===wt,ht=(q&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(y){return V(y).point}toRawBytes(){let{x:y,y:S}=this.toAffine(),C=Ne(S,e.BYTES);return C[C.length-1]|=y&wt?128:0,C}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=Pr(x,a*8);function $(E){return j(E,n)}function M(E){return $(fe(E))}function V(E){let y=a;E=Q("private key",E,y);let S=Q("hashed private key",o(E),2*y),C=d(S.slice(0,y)),U=S.slice(y,2*y),D=M(C),O=A.multiply(D),q=O.toRawBytes();return{head:C,prefix:U,scalar:D,point:O,pointBytes:q}}function rt(E){return V(E).pointBytes}function tt(E=new Uint8Array,...y){let S=Gt(...y);return M(o(w(S,Q("context",E),!!s)))}function xt(E,y,S={}){E=Q("message",E),s&&(E=s(E));let{prefix:C,scalar:U,pointBytes:D}=V(y),O=tt(S.context,C,E),q=A.multiply(O).toRawBytes(),K=tt(S.context,q,D,E),F=$(O+K*U);v(F);let nt=Gt(q,Ne(F,e.BYTES));return Q("result",nt,a*2)}let B=uu;function I(E,y,S,C=B){let{context:U,zip215:D}=C,O=e.BYTES;E=Q("signature",E,2*O),y=Q("message",y),s&&(y=s(y));let q=fe(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(q)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let J=tt(U,F.toRawBytes(),K.toRawBytes(),y);return F.add(K.multiplyUnsafe(J)).subtract(nt).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:xt,verify:I,ExtendedPoint:x,utils:{getExtendedPublicKey:V,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=x.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var Is=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),li=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),t0=BigInt(0),hu=BigInt(1),Ss=BigInt(2),du=BigInt(5),ui=BigInt(10),pu=BigInt(20),gu=BigInt(40),fi=BigInt(80);function yu(r){let t=Is,n=r*r%t*r%t,s=W(n,Ss,t)*n%t,o=W(s,hu,t)*r%t,i=W(o,du,t)*o%t,a=W(i,ui,t)*i%t,c=W(a,pu,t)*a%t,u=W(c,gu,t)*c%t,l=W(u,fi,t)*u%t,f=W(l,fi,t)*u%t,d=W(f,ui,t)*i%t;return{pow_p_5_8:W(d,Ss,t)*r%t,b2:n}}function mu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function bu(r,t){let e=Is,n=j(t*t*t,e),s=j(n*n*t,e),o=yu(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,u=j(i*li,e),l=a===r,f=a===j(-r,e),d=a===j(-r*li,e);return l&&(i=c),(f||d)&&(i=u),oi(i,e)&&(i=j(-i,e)),{isValid:l||f,value:i}}var zt=Or(Is,void 0,!0),Ns={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ue,randomBytes:Ze,adjustScalarBytes:mu,uvRatio:bu},Ye=Mr(Ns);function hi(r,t,e){if(t.length>255)throw new Error("Context is too big");return Ur(gs("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var e0=Mr({...Ns,domain:hi}),r0=Mr({...Ns,domain:hi,prehash:ue});var wu=(zt.ORDER+BigInt(3))/BigInt(8),n0=zt.pow(Ss,wu),s0=zt.sqrt(zt.neg(zt.ONE)),o0=(zt.ORDER-BigInt(5))/BigInt(8),i0=BigInt(486662);var a0=ii(zt,zt.neg(BigInt(486664)));var c0=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),l0=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),u0=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),f0=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var h0=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var We=32,Zt=64,Fr=32;function di(){let r=Ye.utils.randomPrivateKey(),t=Ye.getPublicKey(r);return{privateKey:mi(r,t),publicKey:t}}function pi(r){if(r.length!==Fr)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=Ye.getPublicKey(t);return{privateKey:mi(t,e),publicKey:e}}function gi(r,t){let e=r.subarray(0,Fr);return Ye.sign(t instanceof Uint8Array?t:t.subarray(),e)}function yi(r,t,e){return Ye.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function mi(r,t){let e=new Uint8Array(Zt);for(let n=0;n<Fr;n++)e[n]=r[n],e[Fr+n]=t[n];return e}var Rs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function $r(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(f,d){let w=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:p};typeof d=="string"&&(d=Z(d));let g;if(d.length===0){g=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["encrypt"]);try{let v={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,b,{name:t,length:e},!0,["encrypt"])}catch{g=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["encrypt"])}}else{let v={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,g,f);return Ft([w,h.iv,new Uint8Array(m)])}async function u(f,d){let w=f.subarray(0,o),p=f.subarray(o,o+n),h=f.subarray(o+n),g={name:t,iv:p};typeof d=="string"&&(d=Z(d));let m;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",Rs,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let v=await a.subtle.decrypt(g,m,h);return new Uint8Array(v)}return{encrypt:c,decrypt:u}}async function Je(r,t){let n=await $r().encrypt(r,t);return ke.encode(n)}var Qe={};et(Qe,{KeyType:()=>G,PrivateKey:()=>Ct,PublicKey:()=>Tt});var Ts=new Float32Array([-0]),de=new Uint8Array(Ts.buffer);function wi(r,t,e){Ts[0]=r,t[e]=de[0],t[e+1]=de[1],t[e+2]=de[2],t[e+3]=de[3]}function xi(r,t){return de[0]=r[t],de[1]=r[t+1],de[2]=r[t+2],de[3]=r[t+3],Ts[0]}var Cs=new Float64Array([-0]),dt=new Uint8Array(Cs.buffer);function vi(r,t,e){Cs[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 Bi(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],Cs[0]}var vu=BigInt(Number.MAX_SAFE_INTEGER),Bu=BigInt(Number.MIN_SAFE_INTEGER),yt=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 Te;if(t<vu&&t>Bu)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>Ei&&(s=0n,++n>Ei&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Te;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):Te}},Te=new yt(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var Ei=4294967296n;function Ai(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 ki(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 qr(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 qr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Rt(this,4);return qr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Rt(this,4);let t=xi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Rt(this,4);let t=Bi(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 ki(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 yt(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=qr(this.buf,this.pos+=4),e=qr(this.buf,this.pos+=4);return new yt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){return this.readLongVarint().toNumber(!0)}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 jr(r,t){let e=Ls(r);return t.decode(e)}function Vs(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Mt(i);s+i>t&&(n=Mt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Ce=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}},Eu=Vs();function Au(r){return globalThis.Buffer!=null?Mt(r):Eu(r)}var pr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ce(Hs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ce(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(hr,10,yt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=yt.fromBigInt(t);return this._push(hr,e.length(),e)}uint64Number(t){let e=yt.fromNumber(t);return this._push(hr,e.length(),e)}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=yt.fromBigInt(t).zzEncode();return this._push(hr,e.length(),e)}sint64Number(t){let e=yt.fromNumber(t).zzEncode();return this._push(hr,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(dr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=yt.fromBigInt(t);return this._push(dr,4,e.lo)._push(dr,4,e.hi)}fixed64Number(t){let e=yt.fromNumber(t);return this._push(dr,4,e.lo)._push(dr,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(wi,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(Su,e,t)}string(t){let e=Ai(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 Ce(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 Ce(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=Au(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 ku(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ps=class extends Ce{next;constructor(t,e){super(ku,t,e),this.next=void 0}};function hr(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 dr(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 Su(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(pr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Iu,t,r),this},pr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Nu,t,r),this});function Iu(r,t,e){t.set(r,e)}function Nu(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 pr}function Gr(r,t){let e=Ks();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Xe;(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"})(Xe||(Xe={}));function zr(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 zr("enum",Xe.VARINT,e,n)}function Zr(r,t){return zr("message",Xe.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 Tt;(function(r){let t;r.codec=()=>(t==null&&(t=Zr((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=>Gr(e,r.codec()),r.decode=e=>jr(e,r.codec())})(Tt||(Tt={}));var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=Zr((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=>Gr(e,r.codec()),r.decode=e=>jr(e,r.codec())})(Ct||(Ct={}));var _e=class{_key;constructor(t){this._key=tr(t,We)}verify(t,e){return yi(this._key,e,t)}marshal(){return this._key}get bytes(){return Tt.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}},Yt=class{_key;_publicKey;constructor(t,e){this._key=tr(t,Zt),this._publicKey=tr(e,We)}sign(t){return gi(this._key,t)}get public(){return new _e(this._publicKey)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Bt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Wn.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Je(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ru(r){if(r.length>Zt){r=tr(r,Zt+We);let n=r.subarray(0,Zt),s=r.subarray(Zt,r.length);return new Yt(n,s)}r=tr(r,Zt);let t=r.subarray(0,Zt),e=r.subarray(We);return new Yt(t,e)}function Tu(r){return r=tr(r,We),new _e(r)}async function Cu(){let{privateKey:r,publicKey:t}=di();return new Yt(r,t)}async function $s(r){let{privateKey:t,publicKey:e}=pi(r);return new Yt(t,e)}function tr(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=Tr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):e.encoder.encode(r).substring(1)}var Ii={"P-256":256,"P-384":384,"P-521":521},_u=Object.keys(Ii),js=_u.join(" / ");async function Ni(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",Lu(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,[]),u=await z.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ii[r]);return new Uint8Array(u,0,u.byteLength)},n=await z.get().subtle.exportKey("jwk",t.publicKey);return{key:Uu(n),genSharedKey:e}}var Ri={"P-256":32,"P-384":48,"P-521":66};function Uu(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=Ri[r.crv];return Ft([Uint8Array.from([4]),ds(r.x,t),ds(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=Ri[r];if(!kt(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 Lu=(r,t)=>({...Ti(r,t.public),d:st(t.private,"base64url")});var Ci=Ni;async function _i(r,t){let e=ke.decode(r);return $r().decrypt(e,t)}var Ui={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Li(r,t,e){let n=Ui[r];if(n==null){let v=Object.keys(Ui).join(" / ");throw new _(`unknown cipher type '${r}'. Must be ${v}`,"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),u=await Fn(t,e),l=await u.digest(a),f=[],d=0;for(;d<c;){let v=await u.digest(Ft([l,a])),b=v.length;d+b>c&&(b=c-d),f.push(v),d+=b,l=await u.digest(l)}let w=c/2,p=Ft(f),h=p.subarray(0,w),g=p.subarray(w,c),m=v=>({iv:v.subarray(0,o),cipherKey:v.subarray(o,o+s),macKey:v.subarray(o+s)});return{k1:m(h),k2:m(g)}}var ro={};et(ro,{MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,fromJwk:()=>sf,generateKeyPair:()=>of,unmarshalRsaPrivateKey:()=>to,unmarshalRsaPublicKey:()=>nf});function Wt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Ze(r)}var me={};et(me,{exportToPem:()=>Qu,importFromPem:()=>Qs,jwkToPkcs1:()=>Yu,jwkToPkix:()=>Ju,pkcs1ToJwk:()=>Zu,pkixToJwk:()=>Wu});var Yr=class extends Ge{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Cr(t);let n=ie(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 je(this),this.iHash.update(t),this}digestInto(t){je(this),ps(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()}},gr=(r,t,e)=>new Yr(r,t).update(e).digest();gr.create=(r,t)=>new Yr(r,t);function Vi(r,t,e,n){Cr(r);let s=Jo({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=ie(t),u=ie(e),l=new Uint8Array(i),f=gr.create(r,c),d=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:d}}function Hi(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Di(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Vi(r,t,e,n),u,l=new Uint8Array(4),f=Se(l),d=new Uint8Array(a.outputLen);for(let w=1,p=0;p<o;w++,p+=a.outputLen){let h=i.subarray(p,p+a.outputLen);f.setInt32(0,w,!1),(u=c._cloneInto(u)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let g=1;g<s;g++){a._cloneInto(u).update(d).digestInto(d);for(let m=0;m<h.length;m++)h[m]^=d[m]}}return Hi(a,c,i,u,d)}async function Gs(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=Vi(r,t,e,n),l,f=new Uint8Array(4),d=Se(f),w=new Uint8Array(c.outputLen);for(let p=1,h=0;h<o;p++,h+=c.outputLen){let g=a.subarray(h,h+c.outputLen);d.setInt32(0,p,!1),(l=u._cloneInto(l)).update(f).digestInto(w),g.set(w.subarray(0,g.length)),await Wo(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<g.length;m++)g[m]^=w[m]})}return Hi(c,u,a,l,w)}var P=oc(Oi());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 pe(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 u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Xr(...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 Pi(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=pe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=pe(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 Ki(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 Cp=Math.log(2);function Qr(){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 ee(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 mr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ys(this.items)}},yr=[new Uint8Array([1])],Mi="0123456789";var nr="",Ut=new ArrayBuffer(0),Ws=new Uint8Array(0),br="EndOfContent",$i="OCTET STRING",qi="BIT STRING";function re(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(!ee(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 Xt=class{constructor({blockLength:t=0,error:e=nr,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)}}};Xt.NAME="baseBlock";var pt=class extends Xt{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'")}};pt.NAME="valueBlock";var tn=class extends re(Xt){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=pe(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(!ee(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,u=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(u[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<u.length;w++)d[w]=u[w];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let d=0;d<c;d++)f[d]=u[d];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Ue(u,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};tn.NAME="identificationBlock";var en=class extends Xt{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(!ee(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=pe(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}}};en.NAME="lengthBlock";var k={},ft=class extends Xt{constructor({name:t=nr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new tn(s),this.lenBlock=new en(s),this.valueBlock=o?new o(s):new pt(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 mr;e||ji(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 Ki(e,n)}};ft.NAME="BaseBlock";function ji(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)ji(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var rn=class extends ft{constructor({value:t=nr,...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}'`}};rn.NAME="BaseStringBlock";var nn=class extends re(pt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};nn.NAME="PrimitiveValueBlock";var Gi,sn=class extends ft{constructor(t={}){super(t,nn),this.idBlock.isConstructed=!1}};Gi=sn;k.Primitive=Gi;sn.NAME="PRIMITIVE";function $u(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 On(r,t=0,e=r.length){let n=t,s=new ft({},pt),o=new Xt;if(!ee(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 u=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=$u(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 sr(r){if(!r.byteLength){let t=new ft({},pt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return On(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function qu(r,t){return r?1:t}var Ht=class extends pt{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(!ee(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(;qu(this.isIndefiniteForm,n)>0;){let i=On(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===br)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===br?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new mr;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}};Ht.NAME="ConstructedValueBlock";var zi,ge=class extends ft{constructor(t={}){super(t,Ht),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 Wa=Object.create;var Sr=Object.defineProperty;var Ja=Object.getOwnPropertyDescriptor;var Xa=Object.getOwnPropertyNames;var Qa=Object.getPrototypeOf,tc=Object.prototype.hasOwnProperty;var ec=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),et=(r,t)=>{for(var e in t)Sr(r,e,{get:t[e],enumerable:!0})},Bo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Xa(t))!tc.call(r,s)&&s!==e&&Sr(r,s,{get:()=>t[s],enumerable:!(n=Ja(t,s))||n.enumerable});return r};var rc=(r,t,e)=>(e=r!=null?Wa(Qa(r)):{},Bo(t||!r||!r.__esModule?Sr(e,"default",{value:r,enumerable:!0}):e,r)),nc=r=>Bo(Sr({},"__esModule",{value:!0}),r);var Vi=ec(er=>{"use strict";var _u="[object ArrayBuffer]",Jt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===_u}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}},Gs="string",Uu=/^[0-9a-f]+$/i,Lu=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Vu=/^[a-zA-Z0-9-_]+$/,Wr=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=Jt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Et=class{static toString(t,e=!1){let n=Jt.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}},Jr=class r{static isHex(t){return typeof t===Gs&&Uu.test(t)}static isBase64(t){return typeof t===Gs&&Lu.test(t)}static isBase64Url(t){return typeof t===Gs&&Vu.test(t)}static ToString(t,e="utf8"){let n=Jt.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 Et.toString(n,!0);case"utf16":case"utf16be":return Et.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 Et.fromString(t,!0);case"utf16":case"utf16be":return Et.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Jt.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 Wr.fromString(t);case"utf16":case"utf16be":return Et.fromString(t);case"utf16le":case"usc2":return Et.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 Wr.toString(t);case"utf16":case"utf16be":return Et.toString(t);case"utf16le":case"usc2":return Et.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=Jt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Jt.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 Et.toString(t,e)}static FromUtf16String(t,e=!1){return Et.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,"")||""}};Jr.DEFAULT_UTF8_ENCODING="utf8";function Hu(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 Du(...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 Ou(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}er.BufferSourceConverter=Jt;er.Convert=Jr;er.assign=Hu;er.combine=Du;er.isEqual=Ou});var If={};et(If,{hmac:()=>Ir,keys:()=>lo,pbkdf2:()=>ho,randomBytes:()=>Wt});var Ir={};et(Ir,{create:()=>Fn});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 sc={SHA1:"SHA-1",SHA256:"SHA-256",SHA512:"SHA-512"},oc=async(r,t)=>{let e=await z.get().subtle.sign({name:"HMAC"},r,t);return new Uint8Array(e,0,e.byteLength)};async function Fn(r,t){let e=sc[r],n=await z.get().subtle.importKey("raw",t,{name:"HMAC",hash:{name:e}},!1,["sign"]);return{async digest(s){return oc(n,s)},length:Eo[r]}}var lo={};et(lo,{Ed25519PrivateKey:()=>Yt,Ed25519PublicKey:()=>_e,MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,Secp256k1PrivateKey:()=>Oe,Secp256k1PublicKey:()=>De,generateEphemeralKeyPair:()=>Ni,generateKeyPair:()=>wf,generateKeyPairFromSeed:()=>xf,importKey:()=>Af,keyStretcher:()=>Ci,keysPBM:()=>Qe,marshalPrivateKey:()=>Ef,marshalPublicKey:()=>Bf,supportedKeys:()=>se,unmarshalPrivateKey:()=>Pa,unmarshalPublicKey:()=>vf});var _=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var $s={};et($s,{Ed25519PrivateKey:()=>Yt,Ed25519PublicKey:()=>_e,generateKeyPair:()=>Nu,generateKeyPairFromSeed:()=>Fs,unmarshalEd25519PrivateKey:()=>Su,unmarshalEd25519PublicKey:()=>Iu});var zn={};et(zn,{base58btc:()=>vt,base58flickr:()=>fc});var Lf=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 Kt(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 ic(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),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(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,m=0,v=g.length;m!==v&&g[m]===0;)m++,h++;for(var b=(v-m)*l+1>>>0,T=new Uint8Array(b);m!==v;){for(var x=g[m],A=0,N=b-1;(x!==0||A<p)&&N!==-1;N--,A++)x+=256*T[N]>>>0,T[N]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");p=A,m++}for(var R=b-p;R!==b&&T[R]===0;)R++;for(var $=c.repeat(h);R<b;++R)$+=r.charAt(T[R]);return $}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,m=0;g[h]===c;)p++,h++;for(var v=(g.length-h)*u+1>>>0,b=new Uint8Array(v);g[h];){var T=e[g.charCodeAt(h)];if(T===255)return;for(var x=0,A=v-1;(T!==0||x<m)&&A!==-1;A--,x++)T+=a*b[A]>>>0,b[A]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=x,h++}if(g[h]!==" "){for(var N=v-m;N!==v&&b[N]===0;)N++;for(var R=new Uint8Array(p+(v-N)),$=p;N!==v;)R[$++]=b[N++];return R}}}function w(g){var h=d(g);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:w}}var ac=ic,cc=ac,No=cc;var $n=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")}},qn=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)}},jn=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 jn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Gn=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 $n(t,e,n),this.decoder=new qn(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 Gn(r,t,e,n)}function oe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=No(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Kt(s(o))})}function lc(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,u=0;for(let l=0;l<o;++l){let f=s[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function uc(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 uc(s,n,e)},decode(s){return lc(s,n,e,r)}})}var vt=oe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),fc=oe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Wn={};et(Wn,{identity:()=>Yn});var hc=_o,To=128,dc=127,gc=~dc,pc=Math.pow(2,31);function _o(r,t,e){t=t||[],e=e||0;for(var n=e;r>=pc;)t[e++]=r&255|To,r/=128;for(;r&gc;)t[e++]=r&255|To,r>>>=7;return t[e]=r|0,_o.bytes=e-n+1,t}var yc=Zn,mc=128,Co=127;function Zn(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Zn.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Co)<<s:(i&Co)*Math.pow(2,s),s+=7}while(i>=mc);return Zn.bytes=o-n,e}var bc=Math.pow(2,7),wc=Math.pow(2,14),xc=Math.pow(2,21),vc=Math.pow(2,28),Bc=Math.pow(2,35),Ec=Math.pow(2,42),Ac=Math.pow(2,49),kc=Math.pow(2,56),Sc=Math.pow(2,63),Ic=function(r){return r<bc?1:r<wc?2:r<xc?3:r<vc?4:r<Bc?5:r<Ec?6:r<Ac?7:r<kc?8:r<Sc?9:10},Nc={encode:hc,decode:yc,encodingLength:Ic},Rc=Nc,ir=Rc;function ar(r,t=0){return[ir.decode(r,t),ir.decode.bytes]}function Ke(r,t,e=0){return ir.encode(r,t,e),t}function Me(r){return ir.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=Kt(r),[e,n]=ar(t),[s,o]=ar(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,Tc="identity",Ho=Kt;function Cc(r){return Ee(Vo,Ho(r))}var Yn={code:Vo,name:Tc,encode:Ho,digest:Cc};var Qn={};et(Qn,{sha256:()=>bt,sha512:()=>_c});function Xn({name:r,code:t,encode:e}){return new Jn(r,t,e)}var Jn=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=Xn({name:"sha2-256",code:18,encode:Oo("SHA-256")}),_c=Xn({name:"sha2-512",code:19,encode:Oo("SHA-512")});function kt(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 Ae(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function Mt(r=0){return globalThis.Buffer?.allocUnsafe!=null?Ae(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function Ft(r,t){if(globalThis.Buffer!=null)return Ae(globalThis.Buffer.concat(r,t));t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Mt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return Ae(e)}var ts={};et(ts,{base10:()=>Uc});var Uc=oe({prefix:"9",name:"base10",alphabet:"0123456789"});var es={};et(es,{base16:()=>Lc,base16upper:()=>Vc});var Lc=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Vc=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var rs={};et(rs,{base2:()=>Hc});var Hc=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ns={};et(ns,{base256emoji:()=>Mc});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}"),Dc=Po.reduce((r,t,e)=>(r[e]=t,r),[]),Oc=Po.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Pc(r){return r.reduce((t,e)=>(t+=Dc[e],t),"")}function Kc(r){let t=[];for(let e of r){let n=Oc[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Mc=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:Pc,decode:Kc});var ss={};et(ss,{base32:()=>$e,base32hex:()=>jc,base32hexpad:()=>zc,base32hexpadupper:()=>Zc,base32hexupper:()=>Gc,base32pad:()=>$c,base32padupper:()=>qc,base32upper:()=>Fc,base32z:()=>Yc});var $e=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Fc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),$c=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),qc=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),jc=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Gc=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),zc=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Zc=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Yc=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var os={};et(os,{base36:()=>Wc,base36upper:()=>Jc});var Wc=oe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Jc=oe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var is={};et(is,{base64:()=>ke,base64pad:()=>Xc,base64url:()=>Qc,base64urlpad:()=>tl});var ke=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Xc=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Qc=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),tl=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var as={};et(as,{base8:()=>el});var el=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var cs={};et(cs,{identity:()=>rl});var rl=Pe({prefix:"\0",name:"identity",encode:r=>So(r),decode:r=>ko(r)});var ch=new TextEncoder,lh=new TextDecoder;function Ko(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return il(e,ls(r),t??vt.encoder);default:return al(e,ls(r),t??$e.encoder)}}var Mo=new WeakMap;function ls(r){let t=Mo.get(r);if(t==null){let e=new Map;return Mo.set(r,e),e}return t}var Rr=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!==lr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==cl)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[ll]===!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!==lr)throw new Error(`Version 0 CID must use dag-pb (code: ${lr}) 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,lr,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=Kt(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[f,d]=ar(t.subarray(e));return e+=d,f},s=n(),o=lr;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(),u=e+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,s]=ol(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 ls(o).set(n,t),o}};function ol(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 il(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 al(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 lr=112,cl=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 ll=Symbol.for("@ipld/js-cid/CID");var us={...cs,...rs,...as,...ts,...es,...ss,...os,...zn,...is,...ns},kh={...Qn,...Wn};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))),fs=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=Mt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),ul={utf8:$o,"utf-8":$o,hex:us.base16,latin1:fs,ascii:fs,binary:fs,...us},Tr=ul;function Z(r,t="utf8"){let e=Tr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Ae(globalThis.Buffer.from(r,"utf-8")):e.decoder.decode(`${e.prefix}${r}`)}function hs(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 Bt(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(`Wrong positive integer: ${r}`)}function fl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function ds(r,...t){if(!fl(r))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(r.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${r.length}`)}function Cr(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 je(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){ds(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var _r=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Go(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Se=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),St=(r,t)=>r<<32-t|r>>>t,hl=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!hl)throw new Error("Non little-endian hardware is not supported");var dl=async()=>{};async function zo(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 dl(),n+=o)}}function gs(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ie(r){if(typeof r=="string"&&(r=gs(r)),!Go(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function Ur(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];if(!Go(s))throw new Error("Uint8Array expected");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 Ge=class{clone(){return this._cloneInto()}},gl={}.toString;function Zo(r,t){if(t!==void 0&&gl.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(ie(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ze(r=32){if(_r&&typeof _r.getRandomValues=="function")return _r.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function pl(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,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var ae=class extends Ge{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=Se(this.buffer)}update(t){je(this);let{view:e,buffer:n,blockLen:s}=this;t=ie(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=Se(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){je(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 f=i;f<s;f++)e[f]=0;pl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Se(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],o)}digest(){let{buffer: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 Lr=BigInt(4294967295),ps=BigInt(32);function Yo(r,t=!1){return t?{h:Number(r&Lr),l:Number(r>>ps&Lr)}:{h:Number(r>>ps&Lr)|0,l:Number(r&Lr)|0}}function yl(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 ml=(r,t)=>BigInt(r>>>0)<<ps|BigInt(t>>>0),bl=(r,t,e)=>r>>>e,wl=(r,t,e)=>r<<32-e|t>>>e,xl=(r,t,e)=>r>>>e|t<<32-e,vl=(r,t,e)=>r<<32-e|t>>>e,Bl=(r,t,e)=>r<<64-e|t>>>e-32,El=(r,t,e)=>r>>>e-32|t<<64-e,Al=(r,t)=>t,kl=(r,t)=>r,Sl=(r,t,e)=>r<<e|t>>>32-e,Il=(r,t,e)=>t<<e|r>>>32-e,Nl=(r,t,e)=>t<<e-32|r>>>64-e,Rl=(r,t,e)=>r<<e-32|t>>>64-e;function Tl(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Cl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),_l=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ul=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Ll=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Vl=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Hl=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Dl={fromBig:Yo,split:yl,toBig:ml,shrSH:bl,shrSL:wl,rotrSH:xl,rotrSL:vl,rotrBH:Bl,rotrBL:El,rotr32H:Al,rotr32L:kl,rotlSH:Sl,rotlSL:Il,rotlBH:Nl,rotlBL:Rl,add:Tl,add3L:Cl,add3H:_l,add4L:Ul,add4H:Ll,add5H:Hl,add5L:Vl},L=Dl;var[Ol,Pl]=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))),ce=new Uint32Array(80),le=new Uint32Array(80),ys=class extends ae{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:u,El:l,Fh:f,Fl:d,Gh:w,Gl:g,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,u,l,f,d,w,g,h,p]}set(t,e,n,s,o,i,a,c,u,l,f,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=u|0,this.El=l|0,this.Fh=f|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)ce[b]=t.getUint32(e),le[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=ce[b-15]|0,x=le[b-15]|0,A=L.rotrSH(T,x,1)^L.rotrSH(T,x,8)^L.shrSH(T,x,7),N=L.rotrSL(T,x,1)^L.rotrSL(T,x,8)^L.shrSL(T,x,7),R=ce[b-2]|0,$=le[b-2]|0,M=L.rotrSH(R,$,19)^L.rotrBH(R,$,61)^L.shrSH(R,$,6),V=L.rotrSL(R,$,19)^L.rotrBL(R,$,61)^L.shrSL(R,$,6),rt=L.add4L(N,V,le[b-7],le[b-16]),tt=L.add4H(rt,A,M,ce[b-7],ce[b-16]);ce[b]=tt|0,le[b]=rt|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:d,Fh:w,Fl:g,Gh:h,Gl:p,Hh:m,Hl:v}=this;for(let b=0;b<80;b++){let T=L.rotrSH(f,d,14)^L.rotrSH(f,d,18)^L.rotrBH(f,d,41),x=L.rotrSL(f,d,14)^L.rotrSL(f,d,18)^L.rotrBL(f,d,41),A=f&w^~f&h,N=d&g^~d&p,R=L.add5L(v,x,N,Pl[b],le[b]),$=L.add5H(R,m,T,A,Ol[b],ce[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,xt=s&i^s&c^i&c;m=h|0,v=p|0,h=w|0,p=g|0,w=f|0,g=d|0,{h:f,l:d}=L.add(u|0,l|0,$|0,M|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let B=L.add3L(M,rt,xt);n=L.add3H(B,$,V,tt),s=B|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:u,l}=L.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:d}=L.add(this.Eh|0,this.El|0,f|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:m,l:v}=L.add(this.Hh|0,this.Hl|0,m|0,v|0),this.set(n,s,o,i,a,c,u,l,f,d,w,g,h,p,m,v)}roundClean(){ce.fill(0),le.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 ue=ze(()=>new ys);var Hr={};et(Hr,{bitGet:()=>Gl,bitLen:()=>jl,bitMask:()=>ur,bitSet:()=>zl,bytesToHex:()=>qt,bytesToNumberBE:()=>jt,bytesToNumberLE:()=>fe,concatBytes:()=>Gt,createHmacDrbg:()=>ws,ensureBytes:()=>Q,equalBytes:()=>$l,hexToBytes:()=>Ie,hexToNumber:()=>bs,isBytes:()=>It,numberToBytesBE:()=>he,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>Qo,numberToVarBytesBE:()=>Fl,utf8ToBytes:()=>ql,validateObject:()=>Vt});var Xo=BigInt(0),Vr=BigInt(1),Kl=BigInt(2);function It(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Ml=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qt(r){if(!It(r))throw new Error("Uint8Array expected");let t="";for(let e=0;e<r.length;e++)t+=Ml[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 fe(r){if(!It(r))throw new Error("Uint8Array expected");return bs(qt(Uint8Array.from(r).reverse()))}function he(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return he(r,t).reverse()}function Fl(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(It(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 s=0;s<r.length;s++){let o=r[s];if(!It(o))throw new Error("Uint8Array expected");t+=o.length}let e=new Uint8Array(t),n=0;for(let s=0;s<r.length;s++){let o=r[s];e.set(o,n),n+=o.length}return e}function $l(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 ql(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function jl(r){let t;for(t=0;r>Xo;r>>=Vr,t+=1);return t}function Gl(r,t){return r>>BigInt(t)&Vr}var zl=(r,t,e)=>r|(e?Vr:Xo)<<BigInt(t),ur=r=>(Kl<<BigInt(r-1))-Vr,ms=r=>new Uint8Array(r),Jo=r=>Uint8Array.from(r);function ws(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=ms(r),s=ms(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=ms())=>{s=a(Jo([0]),f),n=a(),f.length!==0&&(s=a(Jo([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let w=n.slice();d.push(w),f+=n.length}return Gt(...d)};return(f,d)=>{i(),c(f);let w;for(;!(w=d(u()));)c();return i(),w}}var Zl={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"||It(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 Vt(r,t,e={}){let n=(s,o,i)=>{let a=Zl[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),Yl=BigInt(3),xs=BigInt(4),ti=BigInt(5),ei=BigInt(8),Wl=BigInt(9),Jl=BigInt(16);function j(r,t){let e=r%t;return e>=at?e:t+e}function Xl(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 Dr(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 u=n/e,l=n%e,f=s-i*u,d=o-a*u;n=e,e=l,s=i,o=a,i=f,a=d}if(n!==Y)throw new Error("invert: does not exist");return j(s,t)}function Ql(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&&Xl(s,t,r)!==r-Y;s++);if(n===1){let i=(r+Y)/xs;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))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 u=n,l=a.pow(a.mul(a.ONE,s),e),f=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<u&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let g=a.pow(l,Y<<BigInt(u-w-1));l=a.sqr(g),f=a.mul(f,g),d=a.mul(d,l),u=w}return f}}function tu(r){if(r%xs===Yl){let t=(r+Y)/xs;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),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),s))throw new Error("Cannot find square root");return u}}return r%Jl,Ql(r)}var ri=(r,t)=>(j(r,t)&Y)===Y,eu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function vs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=eu.reduce((n,s)=>(n[s]="function",n),t);return Vt(r,e)}function ru(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 nu(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 Bs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Or(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Bs(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=tu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:ur(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,u)=>c===u,sqr:c=>j(c*c,r),add:(c,u)=>j(c+u,r),sub:(c,u)=>j(c-u,r),mul:(c,u)=>j(c*u,r),pow:(c,u)=>ru(a,c,u),div:(c,u)=>j(c*Dr(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Dr(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>nu(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Ne(c,o):he(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?fe(c):jt(c)}});return Object.freeze(a)}function ni(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function si(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 Es(r){let t=si(r);return t+Math.ceil(t/2)}function oi(r,t,e=!1){let n=r.length,s=si(t),o=Es(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?jt(r):fe(r),a=j(i,t-Y)+Y;return e?Ne(a,s):he(a,s)}var ou=BigInt(0),As=BigInt(1);function Pr(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>ou;)o&As&&(i=i.add(a)),a=a.double(),o>>=As;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],u=s,l=u;for(let f=0;f<i;f++){l=u,c.push(l);for(let d=1;d<a;d++)l=l.add(u),c.push(l);u=l.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),u=r.ZERO,l=r.BASE,f=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let g=0;g<a;g++){let h=g*c,p=Number(i&f);i>>=w,p>c&&(p-=d,i+=As);let m=h,v=h+Math.abs(p)-1,b=g%2!==0,T=p<0;p===0?l=l.add(e(b,o[m])):u=u.add(e(T,o[v]))}return{p:u,f:l}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,u=o.get(s);return u||(u=this.precomputeWindow(s,c),c!==1&&o.set(s,a(u))),this.wNAF(c,u,i)}}}function fr(r){return vs(r.Fp),Vt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Bs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),wt=BigInt(1),Kr=BigInt(2),iu=BigInt(8),au={zip215:!0};function cu(r){let t=fr(r);return Vt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Mr(r){let t=cu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=Kr<<BigInt(a*8)-wt,l=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(E=>E),w=t.domain||((E,y,S)=>{if(y.length||S)throw new Error("Contexts/pre-hash are not supported");return E}),g=E=>typeof E=="bigint"&&Nt<E,h=(E,y)=>g(E)&&g(y)&&E<y,p=E=>E===Nt||h(E,u);function m(E,y){if(h(E,y))return E;throw new Error(`Expected valid scalar < ${y}, got ${typeof E} ${E}`)}function v(E){return E===Nt?E:m(E,n)}let b=new Map;function T(E){if(!(E instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(y,S,C,U){if(this.ex=y,this.ey=S,this.ez=C,this.et=U,!p(y))throw new Error("x required");if(!p(S))throw new Error("y required");if(!p(C))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(y){if(y instanceof x)throw new Error("extended point not allowed");let{x:S,y:C}=y||{};if(!p(S)||!p(C))throw new Error("invalid affine point");return new x(S,C,wt,l(S*C))}static normalizeZ(y){let S=e.invertBatch(y.map(C=>C.ez));return y.map((C,U)=>C.toAffine(S[U])).map(x.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:S}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:U,ez:D,et:O}=this,q=l(C*C),K=l(U*U),F=l(D*D),nt=l(F*F),J=l(q*y),lt=l(F*l(J+K)),ut=l(nt+l(S*l(q*K)));if(lt!==ut)throw new Error("bad point: equation left != right (1)");let it=l(C*U),ht=l(D*O);if(it!==ht)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:S,ey:C,ez:U}=this,{ex:D,ey:O,ez:q}=y,K=l(S*q),F=l(D*U),nt=l(C*q),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:y}=t,{ex:S,ey:C,ez:U}=this,D=l(S*S),O=l(C*C),q=l(Kr*l(U*U)),K=l(y*D),F=S+C,nt=l(l(F*F)-D-O),J=K+O,lt=J-q,ut=K-O,it=l(nt*lt),ht=l(J*ut),Pt=l(nt*ut),Be=l(lt*J);return new x(it,ht,Be,Pt)}add(y){T(y);let{a:S,d:C}=t,{ex:U,ey:D,ez:O,et:q}=this,{ex:K,ey:F,ez:nt,et:J}=y;if(S===BigInt(-1)){let po=l((D-U)*(F+K)),yo=l((D+U)*(F-K)),Mn=l(yo-po);if(Mn===Nt)return this.double();let mo=l(O*Kr*J),bo=l(q*Kr*nt),wo=bo+mo,xo=yo+po,vo=bo-mo,Ga=l(wo*Mn),za=l(xo*vo),Za=l(wo*vo),Ya=l(Mn*xo);return new x(Ga,za,Ya,Za)}let lt=l(U*K),ut=l(D*F),it=l(q*C*J),ht=l(O*nt),Pt=l((U+D)*(K+F)-lt-ut),Be=ht-it,or=ht+it,go=l(ut-S*lt),Fa=l(Pt*Be),$a=l(or*go),qa=l(Pt*go),ja=l(Be*or);return new x(Fa,$a,ja,qa)}subtract(y){return this.add(y.negate())}wNAF(y){return R.wNAFCached(this,b,y,x.normalizeZ)}multiply(y){let{p:S,f:C}=this.wNAF(m(y,n));return x.normalizeZ([S,C])[0]}multiplyUnsafe(y){let S=v(y);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(y){let{ex:S,ey:C,ez:U}=this,D=this.is0();y==null&&(y=D?iu:e.inv(U));let O=l(S*y),q=l(C*y),K=l(U*y);if(D)return{x:Nt,y:wt};if(K!==wt)throw new Error("invZ was invalid");return{x:O,y:q}}clearCofactor(){let{h:y}=t;return y===wt?this:this.multiplyUnsafe(y)}static fromHex(y,S=!1){let{d:C,a:U}=t,D=e.BYTES;y=Q("pointHex",y,D);let O=y.slice(),q=y[D-1];O[D-1]=q&-129;let K=fe(O);K===Nt||(S?m(K,u):m(K,e.ORDER));let F=l(K*K),nt=l(F-wt),J=l(C*F-U),{isValid:lt,value:ut}=f(nt,J);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let it=(ut&wt)===wt,ht=(q&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(y){return V(y).point}toRawBytes(){let{x:y,y:S}=this.toAffine(),C=Ne(S,e.BYTES);return C[C.length-1]|=y&wt?128:0,C}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=Pr(x,a*8);function $(E){return j(E,n)}function M(E){return $(fe(E))}function V(E){let y=a;E=Q("private key",E,y);let S=Q("hashed private key",o(E),2*y),C=d(S.slice(0,y)),U=S.slice(y,2*y),D=M(C),O=A.multiply(D),q=O.toRawBytes();return{head:C,prefix:U,scalar:D,point:O,pointBytes:q}}function rt(E){return V(E).pointBytes}function tt(E=new Uint8Array,...y){let S=Gt(...y);return M(o(w(S,Q("context",E),!!s)))}function xt(E,y,S={}){E=Q("message",E),s&&(E=s(E));let{prefix:C,scalar:U,pointBytes:D}=V(y),O=tt(S.context,C,E),q=A.multiply(O).toRawBytes(),K=tt(S.context,q,D,E),F=$(O+K*U);v(F);let nt=Gt(q,Ne(F,e.BYTES));return Q("result",nt,a*2)}let B=au;function I(E,y,S,C=B){let{context:U,zip215:D}=C,O=e.BYTES;E=Q("signature",E,2*O),y=Q("message",y),s&&(y=s(y));let q=fe(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(q)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let J=tt(U,F.toRawBytes(),K.toRawBytes(),y);return F.add(K.multiplyUnsafe(J)).subtract(nt).clearCofactor().equals(x.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:xt,verify:I,ExtendedPoint:x,utils:{getExtendedPublicKey:V,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=x.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var Ss=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ii=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),id=BigInt(0),lu=BigInt(1),ks=BigInt(2),uu=BigInt(5),ai=BigInt(10),fu=BigInt(20),hu=BigInt(40),ci=BigInt(80);function du(r){let t=Ss,n=r*r%t*r%t,s=W(n,ks,t)*n%t,o=W(s,lu,t)*r%t,i=W(o,uu,t)*o%t,a=W(i,ai,t)*i%t,c=W(a,fu,t)*a%t,u=W(c,hu,t)*c%t,l=W(u,ci,t)*u%t,f=W(l,ci,t)*u%t,d=W(f,ai,t)*i%t;return{pow_p_5_8:W(d,ks,t)*r%t,b2:n}}function gu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function pu(r,t){let e=Ss,n=j(t*t*t,e),s=j(n*n*t,e),o=du(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,u=j(i*ii,e),l=a===r,f=a===j(-r,e),d=a===j(-r*ii,e);return l&&(i=c),(f||d)&&(i=u),ri(i,e)&&(i=j(-i,e)),{isValid:l||f,value:i}}var zt=Or(Ss,void 0,!0),Is={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ue,randomBytes:Ze,adjustScalarBytes:gu,uvRatio:pu},Ye=Mr(Is);function li(r,t,e){if(t.length>255)throw new Error("Context is too big");return Ur(gs("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var ad=Mr({...Is,domain:li}),cd=Mr({...Is,domain:li,prehash:ue});var yu=(zt.ORDER+BigInt(3))/BigInt(8),ld=zt.pow(ks,yu),ud=zt.sqrt(zt.neg(zt.ONE)),fd=(zt.ORDER-BigInt(5))/BigInt(8),hd=BigInt(486662);var dd=ni(zt,zt.neg(BigInt(486664)));var gd=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),pd=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),yd=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),md=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var bd=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var We=32,Zt=64,Fr=32;function ui(){let r=Ye.utils.randomPrivateKey(),t=Ye.getPublicKey(r);return{privateKey:gi(r,t),publicKey:t}}function fi(r){if(r.length!==Fr)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=Ye.getPublicKey(t);return{privateKey:gi(t,e),publicKey:e}}function hi(r,t){let e=r.subarray(0,Fr);return Ye.sign(t instanceof Uint8Array?t:t.subarray(),e)}function di(r,t,e){return Ye.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function gi(r,t){let e=new Uint8Array(Zt);for(let n=0;n<Fr;n++)e[n]=r[n],e[Fr+n]=t[n];return e}var Ns={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function $r(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(f,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",Ns,{name:"AES-GCM"},!0,["encrypt"]);try{let v={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(v,b,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Ns,{name:"AES-GCM"},!0,["encrypt"])}}else{let v={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(v,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,p,f);return Ft([w,h.iv,new Uint8Array(m)])}async function u(f,d){let w=f.subarray(0,o),g=f.subarray(o,o+n),h=f.subarray(o+n),p={name:t,iv:g};typeof d=="string"&&(d=Z(d));let m;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",Ns,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let v=await a.subtle.decrypt(p,m,h);return new Uint8Array(v)}return{encrypt:c,decrypt:u}}async function Je(r,t){let n=await $r().encrypt(r,t);return ke.encode(n)}var Qe={};et(Qe,{KeyType:()=>G,PrivateKey:()=>Ct,PublicKey:()=>Tt});var Rs=new Float32Array([-0]),de=new Uint8Array(Rs.buffer);function yi(r,t,e){Rs[0]=r,t[e]=de[0],t[e+1]=de[1],t[e+2]=de[2],t[e+3]=de[3]}function mi(r,t){return de[0]=r[t],de[1]=r[t+1],de[2]=r[t+2],de[3]=r[t+3],Rs[0]}var Ts=new Float64Array([-0]),dt=new Uint8Array(Ts.buffer);function bi(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 wi(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 bu=BigInt(Number.MAX_SAFE_INTEGER),wu=BigInt(Number.MIN_SAFE_INTEGER),yt=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 Te;if(t<bu&&t>wu)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>xi&&(s=0n,++n>xi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Te;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):Te}},Te=new yt(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var xi=4294967296n;function vi(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 Bi(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 Cs(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 qr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var _s=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 qr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Rt(this,4);return qr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Rt(this,4);let t=mi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Rt(this,4);let t=wi(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 Bi(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 yt(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=qr(this.buf,this.pos+=4),e=qr(this.buf,this.pos+=4);return new yt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){return this.readLongVarint().toNumber(!0)}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 Us(r){return new _s(r instanceof Uint8Array?r:r.subarray())}function jr(r,t){let e=Us(r);return t.decode(e)}function Ls(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Mt(i);s+i>t&&(n=Mt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Ce=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Vs(){}var Ds=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},xu=Ls();function vu(r){return globalThis.Buffer!=null?Mt(r):xu(r)}var gr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ce(Vs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ce(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Os((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(hr,10,yt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=yt.fromBigInt(t);return this._push(hr,e.length(),e)}uint64Number(t){let e=yt.fromNumber(t);return this._push(hr,e.length(),e)}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=yt.fromBigInt(t).zzEncode();return this._push(hr,e.length(),e)}sint64Number(t){let e=yt.fromNumber(t).zzEncode();return this._push(hr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Hs,1,t?1:0)}fixed32(t){return this._push(dr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=yt.fromBigInt(t);return this._push(dr,4,e.lo)._push(dr,4,e.hi)}fixed64Number(t){let e=yt.fromNumber(t);return this._push(dr,4,e.lo)._push(dr,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(yi,4,t)}double(t){return this._push(bi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Hs,1,0):this.uint32(e)._push(Eu,e,t)}string(t){let e=vi(t);return e!==0?this.uint32(e)._push(Cs,e,t):this._push(Hs,1,0)}fork(){return this.states=new Ds(this),this.head=this.tail=new Ce(Vs,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 Ce(Vs,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=vu(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Hs(r,t,e){t[e]=r&255}function Bu(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Os=class extends Ce{next;constructor(t,e){super(Bu,t,e),this.next=void 0}};function hr(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 dr(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 Eu(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(gr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Au,t,r),this},gr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ku,t,r),this});function Au(r,t,e){t.set(r,e)}function ku(r,t,e){r.length<40?Cs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function Ps(){return new gr}function Gr(r,t){let e=Ps();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Xe;(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"})(Xe||(Xe={}));function zr(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ks(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 zr("enum",Xe.VARINT,e,n)}function Zr(r,t){return zr("message",Xe.LENGTH_DELIMITED,r,t)}var G;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(G||(G={}));var Ms;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Ms||(Ms={}));(function(r){r.codec=()=>Ks(Ms)})(G||(G={}));var Tt;(function(r){let t;r.codec=()=>(t==null&&(t=Zr((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=>Gr(e,r.codec()),r.decode=e=>jr(e,r.codec())})(Tt||(Tt={}));var Ct;(function(r){let t;r.codec=()=>(t==null&&(t=Zr((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=>Gr(e,r.codec()),r.decode=e=>jr(e,r.codec())})(Ct||(Ct={}));var _e=class{_key;constructor(t){this._key=tr(t,We)}verify(t,e){return di(this._key,e,t)}marshal(){return this._key}get bytes(){return Tt.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}},Yt=class{_key;_publicKey;constructor(t,e){this._key=tr(t,Zt),this._publicKey=tr(e,We)}sign(t){return hi(this._key,t)}get public(){return new _e(this._publicKey)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Bt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Yn.digest(this.public.bytes);return vt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Je(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Su(r){if(r.length>Zt){r=tr(r,Zt+We);let n=r.subarray(0,Zt),s=r.subarray(Zt,r.length);return new Yt(n,s)}r=tr(r,Zt);let t=r.subarray(0,Zt),e=r.subarray(We);return new Yt(t,e)}function Iu(r){return r=tr(r,We),new _e(r)}async function Nu(){let{privateKey:r,publicKey:t}=ui();return new Yt(r,t)}async function Fs(r){let{privateKey:t,publicKey:e}=fi(r);return new Yt(t,e)}function tr(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=Tr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):e.encoder.encode(r).substring(1)}var Ai={"P-256":256,"P-384":384,"P-521":521},Ru=Object.keys(Ai),qs=Ru.join(" / ");async function ki(r){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${qs}`,"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",Cu(r,i),{name:"ECDH",namedCurve:r},!1,["deriveBits"]):a=t.privateKey;let c=await z.get().subtle.importKey("jwk",Ii(r,o),{name:"ECDH",namedCurve:r},!1,[]),u=await z.get().subtle.deriveBits({name:"ECDH",namedCurve:r,public:c},a,Ai[r]);return new Uint8Array(u,0,u.byteLength)},n=await z.get().subtle.exportKey("jwk",t.publicKey);return{key:Tu(n),genSharedKey:e}}var Si={"P-256":32,"P-384":48,"P-521":66};function Tu(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 ${qs}`,"ERR_INVALID_CURVE");let t=Si[r.crv];return Ft([Uint8Array.from([4]),hs(r.x,t),hs(r.y,t)],1+t*2)}function Ii(r,t){if(r!=="P-256"&&r!=="P-384"&&r!=="P-521")throw new _(`Unknown curve: ${r}. Must be ${qs}`,"ERR_INVALID_CURVE");let e=Si[r];if(!kt(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 Cu=(r,t)=>({...Ii(r,t.public),d:st(t.private,"base64url")});var Ni=ki;async function Ri(r,t){let e=ke.decode(r);return $r().decrypt(e,t)}var Ti={"AES-128":{ivSize:16,keySize:16},"AES-256":{ivSize:16,keySize:32},Blowfish:{ivSize:8,keySize:32}};async function Ci(r,t,e){let n=Ti[r];if(n==null){let v=Object.keys(Ti).join(" / ");throw new _(`unknown cipher type '${r}'. Must be ${v}`,"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),u=await Fn(t,e),l=await u.digest(a),f=[],d=0;for(;d<c;){let v=await u.digest(Ft([l,a])),b=v.length;d+b>c&&(b=c-d),f.push(v),d+=b,l=await u.digest(l)}let w=c/2,g=Ft(f),h=g.subarray(0,w),p=g.subarray(w,c),m=v=>({iv:v.subarray(0,o),cipherKey:v.subarray(o,o+s),macKey:v.subarray(o+s)});return{k1:m(h),k2:m(p)}}var eo={};et(eo,{MAX_RSA_KEY_SIZE:()=>Ve,RsaPrivateKey:()=>be,RsaPublicKey:()=>Le,fromJwk:()=>ef,generateKeyPair:()=>rf,unmarshalRsaPrivateKey:()=>Qs,unmarshalRsaPublicKey:()=>tf});function Wt(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Ze(r)}var me={};et(me,{exportToPem:()=>Wu,importFromPem:()=>Xs,jwkToPkcs1:()=>Gu,jwkToPkix:()=>Zu,pkcs1ToJwk:()=>ju,pkixToJwk:()=>zu});var Yr=class extends Ge{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Cr(t);let n=ie(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 je(this),this.iHash.update(t),this}digestInto(t){je(this),ds(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()}},pr=(r,t,e)=>new Yr(r,t).update(e).digest();pr.create=(r,t)=>new Yr(r,t);function _i(r,t,e,n){Cr(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=ie(t),u=ie(e),l=new Uint8Array(i),f=pr.create(r,c),d=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:d}}function Ui(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Li(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=_i(r,t,e,n),u,l=new Uint8Array(4),f=Se(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);f.setInt32(0,w,!1),(u=c._cloneInto(u)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let p=1;p<s;p++){a._cloneInto(u).update(d).digestInto(d);for(let m=0;m<h.length;m++)h[m]^=d[m]}}return Ui(a,c,i,u,d)}async function js(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=_i(r,t,e,n),l,f=new Uint8Array(4),d=Se(f),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=u._cloneInto(l)).update(f).digestInto(w),p.set(w.subarray(0,p.length)),await zo(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<p.length;m++)p[m]^=w[m]})}return Ui(c,u,a,l,w)}var P=rc(Vi());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 u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[o-l-1]=Math.floor(s/f),s-=u[o-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Xr(...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 Hi(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 Di(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 D0=Math.log(2);function Qr(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Zs(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 ee(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 mr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Zs(this.items)}},yr=[new Uint8Array([1])],Oi="0123456789";var nr="",Ut=new ArrayBuffer(0),Ys=new Uint8Array(0),br="EndOfContent",Ki="OCTET STRING",Mi="BIT STRING";function re(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):Ys}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(!ee(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 Xt=class{constructor({blockLength:t=0,error:e=nr,warnings:n=[],valueBeforeDecode:s=Ys}={}){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)}}};Xt.NAME="baseBlock";var gt=class extends Xt{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 tn=class extends re(Xt){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):Ys,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(!ee(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,u=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(u[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<u.length;w++)d[w]=u[w];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let d=0;d<c;d++)f[d]=u[d];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Ue(u,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};tn.NAME="identificationBlock";var en=class extends Xt{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(!ee(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}}};en.NAME="lengthBlock";var k={},ft=class extends Xt{constructor({name:t=nr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new tn(s),this.lenBlock=new en(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 mr;e||Fi(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 Di(e,n)}};ft.NAME="BaseBlock";function Fi(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)Fi(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var rn=class extends ft{constructor({value:t=nr,...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}'`}};rn.NAME="BaseStringBlock";var nn=class extends re(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};nn.NAME="PrimitiveValueBlock";var $i,sn=class extends ft{constructor(t={}){super(t,nn),this.idBlock.isConstructed=!1}};$i=sn;k.Primitive=$i;sn.NAME="PRIMITIVE";function Ku(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 On(r,t=0,e=r.length){let n=t,s=new ft({},gt),o=new Xt;if(!ee(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 u=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Ku(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 sr(r){if(!r.byteLength){let t=new ft({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return On(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Mu(r,t){return r?1:t}var Ht=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(!ee(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(;Mu(this.isIndefiniteForm,n)>0;){let i=On(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===br)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===br?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new mr;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}};Ht.NAME="ConstructedValueBlock";var qi,pe=class extends ft{constructor(t={}){super(t,Ht),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};zi=ge;k.Constructed=zi;ge.NAME="CONSTRUCTED";var on=class extends pt{fromBER(t,e,n){return e}toBER(t){return Ut}};on.override="EndOfContentValueBlock";var Zi,an=class extends ft{constructor(t={}){super(t,on),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Zi=an;k.EndOfContent=Zi;an.NAME=br;var Yi,ye=class extends ft{constructor(t={}){super(t,pt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Yi=ye;k.Null=Yi;ye.NAME="NULL";var cn=class extends re(pt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return ee(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Zs.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};cn.NAME="BooleanValueBlock";var Wi,ln=class extends ft{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Wi=ln;k.Boolean=Wi;ln.NAME="BOOLEAN";var un=class extends re(Ht){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Ht.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===br){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==$i)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Ht.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};un.NAME="OctetStringValueBlock";var Ji,Qt=class r extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},un),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=On(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?ge.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};Ji=Qt;k.OctetString=Ji;Qt.NAME=$i;var fn=class extends re(Ht){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Ht.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===br){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==qi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return s}let o=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=On(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Ht.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};fn.NAME="BitStringValueBlock";var Xi,rr=class extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ge.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Xi=rr;k.BitString=Xi;rr.NAME=qi;var Qi;function ju(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let d=l;d>=0;d--,f++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+e[0];break;default:u=o[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=o.length:o=Xr(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=Xr(e,o)),o}function Fi(r){if(r>=yr.length)for(let t=yr.length;t<=r;t++){let e=new Uint8Array([0]),n=yr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Xr(e,n)),yr.push(n)}return yr[r]}function Gu(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=o[i-l]-a[c-l]-e,!0){case u<0:e=1,o[i-l]=u+10;break;default:e=0,o[i-l]=u}if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-e,u<0)e=1,o[i-l]=u+10;else{e=0,o[i-l]=u;break}return o.slice()}var wr=class extends re(pt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Zs.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Pi(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let u=0;u<8;u++){if((s&1)===1)switch(n){case t:e=Gu(Fi(n),e),i="-";break;default:e=ju(e,Fi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Mi.charAt(e[c]));return a===!1&&(i+=Mi.charAt(0)),i}};Qi=wr;wr.NAME="IntegerValueBlock";Object.defineProperty(Qi.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ta,ot=class r extends ft{constructor(t={}){super(t,wr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Qr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Qr();let e=BigInt(t),n=new mr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};ta=ot;k.Integer=ta;ot.NAME="INTEGER";var ea,hn=class extends ot{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ea=hn;k.Enumerated=ea;hn.NAME="ENUMERATED";var xr=class extends re(pt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Qr();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=pe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=P.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};xr.NAME="sidBlock";var dn=class extends pt{constructor({value:t=nr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new xr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ut;e.push(s)}return Ys(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new xr;if(s>Number.MAX_SAFE_INTEGER){Qr();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};dn.NAME="ObjectIdentifierValueBlock";var ra,_t=class extends ft{constructor(t={}){super(t,dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ra=_t;k.ObjectIdentifier=ra;_t.NAME="OBJECT IDENTIFIER";var vr=class extends re(Xt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=pe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};vr.NAME="relativeSidBlock";var pn=class extends pt{constructor({value:t=nr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new vr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Ut;n.push(o)}return Ys(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new vr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};pn.NAME="RelativeObjectIdentifierValueBlock";var na,gn=class extends ft{constructor(t={}){super(t,pn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};na=gn;k.RelativeObjectIdentifier=na;gn.NAME="RelativeObjectIdentifier";var sa,ct=class extends ge{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};sa=ct;k.Sequence=sa;ct.NAME="SEQUENCE";var oa,yn=class extends ge{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};oa=yn;k.Set=oa;yn.NAME="SET";var mn=class extends re(pt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=nr}toJSON(){return{...super.toJSON(),value:this.value}}};mn.NAME="StringValueBlock";var bn=class extends mn{};bn.NAME="SimpleStringValueBlock";var gt=class extends rn{constructor({...t}={}){super(t,bn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};gt.NAME="SIMPLE STRING";var wn=class extends gt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};wn.NAME="Utf8StringValueBlock";var ia,te=class extends wn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ia=te;k.Utf8String=ia;te.NAME="UTF8String";var xn=class extends gt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};xn.NAME="BmpStringValueBlock";var aa,vn=class extends xn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};aa=vn;k.BmpString=aa;vn.NAME="BMPString";var Bn=class extends gt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=pe(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};Bn.NAME="UniversalStringValueBlock";var ca,En=class extends Bn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ca=En;k.UniversalString=ca;En.NAME="UniversalString";var la,An=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};la=An;k.NumericString=la;An.NAME="NumericString";var ua,kn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ua=kn;k.PrintableString=ua;kn.NAME="PrintableString";var fa,Sn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};fa=Sn;k.TeletexString=fa;Sn.NAME="TeletexString";var ha,In=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ha=In;k.VideotexString=ha;In.NAME="VideotexString";var da,Nn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};da=Nn;k.IA5String=da;Nn.NAME="IA5String";var pa,Rn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};pa=Rn;k.GraphicString=pa;Rn.NAME="GraphicString";var ga,Br=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ga=Br;k.VisibleString=ga;Br.NAME="VisibleString";var ya,Tn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ya=Tn;k.GeneralString=ya;Tn.NAME="GeneralString";var ma,Cn=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ma=Cn;k.CharacterString=ma;Cn.NAME="CharacterString";var ba,Er=class extends Br{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=mt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=mt(this.month,2),e[2]=mt(this.day,2),e[3]=mt(this.hour,2),e[4]=mt(this.minute,2),e[5]=mt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};ba=Er;k.UTCTime=ba;Er.NAME="UTCTime";var wa,_n=class extends Er{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,d=n.indexOf("+"),w="";if(d===-1&&(d=n.indexOf("-"),f=-1),d!==-1){if(w=n.substring(d+1),n=n.substring(0,d),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(w.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*p,w.length===4){if(p=parseInt(w.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=f*p}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,u)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(mt(this.year,4)),e.push(mt(this.month,2)),e.push(mt(this.day,2)),e.push(mt(this.hour,2)),e.push(mt(this.minute,2)),e.push(mt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(mt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};wa=_n;k.GeneralizedTime=wa;_n.NAME="GeneralizedTime";var xa,Un=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};xa=Un;k.DATE=xa;Un.NAME="DATE";var va,Ln=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};va=Ln;k.TimeOfDay=va;Ln.NAME="TimeOfDay";var Ba,Vn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ba=Vn;k.DateTime=Ba;Vn.NAME="DateTime";var Ea,Hn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ea=Hn;k.Duration=Ea;Hn.NAME="Duration";var Aa,Dn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Aa=Dn;k.TIME=Aa;Dn.NAME="TIME";function Zu(r){let{result:t}=sr(r),e=t.valueBlock.value;return{n:st(Dt(e[1].toBigInt()),"base64url"),e:st(Dt(e[2].toBigInt()),"base64url"),d:st(Dt(e[3].toBigInt()),"base64url"),p:st(Dt(e[4].toBigInt()),"base64url"),q:st(Dt(e[5].toBigInt()),"base64url"),dp:st(Dt(e[6].toBigInt()),"base64url"),dq:st(Dt(e[7].toBigInt()),"base64url"),qi:st(Dt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Yu(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ct({value:[new ot({value:0}),ot.fromBigInt(Ot(Z(r.n,"base64url"))),ot.fromBigInt(Ot(Z(r.e,"base64url"))),ot.fromBigInt(Ot(Z(r.d,"base64url"))),ot.fromBigInt(Ot(Z(r.p,"base64url"))),ot.fromBigInt(Ot(Z(r.q,"base64url"))),ot.fromBigInt(Ot(Z(r.dp,"base64url"))),ot.fromBigInt(Ot(Z(r.dq,"base64url"))),ot.fromBigInt(Ot(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Wu(r){let{result:t}=sr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:st(Dt(e[0].toBigInt()),"base64url"),e:st(Dt(e[1].toBigInt()),"base64url")}}function Ju(r){if(r.n==null||r.e==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ct({value:[new ct({value:[new _t({value:"1.2.840.113549.1.1.1"}),new ye]}),new rr({valueHex:new ct({value:[ot.fromBigInt(Ot(Z(r.n,"base64url"))),ot.fromBigInt(Ot(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Dt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Ot(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Xu=16,Js=32,Xs=1e4;async function Qu(r,t){let e=z.get(),s=new ct({value:[new ot({value:0}),new ct({value:[new _t({value:"1.2.840.113549.1.1.1"}),new ye]}),new Qt({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Wt(Xu),a=await Gs(ue,t,i,{c:Xs,dkLen:Js}),c=Wt(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new ct({value:[new Qt({valueHex:i}),new ot({value:Xs}),new ot({value:Js}),new ct({value:[new _t({value:"1.2.840.113549.2.11"}),new ye]})]}),d=new ct({value:[new _t({value:"1.2.840.113549.1.5.13"}),new ct({value:[new ct({value:[new _t({value:"1.2.840.113549.1.5.12"}),f]}),new ct({value:[new _t({value:"2.16.840.1.101.3.4.1.42"}),new Qt({valueHex:c})]})]})]}),p=new ct({value:[d,new Qt({valueHex:l})]}).toBER(),h=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...st(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function Qs(r,t){let e=z.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=sr(s),{iv:i,salt:a,iterations:c,keySize:u,cipherText:l}=tf(o),f=await Gs(ue,t,a,{c,dkLen:u}),d=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),w=Ar(await e.subtle.decrypt({name:"AES-CBC",iv:i},d,l)),{result:p}=sr(w);n=ka(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=sr(s);n=ka(o)}else throw new _("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return to(n)}function tf(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new _("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new _("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Ar(o.valueBlock.value[0].getValue()),a=Xs,c=Js;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new _("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=t.valueBlock.value[1].valueBlock.value[1],l=u.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new _("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=Ar(u.valueBlock.value[1].getValue());return{cipherText:Ar(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function ka(r){return Ar(r.valueBlock.value[2].getValue())}function Ar(r){return new Uint8Array(r,0,r.byteLength)}async function Sa(r){let t=await z.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Ra(t);return{privateKey:e[0],publicKey:e[1]}}async function eo(r){let e=[await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await ef(r)],n=await Ra({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ia(r,t){let e=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await z.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Na(r,t,e){let n=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return z.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ra(r){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([z.get().subtle.exportKey("jwk",r.privateKey),z.get().subtle.exportKey("jwk",r.publicKey)])}async function ef(r){return z.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Pn(r){if(r.kty!=="RSA")throw new _("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new _("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Z(r.n,"base64url").length*8}var Ve=8192,Le=class{_key;constructor(t){this._key=t}verify(t,e){return Na(this._key,e,t)}marshal(){return me.jwkToPkix(this._key)}get bytes(){return Tt.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}},be=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Wt(16)}sign(t){return Ia(this._key,t)}get public(){if(this._publicKey==null)throw new _("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Le(this._publicKey)}marshal(){return me.jwkToPkcs1(this._key)}get bytes(){return Ct.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return me.exportToPem(this,t);if(e==="libp2p-key")return Je(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function to(r){let t=me.pkcs1ToJwk(r);if(Pn(t)>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await eo(t);return new be(e.privateKey,e.publicKey)}function nf(r){let t=me.pkixToJwk(r);if(Pn(t)>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Le(t)}async function sf(r){if(Pn(r)>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await eo(r);return new be(t.privateKey,t.publicKey)}async function of(r){if(r>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Sa(r);return new be(t.privateKey,t.publicKey)}var ao={};et(ao,{Secp256k1PrivateKey:()=>Oe,Secp256k1PublicKey:()=>De,generateKeyPair:()=>vf,unmarshalSecp256k1PrivateKey:()=>wf,unmarshalSecp256k1PublicKey:()=>xf});var af=(r,t,e)=>r&t^~r&e,cf=(r,t,e)=>r&t^r&e^t&e,lf=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),xe=new Uint32Array(64),no=class extends ae{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)xe[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=xe[f-15],w=xe[f-2],p=St(d,7)^St(d,18)^d>>>3,h=St(w,17)^St(w,19)^w>>>10;xe[f]=h+xe[f-7]+p+xe[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let d=St(a,6)^St(a,11)^St(a,25),w=l+d+af(a,c,u)+lf[f]+xe[f]|0,h=(St(n,2)^St(n,13)^St(n,22))+cf(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){xe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Kn=ze(()=>new no);function uf(r){let t=fr(r);Vt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:ff,hexToBytes:hf}=Hr,He={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=He;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:ff(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=He,e=typeof r=="string"?hf(r):r;if(!It(e))throw new Error("ui8a expected");let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=He._parseInt(e.subarray(2)),{d:i,l:a}=He._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let l=u.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},ne=BigInt(0),At=BigInt(1),ng=BigInt(2),Ta=BigInt(3),sg=BigInt(4);function df(r){let t=uf(r),{Fp:e}=t,n=t.toBytes||((p,h,g)=>{let m=h.toAffine();return Gt(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(p=>{let h=p.subarray(1),g=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:g,y:m}});function o(p){let{a:h,b:g}=t,m=e.sqr(p),v=e.mul(m,p);return e.add(e.add(v,e.mul(p,h)),g)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&ne<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:g,wrapPrivateKey:m,n:v}=t;if(h&&typeof p!="bigint"){if(It(p)&&(p=qt(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(g*2,"0")}let b;try{b=typeof p=="bigint"?p:jt(Q("private key",p,g))}catch{throw new Error(`private key must be ${g} bytes, hex or bigint, not ${typeof p}`)}return m&&(b=j(b,v)),a(b),b}let u=new Map;function l(p){if(!(p instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,g,m){if(this.px=h,this.py=g,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(g==null||!e.isValid(g))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:g,y:m}=h||{};if(!h||!e.isValid(g)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let v=b=>e.eql(b,e.ZERO);return v(g)&&v(m)?f.ZERO:new f(g,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let g=e.invertBatch(h.map(m=>m.pz));return h.map((m,v)=>m.toAffine(g[v])).map(f.fromAffine)}static fromHex(h){let g=f.fromAffine(s(Q("pointHex",h)));return g.assertValidity(),g}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:g}=this.toAffine();if(!e.isValid(h)||!e.isValid(g))throw new Error("bad point: x or y not FE");let m=e.sqr(g),v=o(h);if(!e.eql(m,v))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:g,py:m,pz:v}=this,{px:b,py:T,pz:x}=h,A=e.eql(e.mul(g,x),e.mul(b,v)),N=e.eql(e.mul(m,x),e.mul(T,v));return A&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:g}=t,m=e.mul(g,Ta),{px:v,py:b,pz:T}=this,x=e.ZERO,A=e.ZERO,N=e.ZERO,R=e.mul(v,v),$=e.mul(b,b),M=e.mul(T,T),V=e.mul(v,b);return V=e.add(V,V),N=e.mul(v,T),N=e.add(N,N),x=e.mul(h,N),A=e.mul(m,M),A=e.add(x,A),x=e.sub($,A),A=e.add($,A),A=e.mul(x,A),x=e.mul(V,x),N=e.mul(m,N),M=e.mul(h,M),V=e.sub(R,M),V=e.mul(h,V),V=e.add(V,N),N=e.add(R,R),R=e.add(N,R),R=e.add(R,M),R=e.mul(R,V),A=e.add(A,R),M=e.mul(b,T),M=e.add(M,M),R=e.mul(M,V),x=e.sub(x,R),N=e.mul(M,$),N=e.add(N,N),N=e.add(N,N),new f(x,A,N)}add(h){l(h);let{px:g,py:m,pz:v}=this,{px:b,py:T,pz:x}=h,A=e.ZERO,N=e.ZERO,R=e.ZERO,$=t.a,M=e.mul(t.b,Ta),V=e.mul(g,b),rt=e.mul(m,T),tt=e.mul(v,x),xt=e.add(g,m),B=e.add(b,T);xt=e.mul(xt,B),B=e.add(V,rt),xt=e.sub(xt,B),B=e.add(g,v);let I=e.add(b,x);return B=e.mul(B,I),I=e.add(V,tt),B=e.sub(B,I),I=e.add(m,v),A=e.add(T,x),I=e.mul(I,A),A=e.add(rt,tt),I=e.sub(I,A),R=e.mul($,B),A=e.mul(M,tt),R=e.add(A,R),A=e.sub(rt,R),R=e.add(rt,R),N=e.mul(A,R),rt=e.add(V,V),rt=e.add(rt,V),tt=e.mul($,tt),B=e.mul(M,B),rt=e.add(rt,tt),tt=e.sub(V,tt),tt=e.mul($,tt),B=e.add(B,tt),V=e.mul(rt,B),N=e.add(N,V),V=e.mul(I,B),A=e.mul(xt,A),A=e.sub(A,V),V=e.mul(xt,rt),R=e.mul(I,R),R=e.add(R,V),new f(A,N,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return w.wNAFCached(this,u,h,g=>{let m=e.invertBatch(g.map(v=>v.pz));return g.map((v,b)=>v.toAffine(m[b])).map(f.fromAffine)})}multiplyUnsafe(h){let g=f.ZERO;if(h===ne)return g;if(a(h),h===At)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:v,k1:b,k2neg:T,k2:x}=m.splitScalar(h),A=g,N=g,R=this;for(;b>ne||x>ne;)b&At&&(A=A.add(R)),x&At&&(N=N.add(R)),R=R.double(),b>>=At,x>>=At;return v&&(A=A.negate()),T&&(N=N.negate()),N=new f(e.mul(N.px,m.beta),N.py,N.pz),A.add(N)}multiply(h){a(h);let g=h,m,v,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:A,k2:N}=b.splitScalar(g),{p:R,f:$}=this.wNAF(x),{p:M,f:V}=this.wNAF(N);R=w.constTimeNegate(T,R),M=w.constTimeNegate(A,M),M=new f(e.mul(M.px,b.beta),M.py,M.pz),m=R.add(M),v=$.add(V)}else{let{p:T,f:x}=this.wNAF(g);m=T,v=x}return f.normalizeZ([m,v])[0]}multiplyAndAddUnsafe(h,g,m){let v=f.BASE,b=(x,A)=>A===ne||A===At||!x.equals(v)?x.multiplyUnsafe(A):x.multiply(A),T=b(this,g).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:g,py:m,pz:v}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(v));let T=e.mul(g,h),x=e.mul(m,h),A=e.mul(v,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(A,e.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:g}=t;if(h===At)return!0;if(g)return g(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:g}=t;return h===At?this:g?g(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return qt(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let d=t.nBitLength,w=Pr(f,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function pf(r){let t=fr(r);return Vt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ca(r){let t=pf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return ne<B&&B<e.ORDER}function a(B){return j(B,n)}function c(B){return Dr(B,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:d}=df({...t,toBytes(B,I,H){let E=I.toAffine(),y=e.toBytes(E.x),S=Gt;return H?S(Uint8Array.from([I.hasEvenY()?2:3]),y):S(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(B){let I=B.length,H=B[0],E=B.subarray(1);if(I===s&&(H===2||H===3)){let y=jt(E);if(!i(y))throw new Error("Point is not on curve");let S=f(y),C=e.sqrt(S),U=(C&At)===At;return(H&1)===1!==U&&(C=e.neg(C)),{x:y,y:C}}else if(I===o&&H===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),S=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:S}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),w=B=>qt(he(B,t.nByteLength));function p(B){let I=n>>At;return B>I}function h(B){return p(B)?a(-B):B}let g=(B,I,H)=>jt(B.slice(I,H));class m{constructor(I,H,E){this.r=I,this.s=H,this.recovery=E,this.assertValidity()}static fromCompact(I){let H=t.nByteLength;return I=Q("compactSignature",I,H*2),new m(g(I,0,H),g(I,H,2*H))}static fromDER(I){let{r:H,s:E}=He.toSig(Q("DER",I));return new m(H,E)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new m(this.r,this.s,I)}recoverPublicKey(I){let{r:H,s:E,recovery:y}=this,S=N(Q("msgHash",I));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?H+t.n:H;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=y&1?"03":"02",D=u.fromHex(U+w(C)),O=c(C),q=a(-S*O),K=a(E*O),F=u.BASE.multiplyAndAddUnsafe(D,q,K);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return He.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let v={isValidPrivateKey(B){try{return l(B),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let B=As(t.n);return ci(t.randomBytes(B),t.n)},precompute(B=8,I=u.BASE){return I._setWindowSize(B),I.multiply(BigInt(3)),I}};function b(B,I=!0){return u.fromPrivateKey(B).toRawBytes(I)}function T(B){let I=It(B),H=typeof B=="string",E=(I||H)&&B.length;return I?E===s||E===o:H?E===2*s||E===2*o:B instanceof u}function x(B,I,H=!0){if(T(B))throw new Error("first arg must be private key");if(!T(I))throw new Error("second arg must be public key");return u.fromHex(I).multiply(l(B)).toRawBytes(H)}let A=t.bits2int||function(B){let I=jt(B),H=B.length*8-t.nBitLength;return H>0?I>>BigInt(H):I},N=t.bits2int_modN||function(B){return a(A(B))},R=ur(t.nBitLength);function $(B){if(typeof B!="bigint")throw new Error("bigint expected");if(!(ne<=B&&B<R))throw new Error(`bigint expected < 2^${t.nBitLength}`);return he(B,t.nByteLength)}function M(B,I,H=V){if(["recovered","canonical"].some(J=>J in H))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:S,prehash:C,extraEntropy:U}=H;S==null&&(S=!0),B=Q("msgHash",B),C&&(B=Q("prehashed msgHash",E(B)));let D=N(B),O=l(I),q=[$(O),$(D)];if(U!=null){let J=U===!0?y(e.BYTES):U;q.push(Q("extraEntropy",J))}let K=Gt(...q),F=D;function nt(J){let lt=A(J);if(!d(lt))return;let ut=c(lt),it=u.BASE.multiply(lt).toAffine(),ht=a(it.x);if(ht===ne)return;let Pt=a(ut*a(F+ht*O));if(Pt===ne)return;let Be=(it.x===ht?0:2)|Number(it.y&At),or=Pt;return S&&p(Pt)&&(or=h(Pt),Be^=1),new m(ht,or,Be)}return{seed:K,k2sig:nt}}let V={lowS:t.lowS,prehash:!1},rt={lowS:t.lowS,prehash:!1};function tt(B,I,H=V){let{seed:E,k2sig:y}=M(B,I,H),S=t;return xs(S.hash.outputLen,S.nByteLength,S.hmac)(E,y)}u.BASE._setWindowSize(8);function xt(B,I,H,E=rt){let y=B;if(I=Q("msgHash",I),H=Q("publicKey",H),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:S,prehash:C}=E,U,D;try{if(typeof y=="string"||It(y))try{U=m.fromDER(y)}catch(it){if(!(it instanceof He.Err))throw it;U=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:it,s:ht}=y;U=new m(it,ht)}else throw new Error("PARSE");D=u.fromHex(H)}catch(it){if(it.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(S&&U.hasHighS())return!1;C&&(I=t.hash(I));let{r:O,s:q}=U,K=N(I),F=c(q),nt=a(K*F),J=a(O*F),lt=u.BASE.multiplyAndAddUnsafe(D,nt,J)?.toAffine();return lt?a(lt.x)===O:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:x,sign:tt,verify:xt,ProjectivePoint:u,Signature:m,utils:v}}function gf(r){return{hash:r,hmac:(t,...e)=>gr(r,t,Ur(...e)),randomBytes:Ze}}function _a(r,t){let e=n=>Ca({...r,...gf(n)});return Object.freeze({...e(t),create:e})}var Va=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ua=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),yf=BigInt(1),so=BigInt(2),La=(r,t)=>(r+t/so)/t;function mf(r){let t=Va,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=W(l,e,t)*l%t,d=W(f,e,t)*l%t,w=W(d,so,t)*u%t,p=W(w,s,t)*w%t,h=W(p,o,t)*p%t,g=W(h,a,t)*h%t,m=W(g,c,t)*g%t,v=W(m,a,t)*h%t,b=W(v,e,t)*l%t,T=W(b,i,t)*p%t,x=W(T,n,t)*u%t,A=W(x,so,t);if(!oo.eql(oo.sqr(A),r))throw new Error("Cannot find square root");return A}var oo=Or(Va,void 0,void 0,{sqrt:mf}),Lt=_a({a:BigInt(0),b:BigInt(7),Fp:oo,n:Ua,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ua,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-yf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=La(o*r,t),c=La(-n*r,t),u=j(r-a*e-c*s,t),l=j(-a*n-c*o,t),f=u>i,d=l>i;if(f&&(u=t-u),d&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:d,k2:l}}}},Kn),dg=BigInt(0);var pg=Lt.ProjectivePoint;function Ha(){return Lt.utils.randomPrivateKey()}function Da(r,t){let e=bt.digest(t instanceof Uint8Array?t:t.subarray());if(Bt(e))return e.then(({digest:n})=>Lt.sign(n,r).toDERRawBytes()).catch(n=>{throw new _(String(n),"ERR_INVALID_INPUT")});try{return Lt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new _(String(n),"ERR_INVALID_INPUT")}}function Oa(r,t,e){let n=bt.digest(e instanceof Uint8Array?e:e.subarray());if(Bt(n))return n.then(({digest:s})=>Lt.verify(t,s,r)).catch(s=>{throw new _(String(s),"ERR_INVALID_INPUT")});try{return Lt.verify(t,n.digest,r)}catch(s){throw new _(String(s),"ERR_INVALID_INPUT")}}function Pa(r){return Lt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ka(r){try{Lt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}function io(r){try{Lt.ProjectivePoint.fromHex(r)}catch(t){throw new _(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Ma(r){try{return Lt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}var De=class{_key;constructor(t){io(t),this._key=t}verify(t,e){return Oa(this._key,e,t)}marshal(){return Pa(this._key)}get bytes(){return Tt.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Bt(t)?{bytes:e}=await t:e=t.bytes,e}},Oe=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Ma(t),Ka(this._key),io(this._publicKey)}sign(t){return Da(this._key,t)}get public(){return new De(this._publicKey)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Je(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function wf(r){return new Oe(r)}function xf(r){return new De(r)}async function vf(){let r=Ha();return new Oe(r)}var se={rsa:ro,ed25519:qs,secp256k1:ao};function co(r){let t=Object.keys(se).join(" / ");return new _(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function lo(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return se[r];throw co(r)}async function Bf(r,t){return lo(r).generateKeyPair(t??2048)}async function Ef(r,t,e){if(r.toLowerCase()!=="ed25519")throw new _("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return $s(t)}function Af(r){let t=Tt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return se.rsa.unmarshalRsaPublicKey(e);case G.Ed25519:return se.ed25519.unmarshalEd25519PublicKey(e);case G.Secp256k1:return se.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw co(t.Type??"unknown")}}function kf(r,t){return t=(t??"rsa").toLowerCase(),lo(t),r.bytes}async function Fa(r){let t=Ct.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return se.rsa.unmarshalRsaPrivateKey(e);case G.Ed25519:return se.ed25519.unmarshalEd25519PrivateKey(e);case G.Secp256k1:return se.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw co(t.Type??"RSA")}}function Sf(r,t){return t=(t??"rsa").toLowerCase(),lo(t),r.bytes}async function If(r,t){try{let e=await _i(r,t);return await Fa(e)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return Qs(r,t)}var fo=(r,t)=>r<<t|r>>>32-t>>>0,Nf=(r,t,e)=>r&t^~r&e,Rf=(r,t,e)=>r&t^r&e^t&e,kr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),ve=new Uint32Array(80),ho=class extends ae{constructor(){super(64,20,8,!1),this.A=kr[0]|0,this.B=kr[1]|0,this.C=kr[2]|0,this.D=kr[3]|0,this.E=kr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)ve[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)ve[c]=fo(ve[c-3]^ve[c-8]^ve[c-14]^ve[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let u,l;c<20?(u=Nf(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Rf(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=fo(n,5)+u+a+l+ve[c]|0;a=i,i=o,o=fo(s,30),s=n,n=f}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){ve.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},$a=ze(()=>new ho);var qa={sha1:$a,"sha2-256":Kn,"sha2-512":ue};function po(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(qa).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let o=qa[s],i=Di(o,r,t,{c:e,dkLen:n});return ke.encode(i).substring(1)}return ic(Tf);})();
6
+ `)}`:`${e} :`}};qi=pe;k.Constructed=qi;pe.NAME="CONSTRUCTED";var on=class extends gt{fromBER(t,e,n){return e}toBER(t){return Ut}};on.override="EndOfContentValueBlock";var ji,an=class extends ft{constructor(t={}){super(t,on),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ji=an;k.EndOfContent=ji;an.NAME=br;var Gi,ye=class extends ft{constructor(t={}){super(t,gt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Gi=ye;k.Null=Gi;ye.NAME="NULL";var cn=class extends re(gt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return ee(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,zs.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};cn.NAME="BooleanValueBlock";var zi,ln=class extends ft{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};zi=ln;k.Boolean=zi;ln.NAME="BOOLEAN";var un=class extends re(Ht){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Ht.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===br){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Ki)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Ht.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};un.NAME="OctetStringValueBlock";var Zi,Qt=class r extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},un),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=On(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?pe.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};Zi=Qt;k.OctetString=Zi;Qt.NAME=Ki;var fn=class extends re(Ht){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Ht.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===br){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Mi)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return s}let o=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=On(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Ht.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};fn.NAME="BitStringValueBlock";var Yi,rr=class extends ft{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return pe.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Yi=rr;k.BitString=Yi;rr.NAME=Mi;var Wi;function Fu(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let d=l;d>=0;d--,f++){switch(!0){case f<a.length:u=o[i-f]+a[c-f]+e[0];break;default:u=o[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=o.length:o=Xr(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=Xr(e,o)),o}function Pi(r){if(r>=yr.length)for(let t=yr.length;t<=r;t++){let e=new Uint8Array([0]),n=yr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Xr(e,n)),yr.push(n)}return yr[r]}function $u(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=o[i-l]-a[c-l]-e,!0){case u<0:e=1,o[i-l]=u+10;break;default:e=0,o[i-l]=u}if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=o[i-l]-e,u<0)e=1,o[i-l]=u+10;else{e=0,o[i-l]=u;break}return o.slice()}var wr=class extends re(gt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=zs.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Hi(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let u=0;u<8;u++){if((s&1)===1)switch(n){case t:e=$u(Pi(n),e),i="-";break;default:e=Fu(e,Pi(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Oi.charAt(e[c]));return a===!1&&(i+=Oi.charAt(0)),i}};Wi=wr;wr.NAME="IntegerValueBlock";Object.defineProperty(Wi.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Ji,ot=class r extends ft{constructor(t={}){super(t,wr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Qr(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Qr();let e=BigInt(t),n=new mr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Ji=ot;k.Integer=Ji;ot.NAME="INTEGER";var Xi,hn=class extends ot{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Xi=hn;k.Enumerated=Xi;hn.NAME="ENUMERATED";var xr=class extends re(gt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Qr();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=P.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};xr.NAME="sidBlock";var dn=class extends gt{constructor({value:t=nr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new xr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Ut;e.push(s)}return Zs(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new xr;if(s>Number.MAX_SAFE_INTEGER){Qr();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};dn.NAME="ObjectIdentifierValueBlock";var Qi,_t=class extends ft{constructor(t={}){super(t,dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Qi=_t;k.ObjectIdentifier=Qi;_t.NAME="OBJECT IDENTIFIER";var vr=class extends re(Xt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ee(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Ue(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ge(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ut;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};vr.NAME="relativeSidBlock";var gn=class extends gt{constructor({value:t=nr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new vr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Ut;n.push(o)}return Zs(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new vr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};gn.NAME="RelativeObjectIdentifierValueBlock";var ta,pn=class extends ft{constructor(t={}){super(t,gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ta=pn;k.RelativeObjectIdentifier=ta;pn.NAME="RelativeObjectIdentifier";var ea,ct=class extends pe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ea=ct;k.Sequence=ea;ct.NAME="SEQUENCE";var ra,yn=class extends pe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ra=yn;k.Set=ra;yn.NAME="SET";var mn=class extends re(gt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=nr}toJSON(){return{...super.toJSON(),value:this.value}}};mn.NAME="StringValueBlock";var bn=class extends mn{};bn.NAME="SimpleStringValueBlock";var pt=class extends rn{constructor({...t}={}){super(t,bn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};pt.NAME="SIMPLE STRING";var wn=class extends pt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};wn.NAME="Utf8StringValueBlock";var na,te=class extends wn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};na=te;k.Utf8String=na;te.NAME="UTF8String";var xn=class extends pt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};xn.NAME="BmpStringValueBlock";var sa,vn=class extends xn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};sa=vn;k.BmpString=sa;vn.NAME="BMPString";var Bn=class extends pt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ge(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};Bn.NAME="UniversalStringValueBlock";var oa,En=class extends Bn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};oa=En;k.UniversalString=oa;En.NAME="UniversalString";var ia,An=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ia=An;k.NumericString=ia;An.NAME="NumericString";var aa,kn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};aa=kn;k.PrintableString=aa;kn.NAME="PrintableString";var ca,Sn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ca=Sn;k.TeletexString=ca;Sn.NAME="TeletexString";var la,In=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};la=In;k.VideotexString=la;In.NAME="VideotexString";var ua,Nn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ua=Nn;k.IA5String=ua;Nn.NAME="IA5String";var fa,Rn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};fa=Rn;k.GraphicString=fa;Rn.NAME="GraphicString";var ha,Br=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ha=Br;k.VisibleString=ha;Br.NAME="VisibleString";var da,Tn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};da=Tn;k.GeneralString=da;Tn.NAME="GeneralString";var ga,Cn=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};ga=Cn;k.CharacterString=ga;Cn.NAME="CharacterString";var pa,Er=class extends Br{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=mt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=mt(this.month,2),e[2]=mt(this.day,2),e[3]=mt(this.hour,2),e[4]=mt(this.minute,2),e[5]=mt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};pa=Er;k.UTCTime=pa;Er.NAME="UTCTime";var ya,_n=class extends Er{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,d=n.indexOf("+"),w="";if(d===-1&&(d=n.indexOf("-"),f=-1),d!==-1){if(w=n.substring(d+1),n=n.substring(0,d),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(w.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*g,w.length===4){if(g=parseInt(w.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=f*g}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,u)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(mt(this.year,4)),e.push(mt(this.month,2)),e.push(mt(this.day,2)),e.push(mt(this.hour,2)),e.push(mt(this.minute,2)),e.push(mt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(mt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ya=_n;k.GeneralizedTime=ya;_n.NAME="GeneralizedTime";var ma,Un=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ma=Un;k.DATE=ma;Un.NAME="DATE";var ba,Ln=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};ba=Ln;k.TimeOfDay=ba;Ln.NAME="TimeOfDay";var wa,Vn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};wa=Vn;k.DateTime=wa;Vn.NAME="DateTime";var xa,Hn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};xa=Hn;k.Duration=xa;Hn.NAME="Duration";var va,Dn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};va=Dn;k.TIME=va;Dn.NAME="TIME";function ju(r){let{result:t}=sr(r),e=t.valueBlock.value;return{n:st(Dt(e[1].toBigInt()),"base64url"),e:st(Dt(e[2].toBigInt()),"base64url"),d:st(Dt(e[3].toBigInt()),"base64url"),p:st(Dt(e[4].toBigInt()),"base64url"),q:st(Dt(e[5].toBigInt()),"base64url"),dp:st(Dt(e[6].toBigInt()),"base64url"),dq:st(Dt(e[7].toBigInt()),"base64url"),qi:st(Dt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Gu(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ct({value:[new ot({value:0}),ot.fromBigInt(Ot(Z(r.n,"base64url"))),ot.fromBigInt(Ot(Z(r.e,"base64url"))),ot.fromBigInt(Ot(Z(r.d,"base64url"))),ot.fromBigInt(Ot(Z(r.p,"base64url"))),ot.fromBigInt(Ot(Z(r.q,"base64url"))),ot.fromBigInt(Ot(Z(r.dp,"base64url"))),ot.fromBigInt(Ot(Z(r.dq,"base64url"))),ot.fromBigInt(Ot(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function zu(r){let{result:t}=sr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:st(Dt(e[0].toBigInt()),"base64url"),e:st(Dt(e[1].toBigInt()),"base64url")}}function Zu(r){if(r.n==null||r.e==null)throw new _("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new ct({value:[new ct({value:[new _t({value:"1.2.840.113549.1.1.1"}),new ye]}),new rr({valueHex:new ct({value:[ot.fromBigInt(Ot(Z(r.n,"base64url"))),ot.fromBigInt(Ot(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Dt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Ot(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Yu=16,Ws=32,Js=1e4;async function Wu(r,t){let e=z.get(),s=new ct({value:[new ot({value:0}),new ct({value:[new _t({value:"1.2.840.113549.1.1.1"}),new ye]}),new Qt({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Wt(Yu),a=await js(ue,t,i,{c:Js,dkLen:Ws}),c=Wt(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,o),f=new ct({value:[new Qt({valueHex:i}),new ot({value:Js}),new ot({value:Ws}),new ct({value:[new _t({value:"1.2.840.113549.2.11"}),new ye]})]}),d=new ct({value:[new _t({value:"1.2.840.113549.1.5.13"}),new ct({value:[new ct({value:[new _t({value:"1.2.840.113549.1.5.12"}),f]}),new ct({value:[new _t({value:"2.16.840.1.101.3.4.1.42"}),new Qt({valueHex:c})]})]})]}),g=new ct({value:[d,new Qt({valueHex:l})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...st(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function Xs(r,t){let e=z.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=sr(s),{iv:i,salt:a,iterations:c,keySize:u,cipherText:l}=Ju(o),f=await js(ue,t,a,{c,dkLen:u}),d=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),w=Ar(await e.subtle.decrypt({name:"AES-CBC",iv:i},d,l)),{result:g}=sr(w);n=Ba(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=sr(s);n=Ba(o)}else throw new _("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Qs(n)}function Ju(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new _("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new _("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=Ar(o.valueBlock.value[0].getValue()),a=Js,c=Ws;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new _("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=t.valueBlock.value[1].valueBlock.value[1],l=u.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new _("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=Ar(u.valueBlock.value[1].getValue());return{cipherText:Ar(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Ba(r){return Ar(r.valueBlock.value[2].getValue())}function Ar(r){return new Uint8Array(r,0,r.byteLength)}async function Ea(r){let t=await z.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Sa(t);return{privateKey:e[0],publicKey:e[1]}}async function to(r){let e=[await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Xu(r)],n=await Sa({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Aa(r,t){let e=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await z.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function ka(r,t,e){let n=await z.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return z.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Sa(r){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([z.get().subtle.exportKey("jwk",r.privateKey),z.get().subtle.exportKey("jwk",r.publicKey)])}async function Xu(r){return z.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Pn(r){if(r.kty!=="RSA")throw new _("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new _("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Z(r.n,"base64url").length*8}var Ve=8192,Le=class{_key;constructor(t){this._key=t}verify(t,e){return ka(this._key,e,t)}marshal(){return me.jwkToPkix(this._key)}get bytes(){return Tt.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}},be=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Wt(16)}sign(t){return Aa(this._key,t)}get public(){if(this._publicKey==null)throw new _("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Le(this._publicKey)}marshal(){return me.jwkToPkcs1(this._key)}get bytes(){return Ct.encode({Type:G.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return me.exportToPem(this,t);if(e==="libp2p-key")return Je(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Qs(r){let t=me.pkcs1ToJwk(r);if(Pn(t)>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await to(t);return new be(e.privateKey,e.publicKey)}function tf(r){let t=me.pkixToJwk(r);if(Pn(t)>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Le(t)}async function ef(r){if(Pn(r)>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await to(r);return new be(t.privateKey,t.publicKey)}async function rf(r){if(r>Ve)throw new _("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ea(r);return new be(t.privateKey,t.publicKey)}var io={};et(io,{Secp256k1PrivateKey:()=>Oe,Secp256k1PublicKey:()=>De,generateKeyPair:()=>bf,unmarshalSecp256k1PrivateKey:()=>yf,unmarshalSecp256k1PublicKey:()=>mf});var nf=(r,t,e)=>r&t^~r&e,sf=(r,t,e)=>r&t^r&e^t&e,of=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),xe=new Uint32Array(64),ro=class extends ae{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)xe[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=xe[f-15],w=xe[f-2],g=St(d,7)^St(d,18)^d>>>3,h=St(w,17)^St(w,19)^w>>>10;xe[f]=h+xe[f-7]+g+xe[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let d=St(a,6)^St(a,11)^St(a,25),w=l+d+nf(a,c,u)+of[f]+xe[f]|0,h=(St(n,2)^St(n,13)^St(n,22))+sf(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){xe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Kn=ze(()=>new ro);function af(r){let t=fr(r);Vt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:cf,hexToBytes:lf}=Hr,He={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=He;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:cf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=He,e=typeof r=="string"?lf(r):r;if(!It(e))throw new Error("ui8a expected");let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=He._parseInt(e.subarray(2)),{d:i,l:a}=He._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let l=u.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},ne=BigInt(0),At=BigInt(1),lg=BigInt(2),Ia=BigInt(3),ug=BigInt(4);function uf(r){let t=af(r),{Fp:e}=t,n=t.toBytes||((g,h,p)=>{let m=h.toAffine();return Gt(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),p=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:p,y:m}});function o(g){let{a:h,b:p}=t,m=e.sqr(g),v=e.mul(m,g);return e.add(e.add(v,e.mul(g,h)),p)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return typeof g=="bigint"&&ne<g&&g<t.n}function a(g){if(!i(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:p,wrapPrivateKey:m,n:v}=t;if(h&&typeof g!="bigint"){if(It(g)&&(g=qt(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(p*2,"0")}let b;try{b=typeof g=="bigint"?g:jt(Q("private key",g,p))}catch{throw new Error(`private key must be ${p} bytes, hex or bigint, not ${typeof g}`)}return m&&(b=j(b,v)),a(b),b}let u=new Map;function l(g){if(!(g instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,p,m){if(this.px=h,this.py=p,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(p==null||!e.isValid(p))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:p,y:m}=h||{};if(!h||!e.isValid(p)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let v=b=>e.eql(b,e.ZERO);return v(p)&&v(m)?f.ZERO:new f(p,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let p=e.invertBatch(h.map(m=>m.pz));return h.map((m,v)=>m.toAffine(p[v])).map(f.fromAffine)}static fromHex(h){let p=f.fromAffine(s(Q("pointHex",h)));return p.assertValidity(),p}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:p}=this.toAffine();if(!e.isValid(h)||!e.isValid(p))throw new Error("bad point: x or y not FE");let m=e.sqr(p),v=o(h);if(!e.eql(m,v))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:p,py:m,pz:v}=this,{px:b,py:T,pz:x}=h,A=e.eql(e.mul(p,x),e.mul(b,v)),N=e.eql(e.mul(m,x),e.mul(T,v));return A&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:p}=t,m=e.mul(p,Ia),{px:v,py:b,pz:T}=this,x=e.ZERO,A=e.ZERO,N=e.ZERO,R=e.mul(v,v),$=e.mul(b,b),M=e.mul(T,T),V=e.mul(v,b);return V=e.add(V,V),N=e.mul(v,T),N=e.add(N,N),x=e.mul(h,N),A=e.mul(m,M),A=e.add(x,A),x=e.sub($,A),A=e.add($,A),A=e.mul(x,A),x=e.mul(V,x),N=e.mul(m,N),M=e.mul(h,M),V=e.sub(R,M),V=e.mul(h,V),V=e.add(V,N),N=e.add(R,R),R=e.add(N,R),R=e.add(R,M),R=e.mul(R,V),A=e.add(A,R),M=e.mul(b,T),M=e.add(M,M),R=e.mul(M,V),x=e.sub(x,R),N=e.mul(M,$),N=e.add(N,N),N=e.add(N,N),new f(x,A,N)}add(h){l(h);let{px:p,py:m,pz:v}=this,{px:b,py:T,pz:x}=h,A=e.ZERO,N=e.ZERO,R=e.ZERO,$=t.a,M=e.mul(t.b,Ia),V=e.mul(p,b),rt=e.mul(m,T),tt=e.mul(v,x),xt=e.add(p,m),B=e.add(b,T);xt=e.mul(xt,B),B=e.add(V,rt),xt=e.sub(xt,B),B=e.add(p,v);let I=e.add(b,x);return B=e.mul(B,I),I=e.add(V,tt),B=e.sub(B,I),I=e.add(m,v),A=e.add(T,x),I=e.mul(I,A),A=e.add(rt,tt),I=e.sub(I,A),R=e.mul($,B),A=e.mul(M,tt),R=e.add(A,R),A=e.sub(rt,R),R=e.add(rt,R),N=e.mul(A,R),rt=e.add(V,V),rt=e.add(rt,V),tt=e.mul($,tt),B=e.mul(M,B),rt=e.add(rt,tt),tt=e.sub(V,tt),tt=e.mul($,tt),B=e.add(B,tt),V=e.mul(rt,B),N=e.add(N,V),V=e.mul(I,B),A=e.mul(xt,A),A=e.sub(A,V),V=e.mul(xt,rt),R=e.mul(I,R),R=e.add(R,V),new f(A,N,R)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return w.wNAFCached(this,u,h,p=>{let m=e.invertBatch(p.map(v=>v.pz));return p.map((v,b)=>v.toAffine(m[b])).map(f.fromAffine)})}multiplyUnsafe(h){let p=f.ZERO;if(h===ne)return p;if(a(h),h===At)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:v,k1:b,k2neg:T,k2:x}=m.splitScalar(h),A=p,N=p,R=this;for(;b>ne||x>ne;)b&At&&(A=A.add(R)),x&At&&(N=N.add(R)),R=R.double(),b>>=At,x>>=At;return v&&(A=A.negate()),T&&(N=N.negate()),N=new f(e.mul(N.px,m.beta),N.py,N.pz),A.add(N)}multiply(h){a(h);let p=h,m,v,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:A,k2:N}=b.splitScalar(p),{p:R,f:$}=this.wNAF(x),{p:M,f:V}=this.wNAF(N);R=w.constTimeNegate(T,R),M=w.constTimeNegate(A,M),M=new f(e.mul(M.px,b.beta),M.py,M.pz),m=R.add(M),v=$.add(V)}else{let{p:T,f:x}=this.wNAF(p);m=T,v=x}return f.normalizeZ([m,v])[0]}multiplyAndAddUnsafe(h,p,m){let v=f.BASE,b=(x,A)=>A===ne||A===At||!x.equals(v)?x.multiplyUnsafe(A):x.multiply(A),T=b(this,p).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:p,py:m,pz:v}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(v));let T=e.mul(p,h),x=e.mul(m,h),A=e.mul(v,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(A,e.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:p}=t;if(h===At)return!0;if(p)return p(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:p}=t;return h===At?this:p?p(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return qt(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let d=t.nBitLength,w=Pr(f,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function ff(r){let t=fr(r);return Vt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Na(r){let t=ff(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(B){return ne<B&&B<e.ORDER}function a(B){return j(B,n)}function c(B){return Dr(B,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:d}=uf({...t,toBytes(B,I,H){let E=I.toAffine(),y=e.toBytes(E.x),S=Gt;return H?S(Uint8Array.from([I.hasEvenY()?2:3]),y):S(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(B){let I=B.length,H=B[0],E=B.subarray(1);if(I===s&&(H===2||H===3)){let y=jt(E);if(!i(y))throw new Error("Point is not on curve");let S=f(y),C=e.sqrt(S),U=(C&At)===At;return(H&1)===1!==U&&(C=e.neg(C)),{x:y,y:C}}else if(I===o&&H===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),S=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:S}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),w=B=>qt(he(B,t.nByteLength));function g(B){let I=n>>At;return B>I}function h(B){return g(B)?a(-B):B}let p=(B,I,H)=>jt(B.slice(I,H));class m{constructor(I,H,E){this.r=I,this.s=H,this.recovery=E,this.assertValidity()}static fromCompact(I){let H=t.nByteLength;return I=Q("compactSignature",I,H*2),new m(p(I,0,H),p(I,H,2*H))}static fromDER(I){let{r:H,s:E}=He.toSig(Q("DER",I));return new m(H,E)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new m(this.r,this.s,I)}recoverPublicKey(I){let{r:H,s:E,recovery:y}=this,S=N(Q("msgHash",I));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?H+t.n:H;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=y&1?"03":"02",D=u.fromHex(U+w(C)),O=c(C),q=a(-S*O),K=a(E*O),F=u.BASE.multiplyAndAddUnsafe(D,q,K);if(!F)throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return He.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let v={isValidPrivateKey(B){try{return l(B),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let B=Es(t.n);return oi(t.randomBytes(B),t.n)},precompute(B=8,I=u.BASE){return I._setWindowSize(B),I.multiply(BigInt(3)),I}};function b(B,I=!0){return u.fromPrivateKey(B).toRawBytes(I)}function T(B){let I=It(B),H=typeof B=="string",E=(I||H)&&B.length;return I?E===s||E===o:H?E===2*s||E===2*o:B instanceof u}function x(B,I,H=!0){if(T(B))throw new Error("first arg must be private key");if(!T(I))throw new Error("second arg must be public key");return u.fromHex(I).multiply(l(B)).toRawBytes(H)}let A=t.bits2int||function(B){let I=jt(B),H=B.length*8-t.nBitLength;return H>0?I>>BigInt(H):I},N=t.bits2int_modN||function(B){return a(A(B))},R=ur(t.nBitLength);function $(B){if(typeof B!="bigint")throw new Error("bigint expected");if(!(ne<=B&&B<R))throw new Error(`bigint expected < 2^${t.nBitLength}`);return he(B,t.nByteLength)}function M(B,I,H=V){if(["recovered","canonical"].some(J=>J in H))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:S,prehash:C,extraEntropy:U}=H;S==null&&(S=!0),B=Q("msgHash",B),C&&(B=Q("prehashed msgHash",E(B)));let D=N(B),O=l(I),q=[$(O),$(D)];if(U!=null){let J=U===!0?y(e.BYTES):U;q.push(Q("extraEntropy",J))}let K=Gt(...q),F=D;function nt(J){let lt=A(J);if(!d(lt))return;let ut=c(lt),it=u.BASE.multiply(lt).toAffine(),ht=a(it.x);if(ht===ne)return;let Pt=a(ut*a(F+ht*O));if(Pt===ne)return;let Be=(it.x===ht?0:2)|Number(it.y&At),or=Pt;return S&&g(Pt)&&(or=h(Pt),Be^=1),new m(ht,or,Be)}return{seed:K,k2sig:nt}}let V={lowS:t.lowS,prehash:!1},rt={lowS:t.lowS,prehash:!1};function tt(B,I,H=V){let{seed:E,k2sig:y}=M(B,I,H),S=t;return ws(S.hash.outputLen,S.nByteLength,S.hmac)(E,y)}u.BASE._setWindowSize(8);function xt(B,I,H,E=rt){let y=B;if(I=Q("msgHash",I),H=Q("publicKey",H),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:S,prehash:C}=E,U,D;try{if(typeof y=="string"||It(y))try{U=m.fromDER(y)}catch(it){if(!(it instanceof He.Err))throw it;U=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:it,s:ht}=y;U=new m(it,ht)}else throw new Error("PARSE");D=u.fromHex(H)}catch(it){if(it.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(S&&U.hasHighS())return!1;C&&(I=t.hash(I));let{r:O,s:q}=U,K=N(I),F=c(q),nt=a(K*F),J=a(O*F),lt=u.BASE.multiplyAndAddUnsafe(D,nt,J)?.toAffine();return lt?a(lt.x)===O:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:x,sign:tt,verify:xt,ProjectivePoint:u,Signature:m,utils:v}}function hf(r){return{hash:r,hmac:(t,...e)=>pr(r,t,Ur(...e)),randomBytes:Ze}}function Ra(r,t){let e=n=>Na({...r,...hf(n)});return Object.freeze({...e(t),create:e})}var _a=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ta=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),df=BigInt(1),no=BigInt(2),Ca=(r,t)=>(r+t/no)/t;function gf(r){let t=_a,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=W(l,e,t)*l%t,d=W(f,e,t)*l%t,w=W(d,no,t)*u%t,g=W(w,s,t)*w%t,h=W(g,o,t)*g%t,p=W(h,a,t)*h%t,m=W(p,c,t)*p%t,v=W(m,a,t)*h%t,b=W(v,e,t)*l%t,T=W(b,i,t)*g%t,x=W(T,n,t)*u%t,A=W(x,no,t);if(!so.eql(so.sqr(A),r))throw new Error("Cannot find square root");return A}var so=Or(_a,void 0,void 0,{sqrt:gf}),Lt=Ra({a:BigInt(0),b:BigInt(7),Fp:so,n:Ta,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ta,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-df*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ca(o*r,t),c=Ca(-n*r,t),u=j(r-a*e-c*s,t),l=j(-a*n-c*o,t),f=u>i,d=l>i;if(f&&(u=t-u),d&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:d,k2:l}}}},Kn),wg=BigInt(0);var xg=Lt.ProjectivePoint;function Ua(){return Lt.utils.randomPrivateKey()}function La(r,t){let e=bt.digest(t instanceof Uint8Array?t:t.subarray());if(Bt(e))return e.then(({digest:n})=>Lt.sign(n,r).toDERRawBytes()).catch(n=>{throw new _(String(n),"ERR_INVALID_INPUT")});try{return Lt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new _(String(n),"ERR_INVALID_INPUT")}}function Va(r,t,e){let n=bt.digest(e instanceof Uint8Array?e:e.subarray());if(Bt(n))return n.then(({digest:s})=>Lt.verify(t,s,r)).catch(s=>{throw new _(String(s),"ERR_INVALID_INPUT")});try{return Lt.verify(t,n.digest,r)}catch(s){throw new _(String(s),"ERR_INVALID_INPUT")}}function Ha(r){return Lt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Da(r){try{Lt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}function oo(r){try{Lt.ProjectivePoint.fromHex(r)}catch(t){throw new _(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Oa(r){try{return Lt.getPublicKey(r,!0)}catch(t){throw new _(String(t),"ERR_INVALID_PRIVATE_KEY")}}var De=class{_key;constructor(t){oo(t),this._key=t}verify(t,e){return Va(this._key,e,t)}marshal(){return Ha(this._key)}get bytes(){return Tt.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=bt.digest(this.bytes),e;return Bt(t)?{bytes:e}=await t:e=t.bytes,e}},Oe=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Oa(t),Da(this._key),oo(this._publicKey)}sign(t){return La(this._key,t)}get public(){return new De(this._publicKey)}marshal(){return this._key}get bytes(){return Ct.encode({Type:G.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=bt.digest(this.bytes);return Bt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return st(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Je(this.bytes,t);throw new _(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function yf(r){return new Oe(r)}function mf(r){return new De(r)}async function bf(){let r=Ua();return new Oe(r)}var se={rsa:eo,ed25519:$s,secp256k1:io};function ao(r){let t=Object.keys(se).join(" / ");return new _(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function co(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return se[r];throw ao(r)}async function wf(r,t){return co(r).generateKeyPair(t??2048)}async function xf(r,t,e){if(r.toLowerCase()!=="ed25519")throw new _("Seed key derivation is unimplemented for RSA or secp256k1","ERR_UNSUPPORTED_KEY_DERIVATION_TYPE");return Fs(t)}function vf(r){let t=Tt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return se.rsa.unmarshalRsaPublicKey(e);case G.Ed25519:return se.ed25519.unmarshalEd25519PublicKey(e);case G.Secp256k1:return se.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw ao(t.Type??"unknown")}}function Bf(r,t){return t=(t??"rsa").toLowerCase(),co(t),r.bytes}async function Pa(r){let t=Ct.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case G.RSA:return se.rsa.unmarshalRsaPrivateKey(e);case G.Ed25519:return se.ed25519.unmarshalEd25519PrivateKey(e);case G.Secp256k1:return se.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw ao(t.Type??"RSA")}}function Ef(r,t){return t=(t??"rsa").toLowerCase(),co(t),r.bytes}async function Af(r,t){try{let e=await Ri(r,t);return await Pa(e)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return Xs(r,t)}var uo=(r,t)=>r<<t|r>>>32-t>>>0,kf=(r,t,e)=>r&t^~r&e,Sf=(r,t,e)=>r&t^r&e^t&e,kr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),ve=new Uint32Array(80),fo=class extends ae{constructor(){super(64,20,8,!1),this.A=kr[0]|0,this.B=kr[1]|0,this.C=kr[2]|0,this.D=kr[3]|0,this.E=kr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)ve[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)ve[c]=uo(ve[c-3]^ve[c-8]^ve[c-14]^ve[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let u,l;c<20?(u=kf(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Sf(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=uo(n,5)+u+a+l+ve[c]|0;a=i,i=o,o=uo(s,30),s=n,n=f}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){ve.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Ka=ze(()=>new fo);var Ma={sha1:Ka,"sha2-256":Kn,"sha2-512":ue};function ho(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Ma).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let o=Ma[s],i=Li(o,r,t,{c:e,dkLen:n});return ke.encode(i).substring(1)}return nc(If);})();
8
8
  /*! Bundled license information:
9
9
 
10
10
  pvtsutils/build/index.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/crypto",
3
- "version": "4.0.0",
3
+ "version": "4.0.1",
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",
@@ -83,7 +83,7 @@
83
83
  "generate": "protons ./src/keys/keys.proto"
84
84
  },
85
85
  "dependencies": {
86
- "@libp2p/interface": "^1.1.1",
86
+ "@libp2p/interface": "^1.1.2",
87
87
  "@noble/curves": "^1.1.0",
88
88
  "@noble/hashes": "^1.3.3",
89
89
  "asn1js": "^3.0.5",
@@ -106,5 +106,6 @@
106
106
  "./dist/src/keys/rsa.js": "./dist/src/keys/rsa-browser.js",
107
107
  "./dist/src/keys/secp256k1.js": "./dist/src/keys/secp256k1-browser.js",
108
108
  "./dist/src/webcrypto.js": "./dist/src/webcrypto-browser.js"
109
- }
109
+ },
110
+ "sideEffects": false
110
111
  }