@libp2p/keychain 5.1.0 → 5.1.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/README.md CHANGED
@@ -24,11 +24,11 @@ repo and examine the changes made.
24
24
 
25
25
  -->
26
26
 
27
- - Manages the lifecycle of a key
27
+ - Manages the life cycle of a key
28
28
  - Keys are encrypted at rest
29
29
  - Enforces the use of safe key names
30
30
  - Uses encrypted PKCS 8 for key storage
31
- - Uses PBKDF2 for a "stetched" key encryption key
31
+ - Uses PBKDF2 for a "stretched" key encryption key
32
32
  - Enforces NIST SP 800-131A and NIST SP 800-132
33
33
  - Delays reporting errors to slow down brute force attacks
34
34
 
@@ -49,9 +49,9 @@ The *public key* is a [protobuf encoding](https://github.com/libp2p/js-libp2p/bl
49
49
 
50
50
  ## Private key storage
51
51
 
52
- A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *passPhrase* using **PBKDF2**.
52
+ A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *pass phrase* using **PBKDF2**.
53
53
 
54
- The default options for generating the derived encryption key are in the `dek` object. This, along with the passPhrase, is the input to a `PBKDF2` function.
54
+ The default options for generating the derived encryption key are in the `dek` object. This, along with the pass phrase, is the input to a `PBKDF2` function.
55
55
 
56
56
  ```TypeScript
57
57
  const defaultOptions = {
package/dist/index.min.js CHANGED
@@ -1,9 +1,9 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PKeychain = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PKeychain=(()=>{var Yc=Object.create;var Gr=Object.defineProperty;var Xc=Object.getOwnPropertyDescriptor;var Qc=Object.getOwnPropertyNames;var tl=Object.getPrototypeOf,el=Object.prototype.hasOwnProperty;var Ee=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ft=(r,t)=>{for(var e in t)Gr(r,e,{get:t[e],enumerable:!0})},Yo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Qc(t))!el.call(r,s)&&s!==e&&Gr(r,s,{get:()=>t[s],enumerable:!(n=Xc(t,s))||n.enumerable});return r};var xs=(r,t,e)=>(e=r!=null?Yc(tl(r)):{},Yo(t||!r||!r.__esModule?Gr(e,"default",{value:r,enumerable:!0}):e,r)),rl=r=>Yo(Gr({},"__esModule",{value:!0}),r);var na=Ee(er=>{"use strict";var kf="[object ArrayBuffer]",Zt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===kf}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}},Eo="string",Sf=/^[0-9a-f\s]+$/i,If=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Nf=/^[a-zA-Z0-9-_]+$/,xn=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=Zt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Zt.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}},vn=class r{static isHex(t){return typeof t===Eo&&Sf.test(t)}static isBase64(t){return typeof t===Eo&&If.test(t)}static isBase64Url(t){return typeof t===Eo&&Nf.test(t)}static ToString(t,e="utf8"){let n=Zt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Zt.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 xn.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return xn.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Zt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Zt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};vn.DEFAULT_UTF8_ENCODING="utf8";function Cf(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 Tf(...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 Uf(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=Zt;er.Convert=vn;er.assign=Cf;er.combine=Tf;er.isEqual=Uf});var vc=Ee((pm,xc)=>{"use strict";xc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Ic=Ee((kc,Sc)=>{"use strict";var gs=vc(),{hasOwnProperty:Ec}=Object.prototype,{propertyIsEnumerable:Jf}=Object,ir=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),Yf=kc,Bc={concatArrays:!1,ignoreUndefined:!1},ms=r=>{let t=[];for(let e in r)Ec.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Jf.call(r,n)&&t.push(n)}return t};function ar(r){return Array.isArray(r)?Xf(r):gs(r)?Qf(r):r}function Xf(r){let t=r.slice(0,0);return ms(r).forEach(e=>{ir(t,e,ar(r[e]))}),t}function Qf(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return ms(r).forEach(e=>{ir(t,e,ar(r[e]))}),t}var Ac=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?ir(r,s,Do(r[s],t[s],n)):ir(r,s,ar(t[s])))}),r),th=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)Ec.call(o,a)&&(i.push(String(a)),o===r?ir(n,s++,o[a]):ir(n,s++,ar(o[a])));n=Ac(n,o,ms(o).filter(a=>!i.includes(a)),e)}),n};function Do(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?th(r,t,e):!gs(t)||!gs(r)?ar(t):Ac(r,t,ms(t),e)}Sc.exports=function(...r){let t=Do(ar(Bc),this!==Yf&&this||{},Bc),e={_:{}};for(let n of r)if(n!==void 0){if(!gs(n))throw new TypeError("`"+n+"` is not an Option Object");e=Do(e,{_:n},t)}return e._}});var Uc=Ee((mm,Tc)=>{"use strict";function eh(r){return r>=55296&&r<=56319}function rh(r){return r>=56320&&r<=57343}Tc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],eh(i)&&rh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Lc=Ee((ym,Rc)=>{"use strict";function nh(r){return r>=55296&&r<=56319}function sh(r){return r>=56320&&r<=57343}Rc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),sh(s)?o!=null&&nh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var Vc=Ee((wm,Hc)=>{"use strict";var oh=Uc(),ih=Lc();Hc.exports=oh.bind(null,ih)});var Dc=Ee((bm,_c)=>{"use strict";var ah=Vc(),ch=/[\/\?<>\\:\*\|"]/g,lh=/[\x00-\x1f\x80-\x9f]/g,uh=/^\.+$/,fh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,hh=/[\. ]+$/;function Oc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(ch,t).replace(lh,t).replace(uh,t).replace(fh,t).replace(hh,t);return ah(e,255)}_c.exports=function(r,t){var e=t&&t.replacement||"",n=Oc(r,e);return e===""?n:Oc(n,"")}});var Ah={};ft(Ah,{keychain:()=>Eh});var hr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},dr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Zr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Xo={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Zr("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var wt=Xo;var V=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ke=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},pr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var Wr=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Me=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Qo=Symbol.for("@libp2p/service-capabilities"),Rh=Symbol.for("@libp2p/service-dependencies");var ks={};ft(ks,{base58btc:()=>st,base58flickr:()=>cl});var ed=new Uint8Array(0);function ti(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 Pt(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 ei(r){return new TextEncoder().encode(r)}function ri(r){return new TextDecoder().decode(r)}function nl(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(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var m=0,d=0,b=0,B=w.length;b!==B&&w[b]===0;)b++,m++;for(var p=(B-b)*l+1>>>0,k=new Uint8Array(p);b!==B;){for(var R=w[b],U=0,I=p-1;(R!==0||U<d)&&I!==-1;I--,U++)R+=256*k[I]>>>0,k[I]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=U,b++}for(var T=p-d;T!==p&&k[T]===0;)T++;for(var N=c.repeat(m);T<p;++T)N+=r.charAt(k[T]);return N}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var m=0;if(w[m]!==" "){for(var d=0,b=0;w[m]===c;)d++,m++;for(var B=(w.length-m)*u+1>>>0,p=new Uint8Array(B);w[m];){var k=e[w.charCodeAt(m)];if(k===255)return;for(var R=0,U=B-1;(k!==0||R<b)&&U!==-1;U--,R++)k+=a*p[U]>>>0,p[U]=k%256>>>0,k=k/256>>>0;if(k!==0)throw new Error("Non-zero carry");b=R,m++}if(w[m]!==" "){for(var I=B-b;I!==B&&p[I]===0;)I++;for(var T=new Uint8Array(d+(B-I)),N=d;I!==B;)T[N++]=p[I++];return T}}}function y(w){var m=h(w);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:y}}var sl=nl,ol=sl,si=ol;var vs=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")}},Bs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,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 oi(this,t)}},Es=class{decoders;constructor(t){this.decoders=t}or(t){return oi(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 oi(r,t){return new Es({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var As=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 vs(t,e,n),this.decoder=new Bs(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 As(r,t,e,n)}function se({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=si(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Pt(s(o))})}function il(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 al(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 Y({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pe({prefix:t,name:r,encode(s){return al(s,n,e)},decode(s){return il(s,n,e,r)}})}var st=se({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),cl=se({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ss={};ft(Ss,{base32:()=>Fe,base32hex:()=>hl,base32hexpad:()=>pl,base32hexpadupper:()=>gl,base32hexupper:()=>dl,base32pad:()=>ul,base32padupper:()=>fl,base32upper:()=>ll,base32z:()=>ml});var Fe=Y({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ll=Y({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ul=Y({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),fl=Y({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),hl=Y({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dl=Y({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pl=Y({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),gl=Y({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ml=Y({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Is={};ft(Is,{base36:()=>gr,base36upper:()=>yl});var gr=se({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yl=se({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var wl=ci,ii=128,bl=127,xl=~bl,vl=Math.pow(2,31);function ci(r,t,e){t=t||[],e=e||0;for(var n=e;r>=vl;)t[e++]=r&255|ii,r/=128;for(;r&xl;)t[e++]=r&255|ii,r>>>=7;return t[e]=r|0,ci.bytes=e-n+1,t}var Bl=Ns,El=128,ai=127;function Ns(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Ns.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&ai)<<s:(i&ai)*Math.pow(2,s),s+=7}while(i>=El);return Ns.bytes=o-n,e}var Al=Math.pow(2,7),kl=Math.pow(2,14),Sl=Math.pow(2,21),Il=Math.pow(2,28),Nl=Math.pow(2,35),Cl=Math.pow(2,42),Tl=Math.pow(2,49),Ul=Math.pow(2,56),Rl=Math.pow(2,63),Ll=function(r){return r<Al?1:r<kl?2:r<Sl?3:r<Il?4:r<Nl?5:r<Cl?6:r<Tl?7:r<Ul?8:r<Rl?9:10},Hl={encode:wl,decode:Bl,encodingLength:Ll},Vl=Hl,mr=Vl;function yr(r,t=0){return[mr.decode(r,t),mr.decode.bytes]}function qe(r,t,e=0){return mr.encode(r,t,e),t}function je(r){return mr.encodingLength(r)}function St(r,t){let e=t.byteLength,n=je(r),s=n+je(e),o=new Uint8Array(s+e);return qe(r,o,0),qe(e,o,n),o.set(t,s),new $e(r,e,t,o)}function li(r){let t=Pt(r),[e,n]=yr(t),[s,o]=yr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new $e(e,s,i,t)}function ui(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ti(r.bytes,e.bytes)}}var $e=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function fi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return _l(e,Cs(r),t??st.encoder);default:return Dl(e,Cs(r),t??Fe.encoder)}}var hi=new WeakMap;function Cs(r){let t=hi.get(r);if(t==null){let e=new Map;return hi.set(r,e),e}return t}var Ht=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!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Kl)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=St(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&&ui(t.multihash,n.multihash)}toString(t){return fi(this,t)}toJSON(){return{"/":fi(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??di(n,s,o.bytes))}else if(e[Ml]===!0){let{version:n,multihash:s,code:o}=e,i=li(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!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=di(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,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=Pt(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 $e(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,h]=yr(t.subarray(e));return e+=h,f},s=n(),o=br;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 Cs(o).set(n,t),o}};function Ol(r,t){switch(r[0]){case"Q":{let e=t??st;return[st.prefix,e.decode(`${st.prefix}${r}`)]}case st.prefix:{let e=t??st;return[st.prefix,e.decode(r)]}case Fe.prefix:{let e=t??Fe;return[Fe.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function _l(r,t,e){let{prefix:n}=e;if(n!==st.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 Dl(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 br=112,Kl=18;function di(r,t,e){let n=je(r),s=n+je(t),o=new Uint8Array(s+e.byteLength);return qe(r,o,0),qe(t,o,n),o.set(e,s),o}var Ml=Symbol.for("@ipld/js-cid/CID");var Ts={};ft(Ts,{identity:()=>xr});var pi=0,Pl="identity",gi=Pt;function Fl(r){return St(pi,gi(r))}var xr={code:pi,name:Pl,encode:gi,digest:Fl};function Ft(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 ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function ql(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ge(r,...t){if(!ql(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function Yr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ze(r.outputLen),ze(r.blockLen)}function Ze(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 mi(r,t){Ge(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ae=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ke(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function It(r,t){return r<<32-t|r>>>t}function Xr(r,t){return r<<t|r>>>32-t>>>0}var jl=async()=>{};async function yi(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 jl(),n+=o)}}function wi(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function oe(r){return typeof r=="string"&&(r=wi(r)),Ge(r),r}function Us(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ge(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var We=class{clone(){return this._cloneInto()}};function bi(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Je(r){let t=n=>r().update(oe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ye(r=32){if(Ae&&typeof Ae.getRandomValues=="function")return Ae.getRandomValues(new Uint8Array(r));if(Ae&&typeof Ae.randomBytes=="function")return Ae.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function $l(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)}function Qr(r,t,e){return r&t^~r&e}function tn(r,t,e){return r&t^r&e^t&e}var ie=class extends We{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=ke(this.buffer)}update(t){Ze(this);let{view:e,buffer:n,blockLen:s}=this;t=oe(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=ke(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ze(this),mi(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;$l(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ke(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let 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 en=BigInt(4294967295),Rs=BigInt(32);function xi(r,t=!1){return t?{h:Number(r&en),l:Number(r>>Rs&en)}:{h:Number(r>>Rs&en)|0,l:Number(r&en)|0}}function zl(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}=xi(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Gl=(r,t)=>BigInt(r>>>0)<<Rs|BigInt(t>>>0),Zl=(r,t,e)=>r>>>e,Wl=(r,t,e)=>r<<32-e|t>>>e,Jl=(r,t,e)=>r>>>e|t<<32-e,Yl=(r,t,e)=>r<<32-e|t>>>e,Xl=(r,t,e)=>r<<64-e|t>>>e-32,Ql=(r,t,e)=>r>>>e-32|t<<64-e,tu=(r,t)=>t,eu=(r,t)=>r,ru=(r,t,e)=>r<<e|t>>>32-e,nu=(r,t,e)=>t<<e|r>>>32-e,su=(r,t,e)=>t<<e-32|r>>>64-e,ou=(r,t,e)=>r<<e-32|t>>>64-e;function iu(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var au=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),cu=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,lu=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),uu=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,fu=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),hu=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var du={fromBig:xi,split:zl,toBig:Gl,shrSH:Zl,shrSL:Wl,rotrSH:Jl,rotrSL:Yl,rotrBH:Xl,rotrBL:Ql,rotr32H:tu,rotr32L:eu,rotlSH:ru,rotlSL:nu,rotlBH:su,rotlBL:ou,add:iu,add3L:au,add3H:cu,add4L:lu,add4H:uu,add5H:hu,add5L:fu},_=du;var[pu,gu]=_.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ae=new Uint32Array(80),ce=new Uint32Array(80),Ls=class extends ie{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:y,Gl:w,Hh:m,Hl:d}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,y,w,m,d]}set(t,e,n,s,o,i,a,c,u,l,f,h,y,w,m,d){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=h|0,this.Gh=y|0,this.Gl=w|0,this.Hh=m|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)ae[p]=t.getUint32(e),ce[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let k=ae[p-15]|0,R=ce[p-15]|0,U=_.rotrSH(k,R,1)^_.rotrSH(k,R,8)^_.shrSH(k,R,7),I=_.rotrSL(k,R,1)^_.rotrSL(k,R,8)^_.shrSL(k,R,7),T=ae[p-2]|0,N=ce[p-2]|0,G=_.rotrSH(T,N,19)^_.rotrBH(T,N,61)^_.shrSH(T,N,6),F=_.rotrSL(T,N,19)^_.rotrBL(T,N,61)^_.shrSL(T,N,6),K=_.add4L(I,F,ce[p-7],ce[p-16]),Q=_.add4H(K,U,G,ae[p-7],ae[p-16]);ae[p]=Q|0,ce[p]=K|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:y,Fl:w,Gh:m,Gl:d,Hh:b,Hl:B}=this;for(let p=0;p<80;p++){let k=_.rotrSH(f,h,14)^_.rotrSH(f,h,18)^_.rotrBH(f,h,41),R=_.rotrSL(f,h,14)^_.rotrSL(f,h,18)^_.rotrBL(f,h,41),U=f&y^~f&m,I=h&w^~h&d,T=_.add5L(B,R,I,gu[p],ce[p]),N=_.add5H(T,b,k,U,pu[p],ae[p]),G=T|0,F=_.rotrSH(n,s,28)^_.rotrBH(n,s,34)^_.rotrBH(n,s,39),K=_.rotrSL(n,s,28)^_.rotrBL(n,s,34)^_.rotrBL(n,s,39),Q=n&o^n&a^o&a,E=s&i^s&c^i&c;b=m|0,B=d|0,m=y|0,d=w|0,y=f|0,w=h|0,{h:f,l:h}=_.add(u|0,l|0,N|0,G|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let C=_.add3L(G,K,E);n=_.add3H(C,N,F,Q),s=C|0}({h:n,l:s}=_.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=_.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=_.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=_.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=_.add(this.Eh|0,this.El|0,f|0,h|0),{h:y,l:w}=_.add(this.Fh|0,this.Fl|0,y|0,w|0),{h:m,l:d}=_.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:b,l:B}=_.add(this.Hh|0,this.Hl|0,b|0,B|0),this.set(n,s,o,i,a,c,u,l,f,h,y,w,m,d,b,B)}roundClean(){ae.fill(0),ce.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var le=Je(()=>new Ls);var sn={};ft(sn,{aInRange:()=>bt,abool:()=>Nt,abytes:()=>Xe,bitGet:()=>vu,bitLen:()=>_s,bitMask:()=>Br,bitSet:()=>Bu,bytesToHex:()=>jt,bytesToNumberBE:()=>$t,bytesToNumberLE:()=>fe,concatBytes:()=>zt,createHmacDrbg:()=>Ds,ensureBytes:()=>J,equalBytes:()=>bu,hexToBytes:()=>Ie,hexToNumber:()=>Os,inRange:()=>vr,isBytes:()=>ue,memoized:()=>Ce,notImplemented:()=>Au,numberToBytesBE:()=>he,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>Se,numberToVarBytesBE:()=>wu,utf8ToBytes:()=>xu,validateObject:()=>Vt});var rn=BigInt(0),nn=BigInt(1),mu=BigInt(2);function ue(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Xe(r){if(!ue(r))throw new Error("Uint8Array expected")}function Nt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var yu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function jt(r){Xe(r);let t="";for(let e=0;e<r.length;e++)t+=yu[r[e]];return t}function Se(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Os(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?rn:BigInt("0x"+r)}var qt={_0:48,_9:57,A:65,F:70,a:97,f:102};function vi(r){if(r>=qt._0&&r<=qt._9)return r-qt._0;if(r>=qt.A&&r<=qt.F)return r-(qt.A-10);if(r>=qt.a&&r<=qt.f)return r-(qt.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("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=vi(r.charCodeAt(o)),a=vi(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 $t(r){return Os(jt(r))}function fe(r){return Xe(r),Os(jt(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 wu(r){return Ie(Se(r))}function J(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(ue(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+" of length "+e+" expected, got "+s);return n}function zt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Xe(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function bu(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 xu(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Hs=r=>typeof r=="bigint"&&rn<=r;function vr(r,t,e){return Hs(r)&&Hs(t)&&Hs(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!vr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function _s(r){let t;for(t=0;r>rn;r>>=nn,t+=1);return t}function vu(r,t){return r>>BigInt(t)&nn}function Bu(r,t,e){return r|(e?nn:rn)<<BigInt(t)}var Br=r=>(mu<<BigInt(r-1))-nn,Vs=r=>new Uint8Array(r),Bi=r=>Uint8Array.from(r);function Ds(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=Vs(r),s=Vs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Vs())=>{s=a(Bi([0]),f),n=a(),f.length!==0&&(s=a(Bi([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,h=[];for(;f<t;){n=a();let y=n.slice();h.push(y),f+=n.length}return zt(...h)};return(f,h)=>{i(),c(f);let y;for(;!(y=h(u()));)c();return i(),y}}var Eu={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"||ue(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=Eu[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};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 Au=()=>{throw new Error("not implemented")};function Ce(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var tt=BigInt(0),Z=BigInt(1),Te=BigInt(2),ku=BigInt(3),Ks=BigInt(4),Ei=BigInt(5),Ai=BigInt(8),Su=BigInt(9),Iu=BigInt(16);function $(r,t){let e=r%t;return e>=tt?e:t+e}function Nu(r,t,e){if(t<tt)throw new Error("invalid exponent, negatives unsupported");if(e<=tt)throw new Error("invalid modulus");if(e===Z)return tt;let n=Z;for(;t>tt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function W(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function on(r,t){if(r===tt)throw new Error("invert: expected non-zero number");if(t<=tt)throw new Error("invert: expected positive modulus, got "+t);let e=$(r,t),n=t,s=tt,o=Z,i=Z,a=tt;for(;e!==tt;){let u=n/e,l=n%e,f=s-i*u,h=o-a*u;n=e,e=l,s=i,o=a,i=f,a=h}if(n!==Z)throw new Error("invert: does not exist");return $(s,t)}function Cu(r){let t=(r-Z)/Te,e,n,s;for(e=r-Z,n=0;e%Te===tt;e/=Te,n++);for(s=Te;s<r&&Nu(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/Ks;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+Z)/Te;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),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let m=a.sqr(h);y<u&&!a.eql(m,a.ONE);y++)m=a.sqr(m);let w=a.pow(l,Z<<BigInt(u-y-1));l=a.sqr(w),f=a.mul(f,w),h=a.mul(h,l),u=y}return f}}function Tu(r){if(r%Ks===ku){let t=(r+Z)/Ks;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%Ai===Ei){let t=(r-Ei)/Ai;return function(n,s){let o=n.mul(s,Te),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Te),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%Iu,Cu(r)}var ki=(r,t)=>($(r,t)&Z)===Z,Uu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ms(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Uu.reduce((n,s)=>(n[s]="function",n),t);return Vt(r,e)}function Ru(r,t,e){if(e<tt)throw new Error("invalid exponent, negatives unsupported");if(e===tt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>tt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Lu(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 Ps(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function de(r,t,e=!1,n={}){if(r<=tt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=Ps(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Br(s),ZERO:tt,ONE:Z,create:c=>$(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&Z)===Z,neg:c=>$(-c,r),eql:(c,u)=>c===u,sqr:c=>$(c*c,r),add:(c,u)=>$(c+u,r),sub:(c,u)=>$(c-u,r),mul:(c,u)=>$(c*u,r),pow:(c,u)=>Ru(a,c,u),div:(c,u)=>$(c*on(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>on(c,r),sqrt:n.sqrt||(c=>(i||(i=Tu(r)),i(a,c))),invertBatch:c=>Lu(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("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?fe(c):$t(c)}});return Object.freeze(a)}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 Fs(r){let t=Si(r);return t+Math.ceil(t/2)}function Ii(r,t,e=!1){let n=r.length,s=Si(t),o=Fs(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?fe(r):$t(r),a=$(i,t-Z)+Z;return e?Ne(a,s):he(a,s)}var Ni=BigInt(0),an=BigInt(1);function qs(r,t){let e=t.negate();return r?e:t}function Ci(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function js(r,t){Ci(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function Hu(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Vu(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var $s=new WeakMap,Ti=new WeakMap;function zs(r){return Ti.get(r)||1}function cn(r,t){return{constTimeNegate:qs,hasPrecomputes(e){return zs(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Ni;)n&an&&(s=s.add(o)),o=o.double(),n>>=an;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=js(n,t),i=[],a=e,c=a;for(let u=0;u<s;u++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=js(e,t),a=r.ZERO,c=r.BASE,u=BigInt(2**e-1),l=2**e,f=BigInt(e);for(let h=0;h<o;h++){let y=h*i,w=Number(s&u);s>>=f,w>i&&(w-=l,s+=an);let m=y,d=y+Math.abs(w)-1,b=h%2!==0,B=w<0;w===0?c=c.add(qs(b,n[m])):a=a.add(qs(B,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=js(e,t),c=BigInt(2**e-1),u=2**e,l=BigInt(e);for(let f=0;f<i;f++){let h=f*a;if(s===Ni)break;let y=Number(s&c);if(s>>=l,y>a&&(y-=u,s+=an),y===0)continue;let w=n[h+Math.abs(y)-1];y<0&&(w=w.negate()),o=o.add(w)}return o},getPrecomputes(e,n,s){let o=$s.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&$s.set(n,s(o))),o},wNAFCached(e,n,s){let o=zs(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=zs(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){Ci(n,t),Ti.set(e,n),$s.delete(e)}}}function ln(r,t,e,n){if(Hu(e,r),Vu(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=_s(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),u=Math.floor((t.BITS-1)/i)*i,l=s;for(let f=u;f>=0;f-=i){c.fill(s);for(let y=0;y<n.length;y++){let w=n[y],m=Number(w>>BigInt(f)&BigInt(a));c[m]=c[m].add(e[y])}let h=s;for(let y=c.length-1,w=s;y>0;y--)w=w.add(c[y]),h=h.add(w);if(l=l.add(h),f!==0)for(let y=0;y<i;y++)l=l.double()}return l}function Er(r){return Ms(r.Fp),Vt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ps(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ct=BigInt(0),xt=BigInt(1),un=BigInt(2),Ou=BigInt(8),_u={zip215:!0};function Du(r){let t=Er(r);return Vt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ui(r){let t=Du(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=un<<BigInt(a*8)-xt,l=e.create,f=de(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:Ct}}}),y=t.adjustScalarBytes||(x=>x),w=t.domain||((x,g,v)=>{if(Nt("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function m(x,g){bt("coordinate "+x,g,Ct,u)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let b=Ce((x,g)=>{let{ex:v,ey:S,ez:L}=x,H=x.is0();g==null&&(g=H?Ou:e.inv(L));let D=l(v*g),P=l(S*g),O=l(L*g);if(H)return{x:Ct,y:xt};if(O!==xt)throw new Error("invZ was invalid");return{x:D,y:P}}),B=Ce(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:S,ey:L,ez:H,et:D}=x,P=l(S*S),O=l(L*L),j=l(H*H),z=l(j*j),rt=l(P*g),nt=l(j*l(rt+O)),at=l(z+l(v*l(P*O)));if(nt!==at)throw new Error("bad point: equation left != right (1)");let ut=l(S*L),yt=l(H*D);if(ut!==yt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,S,L){this.ex=g,this.ey=v,this.ez=S,this.et=L,m("x",g),m("y",v),m("z",S),m("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:S}=g||{};return m("x",v),m("y",S),new p(v,S,xt,l(v*S))}static normalizeZ(g){let v=e.invertBatch(g.map(S=>S.ez));return g.map((S,L)=>S.toAffine(v[L])).map(p.fromAffine)}static msm(g,v){return ln(p,f,g,v)}_setWindowSize(g){U.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:v,ey:S,ez:L}=this,{ex:H,ey:D,ez:P}=g,O=l(v*P),j=l(H*L),z=l(S*P),rt=l(D*L);return O===j&&z===rt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:S,ez:L}=this,H=l(v*v),D=l(S*S),P=l(un*l(L*L)),O=l(g*H),j=v+S,z=l(l(j*j)-H-D),rt=O+D,nt=rt-P,at=O-D,ut=l(z*nt),yt=l(rt*at),pt=l(z*at),Lt=l(nt*rt);return new p(ut,yt,Lt,pt)}add(g){d(g);let{a:v,d:S}=t,{ex:L,ey:H,ez:D,et:P}=this,{ex:O,ey:j,ez:z,et:rt}=g;if(v===BigInt(-1)){let jo=l((H-L)*(j+O)),$o=l((H+L)*(j-O)),bs=l($o-jo);if(bs===Ct)return this.double();let zo=l(D*un*rt),Go=l(P*un*z),Zo=Go+zo,Wo=$o+jo,Jo=Go-zo,Gc=l(Zo*bs),Zc=l(Wo*Jo),Wc=l(Zo*Jo),Jc=l(bs*Wo);return new p(Gc,Zc,Jc,Wc)}let nt=l(L*O),at=l(H*j),ut=l(P*S*rt),yt=l(D*z),pt=l((L+H)*(O+j)-nt-at),Lt=yt-ut,Mt=yt+ut,fr=l(at-v*nt),qc=l(pt*Lt),jc=l(Mt*fr),$c=l(pt*fr),zc=l(Lt*Mt);return new p(qc,jc,zc,$c)}subtract(g){return this.add(g.negate())}wNAF(g){return U.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;bt("scalar",v,xt,n);let{p:S,f:L}=this.wNAF(v);return p.normalizeZ([S,L])[0]}multiplyUnsafe(g,v=p.ZERO){let S=g;return bt("scalar",S,Ct,n),S===Ct?R:this.is0()||S===xt?this:U.wNAFCachedUnsafe(this,S,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return U.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===xt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:S,a:L}=t,H=e.BYTES;g=J("pointHex",g,H),Nt("zip215",v);let D=g.slice(),P=g[H-1];D[H-1]=P&-129;let O=fe(D),j=v?u:e.ORDER;bt("pointHex.y",O,Ct,j);let z=l(O*O),rt=l(z-xt),nt=l(S*z-L),{isValid:at,value:ut}=h(rt,nt);if(!at)throw new Error("Point.fromHex: invalid y coordinate");let yt=(ut&xt)===xt,pt=(P&128)!==0;if(!v&&ut===Ct&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==yt&&(ut=l(-ut)),p.fromAffine({x:ut,y:O})}static fromPrivateKey(g){return N(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),S=Ne(v,e.BYTES);return S[S.length-1]|=g&xt?128:0,S}toHex(){return jt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,xt,l(t.Gx*t.Gy)),p.ZERO=new p(Ct,xt,xt,Ct);let{BASE:k,ZERO:R}=p,U=cn(p,a*8);function I(x){return $(x,n)}function T(x){return I(fe(x))}function N(x){let g=e.BYTES;x=J("private key",x,g);let v=J("hashed private key",o(x),2*g),S=y(v.slice(0,g)),L=v.slice(g,2*g),H=T(S),D=k.multiply(H),P=D.toRawBytes();return{head:S,prefix:L,scalar:H,point:D,pointBytes:P}}function G(x){return N(x).pointBytes}function F(x=new Uint8Array,...g){let v=zt(...g);return T(o(w(v,J("context",x),!!s)))}function K(x,g,v={}){x=J("message",x),s&&(x=s(x));let{prefix:S,scalar:L,pointBytes:H}=N(g),D=F(v.context,S,x),P=k.multiply(D).toRawBytes(),O=F(v.context,P,H,x),j=I(D+O*L);bt("signature.s",j,Ct,n);let z=zt(P,Ne(j,e.BYTES));return J("result",z,e.BYTES*2)}let Q=_u;function E(x,g,v,S=Q){let{context:L,zip215:H}=S,D=e.BYTES;x=J("signature",x,2*D),g=J("message",g),v=J("publicKey",v,D),H!==void 0&&Nt("zip215",H),s&&(g=s(g));let P=fe(x.slice(D,2*D)),O,j,z;try{O=p.fromHex(v,H),j=p.fromHex(x.slice(0,D),H),z=k.multiplyUnsafe(P)}catch{return!1}if(!H&&O.isSmallOrder())return!1;let rt=F(L,j.toRawBytes(),O.toRawBytes(),g);return j.add(O.multiplyUnsafe(rt)).subtract(z).clearCofactor().equals(p.ZERO)}return k._setWindowSize(8),{CURVE:t,getPublicKey:G,sign:K,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var Gs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ri=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Gd=BigInt(0),Ku=BigInt(1),Li=BigInt(2),Zd=BigInt(3),Mu=BigInt(5),Pu=BigInt(8);function Fu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Gs,a=r*r%o*r%o,c=W(a,Li,o)*a%o,u=W(c,Ku,o)*r%o,l=W(u,Mu,o)*u%o,f=W(l,t,o)*l%o,h=W(f,e,o)*f%o,y=W(h,n,o)*h%o,w=W(y,s,o)*y%o,m=W(w,s,o)*y%o,d=W(m,t,o)*l%o;return{pow_p_5_8:W(d,Li,o)*r%o,b2:a}}function qu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ju(r,t){let e=Gs,n=$(t*t*t,e),s=$(n*n*t,e),o=Fu(r*s).pow_p_5_8,i=$(r*n*o,e),a=$(t*i*i,e),c=i,u=$(i*Ri,e),l=a===r,f=a===$(-r,e),h=a===$(-r*Ri,e);return l&&(i=c),(f||h)&&(i=u),ki(i,e)&&(i=$(-i,e)),{isValid:l||f,value:i}}var $u=de(Gs,void 0,!0),zu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:$u,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Pu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:le,randomBytes:Ye,adjustScalarBytes:qu,uvRatio:ju},Zs=Ui(zu);var Ar=32,Gt=64,Gu=32;function Hi(r,t){let e=r.subarray(0,Gu);return Zs.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Vi(r,t,e){return Zs.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var fn=class{type="Ed25519";raw;constructor(t){this.raw=Sr(t,Ar)}toMultihash(){return xr.digest(hn(this))}toCID(){return Ht.createV1(114,this.toMultihash())}toString(){return st.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}verify(t,e){return Vi(this.raw,e,t)}},kr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Sr(t,Gt),this.publicKey=new fn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}sign(t){return Hi(this.raw,t)}};function Ws(r){if(r.length>Gt){r=Sr(r,Gt+Ar);let n=r.subarray(0,Gt),s=r.subarray(Gt,r.length);return new kr(n,s)}r=Sr(r,Gt);let t=r.subarray(0,Gt),e=r.subarray(Ar);return new kr(t,e)}function Sr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new V(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Ot(r=0){return new Uint8Array(r)}var Zu=Math.pow(2,7),Wu=Math.pow(2,14),Ju=Math.pow(2,21),_i=Math.pow(2,28),Di=Math.pow(2,35),Ki=Math.pow(2,42),Mi=Math.pow(2,49),gt=128,pe=127;function Ir(r){if(r<Zu)return 1;if(r<Wu)return 2;if(r<Ju)return 3;if(r<_i)return 4;if(r<Di)return 5;if(r<Ki)return 6;if(r<Mi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Pi(r,t,e=0){switch(Ir(r)){case 8:t[e++]=r&255|gt,r/=128;case 7:t[e++]=r&255|gt,r/=128;case 6:t[e++]=r&255|gt,r/=128;case 5:t[e++]=r&255|gt,r/=128;case 4:t[e++]=r&255|gt,r>>>=7;case 3:t[e++]=r&255|gt,r>>>=7;case 2:t[e++]=r&255|gt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Fi(r,t){let e=r[t],n=0;if(n+=e&pe,e<gt||(e=r[t+1],n+=(e&pe)<<7,e<gt)||(e=r[t+2],n+=(e&pe)<<14,e<gt)||(e=r[t+3],n+=(e&pe)<<21,e<gt)||(e=r[t+4],n+=(e&pe)*_i,e<gt)||(e=r[t+5],n+=(e&pe)*Di,e<gt)||(e=r[t+6],n+=(e&pe)*Ki,e<gt)||(e=r[t+7],n+=(e&pe)*Mi,e<gt))return n;throw new RangeError("Could not decode varint")}var Js=new Float32Array([-0]),ge=new Uint8Array(Js.buffer);function qi(r,t,e){Js[0]=r,t[e]=ge[0],t[e+1]=ge[1],t[e+2]=ge[2],t[e+3]=ge[3]}function ji(r,t){return ge[0]=r[t],ge[1]=r[t+1],ge[2]=r[t+2],ge[3]=r[t+3],Js[0]}var Ys=new Float64Array([-0]),ht=new Uint8Array(Ys.buffer);function $i(r,t,e){Ys[0]=r,t[e]=ht[0],t[e+1]=ht[1],t[e+2]=ht[2],t[e+3]=ht[3],t[e+4]=ht[4],t[e+5]=ht[5],t[e+6]=ht[6],t[e+7]=ht[7]}function zi(r,t){return ht[0]=r[t],ht[1]=r[t+1],ht[2]=r[t+2],ht[3]=r[t+3],ht[4]=r[t+4],ht[5]=r[t+5],ht[6]=r[t+6],ht[7]=r[t+7],Ys[0]}var Yu=BigInt(Number.MAX_SAFE_INTEGER),Xu=BigInt(Number.MIN_SAFE_INTEGER),Et=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 Ue;if(t<Yu&&t>Xu)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>Gi&&(s=0n,++n>Gi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ue;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):Ue}},Ue=new Et(0,0);Ue.toBigInt=function(){return 0n};Ue.zzEncode=Ue.zzDecode=function(){return this};Ue.length=function(){return 1};var Gi=4294967296n;function Zi(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 Wi(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 Xs(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 Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function dn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Qs=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,Tt(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 Tt(this,4);return dn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return dn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=ji(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=zi(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 Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Wi(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(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 Et(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 Tt(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 Tt(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 Tt(this,8);let t=dn(this.buf,this.pos+=4),e=dn(this.buf,this.pos+=4);return new Et(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Fi(this.buf,this.pos);return this.pos+=Ir(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function to(r){return new Qs(r instanceof Uint8Array?r:r.subarray())}function pn(r,t,e){let n=to(r);return t.decode(n,void 0,e)}var eo={};ft(eo,{base10:()=>Qu});var Qu=se({prefix:"9",name:"base10",alphabet:"0123456789"});var ro={};ft(ro,{base16:()=>tf,base16upper:()=>ef});var tf=Y({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ef=Y({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var no={};ft(no,{base2:()=>rf});var rf=Y({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var so={};ft(so,{base256emoji:()=>cf});var Yi=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}"),nf=Yi.reduce((r,t,e)=>(r[e]=t,r),[]),sf=Yi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function of(r){return r.reduce((t,e)=>(t+=nf[e],t),"")}function af(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=sf[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var cf=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:of,decode:af});var oo={};ft(oo,{base64:()=>Re,base64pad:()=>lf,base64url:()=>uf,base64urlpad:()=>ff});var Re=Y({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),lf=Y({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),uf=Y({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ff=Y({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var io={};ft(io,{base8:()=>hf});var hf=Y({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ao={};ft(ao,{identity:()=>df});var df=Pe({prefix:"\0",name:"identity",encode:r=>ri(r),decode:r=>ei(r)});var C0=new TextEncoder,T0=new TextDecoder;var uo={};ft(uo,{sha256:()=>Qe,sha512:()=>mf});function lo({name:r,code:t,encode:e}){return new co(r,t,e)}var co=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?St(this.code,e):e.then(n=>St(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Qi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Qe=lo({name:"sha2-256",code:18,encode:Qi("SHA-256")}),mf=lo({name:"sha2-512",code:19,encode:Qi("SHA-512")});var fo={...ao,...no,...io,...eo,...ro,...Ss,...Is,...ks,...oo,...so},F0={...uo,...Ts};function ea(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ta=ea("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ho=ea("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=Ot(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),yf={utf8:ta,"utf-8":ta,hex:fo.base16,latin1:ho,ascii:ho,binary:ho,...fo},gn=yf;function q(r,t="utf8"){let e=gn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function po(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Ot(i);s+i>t&&(n=Ot(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Le=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function go(){}var yo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},wf=po();function bf(r){return globalThis.Buffer!=null?Ot(r):wf(r)}var Cr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Le(go,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Le(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new wo((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(mn,10,Et.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Et.fromBigInt(t);return this._push(mn,e.length(),e)}uint64Number(t){return this._push(Pi,Ir(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Et.fromBigInt(t).zzEncode();return this._push(mn,e.length(),e)}sint64Number(t){let e=Et.fromNumber(t).zzEncode();return this._push(mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(mo,1,t?1:0)}fixed32(t){return this._push(Nr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Et.fromBigInt(t);return this._push(Nr,4,e.lo)._push(Nr,4,e.hi)}fixed64Number(t){let e=Et.fromNumber(t);return this._push(Nr,4,e.lo)._push(Nr,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(qi,4,t)}double(t){return this._push($i,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(mo,1,0):this.uint32(e)._push(vf,e,t)}string(t){let e=Zi(t);return e!==0?this.uint32(e)._push(Xs,e,t):this._push(mo,1,0)}fork(){return this.states=new yo(this),this.head=this.tail=new Le(go,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 Le(go,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=bf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function mo(r,t,e){t[e]=r&255}function xf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var wo=class extends Le{next;constructor(t,e){super(xf,t,e),this.next=void 0}};function mn(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 Nr(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 vf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Cr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Bf,t,r),this},Cr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ef,t,r),this});function Bf(r,t,e){t.set(r,e)}function Ef(r,t,e){r.length<40?Xs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function bo(){return new Cr}function yn(r,t){let e=bo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function wn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function xo(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 wn("enum",tr.VARINT,e,n)}function bn(r,t){return wn("message",tr.LENGTH_DELIMITED,r,t)}var ot;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(ot||(ot={}));var vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(vo||(vo={}));(function(r){r.codec=()=>xo(vo)})(ot||(ot={}));var me;(function(r){let t;r.codec=()=>(t==null&&(t=bn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ot.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=ot.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>yn(e,r.codec()),r.decode=(e,n)=>pn(e,r.codec(),n)})(me||(me={}));var Tr;(function(r){let t;r.codec=()=>(t==null&&(t=bn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ot.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=ot.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>yn(e,r.codec()),r.decode=(e,n)=>pn(e,r.codec(),n)})(Tr||(Tr={}));var Kr={};ft(Kr,{MAX_RSA_KEY_SIZE:()=>cs,generateRSAKeyPair:()=>Ya,jwkToJWKKeyPair:()=>Xa,jwkToPkcs1:()=>Df,jwkToPkix:()=>To,jwkToRSAPrivateKey:()=>Ja,pkcs1ToJwk:()=>Ga,pkcs1ToRSAPrivateKey:()=>ls,pkixToJwk:()=>Za,pkixToRSAPublicKey:()=>Wa});var Af=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]),ye=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),we=new Uint32Array(64),Bo=class extends ie{constructor(){super(64,32,8,!1),this.A=ye[0]|0,this.B=ye[1]|0,this.C=ye[2]|0,this.D=ye[3]|0,this.E=ye[4]|0,this.F=ye[5]|0,this.G=ye[6]|0,this.H=ye[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)we[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=we[f-15],y=we[f-2],w=It(h,7)^It(h,18)^h>>>3,m=It(y,17)^It(y,19)^y>>>10;we[f]=m+we[f-7]+w+we[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=It(a,6)^It(a,11)^It(a,25),y=l+h+Qr(a,c,u)+Af[f]+we[f]|0,m=(It(n,2)^It(n,13)^It(n,22))+tn(n,s,o)|0;l=u,u=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+m|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(){we.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var be=Je(()=>new Bo);var M=xs(na());function He(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 xe(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 Bn(...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 Ao(){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=He(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,He(o,8)-n}function sa(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=xe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(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 oa(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 vt(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 Ep=Math.log(2);function En(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ko(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 Qt(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 Rr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ko(this.items)}},Ur=[new Uint8Array([1])],ia="0123456789";var nr="",Ut=new ArrayBuffer(0),So=new Uint8Array(0),Lr="EndOfContent",ca="OCTET STRING",la="BIT STRING";function te(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?M.BufferSourceConverter.toUint8Array(o.valueHex):So}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(!Qt(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:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Wt=class{constructor({blockLength:t=0,error:e=nr,warnings:n=[],valueBeforeDecode:s=So}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.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:M.Convert.ToHex(this.valueBeforeDecodeView)}}};Wt.NAME="baseBlock";var dt=class extends Wt{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'")}};dt.NAME="valueBlock";var An=class extends te(Wt){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?M.BufferSourceConverter.toUint8Array(t.valueHex):So,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=xe(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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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 h=new Uint8Array(l);for(let y=0;y<u.length;y++)h[y]=u[y];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=He(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}}};An.NAME="identificationBlock";var kn=class extends Wt{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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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=He(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=xe(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}}};kn.NAME="lengthBlock";var A={},ct=class extends Wt{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 An(s),this.lenBlock=new kn(s),this.valueBlock=o?new o(s):new dt(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 Rr;e||ua(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():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.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 oa(e,n)}};ct.NAME="BaseBlock";function ua(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)ua(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Sn=class extends ct{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}'`}};Sn.NAME="BaseStringBlock";var In=class extends te(dt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};In.NAME="PrimitiveValueBlock";var fa,Nn=class extends ct{constructor(t={}){super(t,In),this.idBlock.isConstructed=!1}};fa=Nn;A.Primitive=fa;Nn.NAME="PRIMITIVE";function Lf(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 as(r,t=0,e=r.length){let n=t,s=new ct({},dt),o=new Wt;if(!Qt(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=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let u=s.idBlock.isConstructed?new A.Constructed:new A.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?A.Constructed:A.Primitive}return s=Lf(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 Ve(r){if(!r.byteLength){let t=new ct({},dt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return as(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Hf(r,t){return r?1:t}var _t=class extends dt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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(;Hf(this.isIndefiniteForm,n)>0;){let i=as(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===Lr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Lr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Rr;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}};_t.NAME="ConstructedValueBlock";var ha,ve=class extends ct{constructor(t={}){super(t,_t),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 Libp2PKeychain=(()=>{var Yc=Object.create;var Gr=Object.defineProperty;var Xc=Object.getOwnPropertyDescriptor;var Qc=Object.getOwnPropertyNames;var tl=Object.getPrototypeOf,el=Object.prototype.hasOwnProperty;var Ee=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ft=(r,t)=>{for(var e in t)Gr(r,e,{get:t[e],enumerable:!0})},Yo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Qc(t))!el.call(r,s)&&s!==e&&Gr(r,s,{get:()=>t[s],enumerable:!(n=Xc(t,s))||n.enumerable});return r};var xs=(r,t,e)=>(e=r!=null?Yc(tl(r)):{},Yo(t||!r||!r.__esModule?Gr(e,"default",{value:r,enumerable:!0}):e,r)),rl=r=>Yo(Gr({},"__esModule",{value:!0}),r);var na=Ee(er=>{"use strict";var kf="[object ArrayBuffer]",Zt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===kf}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}},Eo="string",Sf=/^[0-9a-f\s]+$/i,If=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Nf=/^[a-zA-Z0-9-_]+$/,xn=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=Zt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},At=class{static toString(t,e=!1){let n=Zt.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}},vn=class r{static isHex(t){return typeof t===Eo&&Sf.test(t)}static isBase64(t){return typeof t===Eo&&If.test(t)}static isBase64Url(t){return typeof t===Eo&&Nf.test(t)}static ToString(t,e="utf8"){let n=Zt.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return At.toString(n,!0);case"utf16":case"utf16be":return At.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return At.fromString(t,!0);case"utf16":case"utf16be":return At.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Zt.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 xn.fromString(t);case"utf16":case"utf16be":return At.fromString(t);case"utf16le":case"usc2":return At.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return xn.toString(t);case"utf16":case"utf16be":return At.toString(t);case"utf16le":case"usc2":return At.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=Zt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Zt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return At.toString(t,e)}static FromUtf16String(t,e=!1){return At.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};vn.DEFAULT_UTF8_ENCODING="utf8";function Cf(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 Tf(...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 Uf(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=Zt;er.Convert=vn;er.assign=Cf;er.combine=Tf;er.isEqual=Uf});var vc=Ee((pm,xc)=>{"use strict";xc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Ic=Ee((kc,Sc)=>{"use strict";var gs=vc(),{hasOwnProperty:Ec}=Object.prototype,{propertyIsEnumerable:Jf}=Object,ir=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),Yf=kc,Bc={concatArrays:!1,ignoreUndefined:!1},ms=r=>{let t=[];for(let e in r)Ec.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Jf.call(r,n)&&t.push(n)}return t};function ar(r){return Array.isArray(r)?Xf(r):gs(r)?Qf(r):r}function Xf(r){let t=r.slice(0,0);return ms(r).forEach(e=>{ir(t,e,ar(r[e]))}),t}function Qf(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return ms(r).forEach(e=>{ir(t,e,ar(r[e]))}),t}var Ac=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?ir(r,s,Do(r[s],t[s],n)):ir(r,s,ar(t[s])))}),r),th=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)Ec.call(o,a)&&(i.push(String(a)),o===r?ir(n,s++,o[a]):ir(n,s++,ar(o[a])));n=Ac(n,o,ms(o).filter(a=>!i.includes(a)),e)}),n};function Do(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?th(r,t,e):!gs(t)||!gs(r)?ar(t):Ac(r,t,ms(t),e)}Sc.exports=function(...r){let t=Do(ar(Bc),this!==Yf&&this||{},Bc),e={_:{}};for(let n of r)if(n!==void 0){if(!gs(n))throw new TypeError("`"+n+"` is not an Option Object");e=Do(e,{_:n},t)}return e._}});var Uc=Ee((mm,Tc)=>{"use strict";function eh(r){return r>=55296&&r<=56319}function rh(r){return r>=56320&&r<=57343}Tc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],eh(i)&&rh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Lc=Ee((ym,Rc)=>{"use strict";function nh(r){return r>=55296&&r<=56319}function sh(r){return r>=56320&&r<=57343}Rc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),sh(s)?o!=null&&nh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var Vc=Ee((wm,Hc)=>{"use strict";var oh=Uc(),ih=Lc();Hc.exports=oh.bind(null,ih)});var Dc=Ee((bm,_c)=>{"use strict";var ah=Vc(),ch=/[\/\?<>\\:\*\|"]/g,lh=/[\x00-\x1f\x80-\x9f]/g,uh=/^\.+$/,fh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,hh=/[\. ]+$/;function Oc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(ch,t).replace(lh,t).replace(uh,t).replace(fh,t).replace(hh,t);return ah(e,255)}_c.exports=function(r,t){var e=t&&t.replacement||"",n=Oc(r,e);return e===""?n:Oc(n,"")}});var Ah={};ft(Ah,{keychain:()=>Eh});var hr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},dr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Zr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Xo={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Zr("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var wt=Xo;var V=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ke=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},pr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var Wr=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Me=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Qo=Symbol.for("@libp2p/service-capabilities"),Rh=Symbol.for("@libp2p/service-dependencies");var ks={};ft(ks,{base58btc:()=>st,base58flickr:()=>cl});var ed=new Uint8Array(0);function ti(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 Pt(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 ei(r){return new TextEncoder().encode(r)}function ri(r){return new TextDecoder().decode(r)}function nl(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(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var m=0,d=0,b=0,B=w.length;b!==B&&w[b]===0;)b++,m++;for(var p=(B-b)*l+1>>>0,k=new Uint8Array(p);b!==B;){for(var R=w[b],U=0,I=p-1;(R!==0||U<d)&&I!==-1;I--,U++)R+=256*k[I]>>>0,k[I]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=U,b++}for(var T=p-d;T!==p&&k[T]===0;)T++;for(var N=c.repeat(m);T<p;++T)N+=r.charAt(k[T]);return N}function h(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var m=0;if(w[m]!==" "){for(var d=0,b=0;w[m]===c;)d++,m++;for(var B=(w.length-m)*u+1>>>0,p=new Uint8Array(B);w[m];){var k=e[w.charCodeAt(m)];if(k===255)return;for(var R=0,U=B-1;(k!==0||R<b)&&U!==-1;U--,R++)k+=a*p[U]>>>0,p[U]=k%256>>>0,k=k/256>>>0;if(k!==0)throw new Error("Non-zero carry");b=R,m++}if(w[m]!==" "){for(var I=B-b;I!==B&&p[I]===0;)I++;for(var T=new Uint8Array(d+(B-I)),N=d;I!==B;)T[N++]=p[I++];return T}}}function y(w){var m=h(w);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:y}}var sl=nl,ol=sl,si=ol;var vs=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")}},Bs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,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 oi(this,t)}},Es=class{decoders;constructor(t){this.decoders=t}or(t){return oi(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 oi(r,t){return new Es({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var As=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 vs(t,e,n),this.decoder=new Bs(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 As(r,t,e,n)}function se({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=si(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Pt(s(o))})}function il(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)!==0)throw new SyntaxError("Unexpected end of data");return i}function al(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)!==0;)o+="=";return o}function Y({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pe({prefix:t,name:r,encode(s){return al(s,n,e)},decode(s){return il(s,n,e,r)}})}var st=se({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),cl=se({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ss={};ft(Ss,{base32:()=>Fe,base32hex:()=>hl,base32hexpad:()=>pl,base32hexpadupper:()=>gl,base32hexupper:()=>dl,base32pad:()=>ul,base32padupper:()=>fl,base32upper:()=>ll,base32z:()=>ml});var Fe=Y({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ll=Y({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ul=Y({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),fl=Y({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),hl=Y({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dl=Y({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pl=Y({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),gl=Y({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ml=Y({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Is={};ft(Is,{base36:()=>gr,base36upper:()=>yl});var gr=se({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yl=se({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var wl=ci,ii=128,bl=127,xl=~bl,vl=Math.pow(2,31);function ci(r,t,e){t=t||[],e=e||0;for(var n=e;r>=vl;)t[e++]=r&255|ii,r/=128;for(;r&xl;)t[e++]=r&255|ii,r>>>=7;return t[e]=r|0,ci.bytes=e-n+1,t}var Bl=Ns,El=128,ai=127;function Ns(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Ns.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&ai)<<s:(i&ai)*Math.pow(2,s),s+=7}while(i>=El);return Ns.bytes=o-n,e}var Al=Math.pow(2,7),kl=Math.pow(2,14),Sl=Math.pow(2,21),Il=Math.pow(2,28),Nl=Math.pow(2,35),Cl=Math.pow(2,42),Tl=Math.pow(2,49),Ul=Math.pow(2,56),Rl=Math.pow(2,63),Ll=function(r){return r<Al?1:r<kl?2:r<Sl?3:r<Il?4:r<Nl?5:r<Cl?6:r<Tl?7:r<Ul?8:r<Rl?9:10},Hl={encode:wl,decode:Bl,encodingLength:Ll},Vl=Hl,mr=Vl;function yr(r,t=0){return[mr.decode(r,t),mr.decode.bytes]}function qe(r,t,e=0){return mr.encode(r,t,e),t}function je(r){return mr.encodingLength(r)}function St(r,t){let e=t.byteLength,n=je(r),s=n+je(e),o=new Uint8Array(s+e);return qe(r,o,0),qe(e,o,n),o.set(t,s),new $e(r,e,t,o)}function li(r){let t=Pt(r),[e,n]=yr(t),[s,o]=yr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new $e(e,s,i,t)}function ui(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ti(r.bytes,e.bytes)}}var $e=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function fi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return _l(e,Cs(r),t??st.encoder);default:return Dl(e,Cs(r),t??Fe.encoder)}}var hi=new WeakMap;function Cs(r){let t=hi.get(r);if(t==null){let e=new Map;return hi.set(r,e),e}return t}var Ht=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!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Kl)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=St(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&&ui(t.multihash,n.multihash)}toString(t){return fi(this,t)}toJSON(){return{"/":fi(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??di(n,s,o.bytes))}else if(e[Ml]===!0){let{version:n,multihash:s,code:o}=e,i=li(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!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=di(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,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=Pt(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 $e(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,h]=yr(t.subarray(e));return e+=h,f},s=n(),o=br;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 Cs(o).set(n,t),o}};function Ol(r,t){switch(r[0]){case"Q":{let e=t??st;return[st.prefix,e.decode(`${st.prefix}${r}`)]}case st.prefix:{let e=t??st;return[st.prefix,e.decode(r)]}case Fe.prefix:{let e=t??Fe;return[Fe.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function _l(r,t,e){let{prefix:n}=e;if(n!==st.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 Dl(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 br=112,Kl=18;function di(r,t,e){let n=je(r),s=n+je(t),o=new Uint8Array(s+e.byteLength);return qe(r,o,0),qe(t,o,n),o.set(e,s),o}var Ml=Symbol.for("@ipld/js-cid/CID");var Ts={};ft(Ts,{identity:()=>xr});var pi=0,Pl="identity",gi=Pt;function Fl(r){return St(pi,gi(r))}var xr={code:pi,name:Pl,encode:gi,digest:Fl};function Ft(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 ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function ql(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ge(r,...t){if(!ql(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function Yr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ze(r.outputLen),ze(r.blockLen)}function Ze(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 mi(r,t){Ge(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ae=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function ke(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function It(r,t){return r<<32-t|r>>>t}function Xr(r,t){return r<<t|r>>>32-t>>>0}var jl=async()=>{};async function yi(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 jl(),n+=o)}}function wi(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function oe(r){return typeof r=="string"&&(r=wi(r)),Ge(r),r}function Us(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ge(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var We=class{clone(){return this._cloneInto()}};function bi(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Je(r){let t=n=>r().update(oe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ye(r=32){if(Ae&&typeof Ae.getRandomValues=="function")return Ae.getRandomValues(new Uint8Array(r));if(Ae&&typeof Ae.randomBytes=="function")return Ae.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function $l(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)}function Qr(r,t,e){return r&t^~r&e}function tn(r,t,e){return r&t^r&e^t&e}var ie=class extends We{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=ke(this.buffer)}update(t){Ze(this);let{view:e,buffer:n,blockLen:s}=this;t=oe(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=ke(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ze(this),mi(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;$l(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=ke(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let 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 en=BigInt(4294967295),Rs=BigInt(32);function xi(r,t=!1){return t?{h:Number(r&en),l:Number(r>>Rs&en)}:{h:Number(r>>Rs&en)|0,l:Number(r&en)|0}}function zl(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}=xi(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Gl=(r,t)=>BigInt(r>>>0)<<Rs|BigInt(t>>>0),Zl=(r,t,e)=>r>>>e,Wl=(r,t,e)=>r<<32-e|t>>>e,Jl=(r,t,e)=>r>>>e|t<<32-e,Yl=(r,t,e)=>r<<32-e|t>>>e,Xl=(r,t,e)=>r<<64-e|t>>>e-32,Ql=(r,t,e)=>r>>>e-32|t<<64-e,tu=(r,t)=>t,eu=(r,t)=>r,ru=(r,t,e)=>r<<e|t>>>32-e,nu=(r,t,e)=>t<<e|r>>>32-e,su=(r,t,e)=>t<<e-32|r>>>64-e,ou=(r,t,e)=>r<<e-32|t>>>64-e;function iu(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var au=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),cu=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,lu=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),uu=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,fu=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),hu=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var du={fromBig:xi,split:zl,toBig:Gl,shrSH:Zl,shrSL:Wl,rotrSH:Jl,rotrSL:Yl,rotrBH:Xl,rotrBL:Ql,rotr32H:tu,rotr32L:eu,rotlSH:ru,rotlSL:nu,rotlBH:su,rotlBL:ou,add:iu,add3L:au,add3H:cu,add4L:lu,add4H:uu,add5H:hu,add5L:fu},_=du;var[pu,gu]=_.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ae=new Uint32Array(80),ce=new Uint32Array(80),Ls=class extends ie{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:y,Gl:w,Hh:m,Hl:d}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,y,w,m,d]}set(t,e,n,s,o,i,a,c,u,l,f,h,y,w,m,d){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=h|0,this.Gh=y|0,this.Gl=w|0,this.Hh=m|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)ae[p]=t.getUint32(e),ce[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let k=ae[p-15]|0,R=ce[p-15]|0,U=_.rotrSH(k,R,1)^_.rotrSH(k,R,8)^_.shrSH(k,R,7),I=_.rotrSL(k,R,1)^_.rotrSL(k,R,8)^_.shrSL(k,R,7),T=ae[p-2]|0,N=ce[p-2]|0,G=_.rotrSH(T,N,19)^_.rotrBH(T,N,61)^_.shrSH(T,N,6),F=_.rotrSL(T,N,19)^_.rotrBL(T,N,61)^_.shrSL(T,N,6),K=_.add4L(I,F,ce[p-7],ce[p-16]),Q=_.add4H(K,U,G,ae[p-7],ae[p-16]);ae[p]=Q|0,ce[p]=K|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:y,Fl:w,Gh:m,Gl:d,Hh:b,Hl:B}=this;for(let p=0;p<80;p++){let k=_.rotrSH(f,h,14)^_.rotrSH(f,h,18)^_.rotrBH(f,h,41),R=_.rotrSL(f,h,14)^_.rotrSL(f,h,18)^_.rotrBL(f,h,41),U=f&y^~f&m,I=h&w^~h&d,T=_.add5L(B,R,I,gu[p],ce[p]),N=_.add5H(T,b,k,U,pu[p],ae[p]),G=T|0,F=_.rotrSH(n,s,28)^_.rotrBH(n,s,34)^_.rotrBH(n,s,39),K=_.rotrSL(n,s,28)^_.rotrBL(n,s,34)^_.rotrBL(n,s,39),Q=n&o^n&a^o&a,E=s&i^s&c^i&c;b=m|0,B=d|0,m=y|0,d=w|0,y=f|0,w=h|0,{h:f,l:h}=_.add(u|0,l|0,N|0,G|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let C=_.add3L(G,K,E);n=_.add3H(C,N,F,Q),s=C|0}({h:n,l:s}=_.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=_.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=_.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=_.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=_.add(this.Eh|0,this.El|0,f|0,h|0),{h:y,l:w}=_.add(this.Fh|0,this.Fl|0,y|0,w|0),{h:m,l:d}=_.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:b,l:B}=_.add(this.Hh|0,this.Hl|0,b|0,B|0),this.set(n,s,o,i,a,c,u,l,f,h,y,w,m,d,b,B)}roundClean(){ae.fill(0),ce.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var le=Je(()=>new Ls);var sn={};ft(sn,{aInRange:()=>bt,abool:()=>Nt,abytes:()=>Xe,bitGet:()=>vu,bitLen:()=>_s,bitMask:()=>Br,bitSet:()=>Bu,bytesToHex:()=>jt,bytesToNumberBE:()=>$t,bytesToNumberLE:()=>fe,concatBytes:()=>zt,createHmacDrbg:()=>Ds,ensureBytes:()=>J,equalBytes:()=>bu,hexToBytes:()=>Ie,hexToNumber:()=>Os,inRange:()=>vr,isBytes:()=>ue,memoized:()=>Ce,notImplemented:()=>Au,numberToBytesBE:()=>he,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>Se,numberToVarBytesBE:()=>wu,utf8ToBytes:()=>xu,validateObject:()=>Vt});var rn=BigInt(0),nn=BigInt(1),mu=BigInt(2);function ue(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Xe(r){if(!ue(r))throw new Error("Uint8Array expected")}function Nt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var yu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function jt(r){Xe(r);let t="";for(let e=0;e<r.length;e++)t+=yu[r[e]];return t}function Se(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Os(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?rn:BigInt("0x"+r)}var qt={_0:48,_9:57,A:65,F:70,a:97,f:102};function vi(r){if(r>=qt._0&&r<=qt._9)return r-qt._0;if(r>=qt.A&&r<=qt.F)return r-(qt.A-10);if(r>=qt.a&&r<=qt.f)return r-(qt.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("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=vi(r.charCodeAt(o)),a=vi(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 $t(r){return Os(jt(r))}function fe(r){return Xe(r),Os(jt(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 wu(r){return Ie(Se(r))}function J(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(ue(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+" of length "+e+" expected, got "+s);return n}function zt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Xe(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function bu(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 xu(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Hs=r=>typeof r=="bigint"&&rn<=r;function vr(r,t,e){return Hs(r)&&Hs(t)&&Hs(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!vr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function _s(r){let t;for(t=0;r>rn;r>>=nn,t+=1);return t}function vu(r,t){return r>>BigInt(t)&nn}function Bu(r,t,e){return r|(e?nn:rn)<<BigInt(t)}var Br=r=>(mu<<BigInt(r-1))-nn,Vs=r=>new Uint8Array(r),Bi=r=>Uint8Array.from(r);function Ds(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=Vs(r),s=Vs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Vs())=>{s=a(Bi([0]),f),n=a(),f.length!==0&&(s=a(Bi([1]),f),n=a())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,h=[];for(;f<t;){n=a();let y=n.slice();h.push(y),f+=n.length}return zt(...h)};return(f,h)=>{i(),c(f);let y;for(;!(y=h(u()));)c();return i(),y}}var Eu={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"||ue(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=Eu[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};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 Au=()=>{throw new Error("not implemented")};function Ce(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var tt=BigInt(0),Z=BigInt(1),Te=BigInt(2),ku=BigInt(3),Ks=BigInt(4),Ei=BigInt(5),Ai=BigInt(8),Su=BigInt(9),Iu=BigInt(16);function $(r,t){let e=r%t;return e>=tt?e:t+e}function Nu(r,t,e){if(t<tt)throw new Error("invalid exponent, negatives unsupported");if(e<=tt)throw new Error("invalid modulus");if(e===Z)return tt;let n=Z;for(;t>tt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function W(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function on(r,t){if(r===tt)throw new Error("invert: expected non-zero number");if(t<=tt)throw new Error("invert: expected positive modulus, got "+t);let e=$(r,t),n=t,s=tt,o=Z,i=Z,a=tt;for(;e!==tt;){let u=n/e,l=n%e,f=s-i*u,h=o-a*u;n=e,e=l,s=i,o=a,i=f,a=h}if(n!==Z)throw new Error("invert: does not exist");return $(s,t)}function Cu(r){let t=(r-Z)/Te,e,n,s;for(e=r-Z,n=0;e%Te===tt;e/=Te,n++);for(s=Te;s<r&&Nu(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/Ks;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+Z)/Te;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),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let m=a.sqr(h);y<u&&!a.eql(m,a.ONE);y++)m=a.sqr(m);let w=a.pow(l,Z<<BigInt(u-y-1));l=a.sqr(w),f=a.mul(f,w),h=a.mul(h,l),u=y}return f}}function Tu(r){if(r%Ks===ku){let t=(r+Z)/Ks;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%Ai===Ei){let t=(r-Ei)/Ai;return function(n,s){let o=n.mul(s,Te),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Te),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%Iu,Cu(r)}var ki=(r,t)=>($(r,t)&Z)===Z,Uu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ms(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Uu.reduce((n,s)=>(n[s]="function",n),t);return Vt(r,e)}function Ru(r,t,e){if(e<tt)throw new Error("invalid exponent, negatives unsupported");if(e===tt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>tt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Lu(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 Ps(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function de(r,t,e=!1,n={}){if(r<=tt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=Ps(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Br(s),ZERO:tt,ONE:Z,create:c=>$(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&Z)===Z,neg:c=>$(-c,r),eql:(c,u)=>c===u,sqr:c=>$(c*c,r),add:(c,u)=>$(c+u,r),sub:(c,u)=>$(c-u,r),mul:(c,u)=>$(c*u,r),pow:(c,u)=>Ru(a,c,u),div:(c,u)=>$(c*on(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>on(c,r),sqrt:n.sqrt||(c=>(i||(i=Tu(r)),i(a,c))),invertBatch:c=>Lu(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("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?fe(c):$t(c)}});return Object.freeze(a)}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 Fs(r){let t=Si(r);return t+Math.ceil(t/2)}function Ii(r,t,e=!1){let n=r.length,s=Si(t),o=Fs(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?fe(r):$t(r),a=$(i,t-Z)+Z;return e?Ne(a,s):he(a,s)}var Ni=BigInt(0),an=BigInt(1);function qs(r,t){let e=t.negate();return r?e:t}function Ci(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function js(r,t){Ci(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function Hu(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Vu(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var $s=new WeakMap,Ti=new WeakMap;function zs(r){return Ti.get(r)||1}function cn(r,t){return{constTimeNegate:qs,hasPrecomputes(e){return zs(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Ni;)n&an&&(s=s.add(o)),o=o.double(),n>>=an;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=js(n,t),i=[],a=e,c=a;for(let u=0;u<s;u++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=js(e,t),a=r.ZERO,c=r.BASE,u=BigInt(2**e-1),l=2**e,f=BigInt(e);for(let h=0;h<o;h++){let y=h*i,w=Number(s&u);s>>=f,w>i&&(w-=l,s+=an);let m=y,d=y+Math.abs(w)-1,b=h%2!==0,B=w<0;w===0?c=c.add(qs(b,n[m])):a=a.add(qs(B,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=js(e,t),c=BigInt(2**e-1),u=2**e,l=BigInt(e);for(let f=0;f<i;f++){let h=f*a;if(s===Ni)break;let y=Number(s&c);if(s>>=l,y>a&&(y-=u,s+=an),y===0)continue;let w=n[h+Math.abs(y)-1];y<0&&(w=w.negate()),o=o.add(w)}return o},getPrecomputes(e,n,s){let o=$s.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&$s.set(n,s(o))),o},wNAFCached(e,n,s){let o=zs(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=zs(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){Ci(n,t),Ti.set(e,n),$s.delete(e)}}}function ln(r,t,e,n){if(Hu(e,r),Vu(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=_s(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),u=Math.floor((t.BITS-1)/i)*i,l=s;for(let f=u;f>=0;f-=i){c.fill(s);for(let y=0;y<n.length;y++){let w=n[y],m=Number(w>>BigInt(f)&BigInt(a));c[m]=c[m].add(e[y])}let h=s;for(let y=c.length-1,w=s;y>0;y--)w=w.add(c[y]),h=h.add(w);if(l=l.add(h),f!==0)for(let y=0;y<i;y++)l=l.double()}return l}function Er(r){return Ms(r.Fp),Vt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ps(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ct=BigInt(0),xt=BigInt(1),un=BigInt(2),Ou=BigInt(8),_u={zip215:!0};function Du(r){let t=Er(r);return Vt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ui(r){let t=Du(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=un<<BigInt(a*8)-xt,l=e.create,f=de(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:Ct}}}),y=t.adjustScalarBytes||(x=>x),w=t.domain||((x,g,v)=>{if(Nt("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function m(x,g){bt("coordinate "+x,g,Ct,u)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let b=Ce((x,g)=>{let{ex:v,ey:S,ez:L}=x,H=x.is0();g==null&&(g=H?Ou:e.inv(L));let D=l(v*g),P=l(S*g),O=l(L*g);if(H)return{x:Ct,y:xt};if(O!==xt)throw new Error("invZ was invalid");return{x:D,y:P}}),B=Ce(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:S,ey:L,ez:H,et:D}=x,P=l(S*S),O=l(L*L),j=l(H*H),z=l(j*j),rt=l(P*g),nt=l(j*l(rt+O)),at=l(z+l(v*l(P*O)));if(nt!==at)throw new Error("bad point: equation left != right (1)");let ut=l(S*L),yt=l(H*D);if(ut!==yt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,S,L){this.ex=g,this.ey=v,this.ez=S,this.et=L,m("x",g),m("y",v),m("z",S),m("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:S}=g||{};return m("x",v),m("y",S),new p(v,S,xt,l(v*S))}static normalizeZ(g){let v=e.invertBatch(g.map(S=>S.ez));return g.map((S,L)=>S.toAffine(v[L])).map(p.fromAffine)}static msm(g,v){return ln(p,f,g,v)}_setWindowSize(g){U.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:v,ey:S,ez:L}=this,{ex:H,ey:D,ez:P}=g,O=l(v*P),j=l(H*L),z=l(S*P),rt=l(D*L);return O===j&&z===rt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:S,ez:L}=this,H=l(v*v),D=l(S*S),P=l(un*l(L*L)),O=l(g*H),j=v+S,z=l(l(j*j)-H-D),rt=O+D,nt=rt-P,at=O-D,ut=l(z*nt),yt=l(rt*at),pt=l(z*at),Lt=l(nt*rt);return new p(ut,yt,Lt,pt)}add(g){d(g);let{a:v,d:S}=t,{ex:L,ey:H,ez:D,et:P}=this,{ex:O,ey:j,ez:z,et:rt}=g;if(v===BigInt(-1)){let jo=l((H-L)*(j+O)),$o=l((H+L)*(j-O)),bs=l($o-jo);if(bs===Ct)return this.double();let zo=l(D*un*rt),Go=l(P*un*z),Zo=Go+zo,Wo=$o+jo,Jo=Go-zo,Gc=l(Zo*bs),Zc=l(Wo*Jo),Wc=l(Zo*Jo),Jc=l(bs*Wo);return new p(Gc,Zc,Jc,Wc)}let nt=l(L*O),at=l(H*j),ut=l(P*S*rt),yt=l(D*z),pt=l((L+H)*(O+j)-nt-at),Lt=yt-ut,Mt=yt+ut,fr=l(at-v*nt),qc=l(pt*Lt),jc=l(Mt*fr),$c=l(pt*fr),zc=l(Lt*Mt);return new p(qc,jc,zc,$c)}subtract(g){return this.add(g.negate())}wNAF(g){return U.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;bt("scalar",v,xt,n);let{p:S,f:L}=this.wNAF(v);return p.normalizeZ([S,L])[0]}multiplyUnsafe(g,v=p.ZERO){let S=g;return bt("scalar",S,Ct,n),S===Ct?R:this.is0()||S===xt?this:U.wNAFCachedUnsafe(this,S,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return U.unsafeLadder(this,n).is0()}toAffine(g){return b(this,g)}clearCofactor(){let{h:g}=t;return g===xt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:S,a:L}=t,H=e.BYTES;g=J("pointHex",g,H),Nt("zip215",v);let D=g.slice(),P=g[H-1];D[H-1]=P&-129;let O=fe(D),j=v?u:e.ORDER;bt("pointHex.y",O,Ct,j);let z=l(O*O),rt=l(z-xt),nt=l(S*z-L),{isValid:at,value:ut}=h(rt,nt);if(!at)throw new Error("Point.fromHex: invalid y coordinate");let yt=(ut&xt)===xt,pt=(P&128)!==0;if(!v&&ut===Ct&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==yt&&(ut=l(-ut)),p.fromAffine({x:ut,y:O})}static fromPrivateKey(g){return N(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),S=Ne(v,e.BYTES);return S[S.length-1]|=g&xt?128:0,S}toHex(){return jt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,xt,l(t.Gx*t.Gy)),p.ZERO=new p(Ct,xt,xt,Ct);let{BASE:k,ZERO:R}=p,U=cn(p,a*8);function I(x){return $(x,n)}function T(x){return I(fe(x))}function N(x){let g=e.BYTES;x=J("private key",x,g);let v=J("hashed private key",o(x),2*g),S=y(v.slice(0,g)),L=v.slice(g,2*g),H=T(S),D=k.multiply(H),P=D.toRawBytes();return{head:S,prefix:L,scalar:H,point:D,pointBytes:P}}function G(x){return N(x).pointBytes}function F(x=new Uint8Array,...g){let v=zt(...g);return T(o(w(v,J("context",x),!!s)))}function K(x,g,v={}){x=J("message",x),s&&(x=s(x));let{prefix:S,scalar:L,pointBytes:H}=N(g),D=F(v.context,S,x),P=k.multiply(D).toRawBytes(),O=F(v.context,P,H,x),j=I(D+O*L);bt("signature.s",j,Ct,n);let z=zt(P,Ne(j,e.BYTES));return J("result",z,e.BYTES*2)}let Q=_u;function E(x,g,v,S=Q){let{context:L,zip215:H}=S,D=e.BYTES;x=J("signature",x,2*D),g=J("message",g),v=J("publicKey",v,D),H!==void 0&&Nt("zip215",H),s&&(g=s(g));let P=fe(x.slice(D,2*D)),O,j,z;try{O=p.fromHex(v,H),j=p.fromHex(x.slice(0,D),H),z=k.multiplyUnsafe(P)}catch{return!1}if(!H&&O.isSmallOrder())return!1;let rt=F(L,j.toRawBytes(),O.toRawBytes(),g);return j.add(O.multiplyUnsafe(rt)).subtract(z).clearCofactor().equals(p.ZERO)}return k._setWindowSize(8),{CURVE:t,getPublicKey:G,sign:K,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var Gs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ri=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Gd=BigInt(0),Ku=BigInt(1),Li=BigInt(2),Zd=BigInt(3),Mu=BigInt(5),Pu=BigInt(8);function Fu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Gs,a=r*r%o*r%o,c=W(a,Li,o)*a%o,u=W(c,Ku,o)*r%o,l=W(u,Mu,o)*u%o,f=W(l,t,o)*l%o,h=W(f,e,o)*f%o,y=W(h,n,o)*h%o,w=W(y,s,o)*y%o,m=W(w,s,o)*y%o,d=W(m,t,o)*l%o;return{pow_p_5_8:W(d,Li,o)*r%o,b2:a}}function qu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ju(r,t){let e=Gs,n=$(t*t*t,e),s=$(n*n*t,e),o=Fu(r*s).pow_p_5_8,i=$(r*n*o,e),a=$(t*i*i,e),c=i,u=$(i*Ri,e),l=a===r,f=a===$(-r,e),h=a===$(-r*Ri,e);return l&&(i=c),(f||h)&&(i=u),ki(i,e)&&(i=$(-i,e)),{isValid:l||f,value:i}}var $u=de(Gs,void 0,!0),zu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:$u,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Pu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:le,randomBytes:Ye,adjustScalarBytes:qu,uvRatio:ju},Zs=Ui(zu);var Ar=32,Gt=64,Gu=32;function Hi(r,t){let e=r.subarray(0,Gu);return Zs.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Vi(r,t,e){return Zs.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var fn=class{type="Ed25519";raw;constructor(t){this.raw=Sr(t,Ar)}toMultihash(){return xr.digest(hn(this))}toCID(){return Ht.createV1(114,this.toMultihash())}toString(){return st.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}verify(t,e){return Vi(this.raw,e,t)}},kr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Sr(t,Gt),this.publicKey=new fn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}sign(t){return Hi(this.raw,t)}};function Ws(r){if(r.length>Gt){r=Sr(r,Gt+Ar);let n=r.subarray(0,Gt),s=r.subarray(Gt,r.length);return new kr(n,s)}r=Sr(r,Gt);let t=r.subarray(0,Gt),e=r.subarray(Ar);return new kr(t,e)}function Sr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new V(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Ot(r=0){return new Uint8Array(r)}var Zu=Math.pow(2,7),Wu=Math.pow(2,14),Ju=Math.pow(2,21),_i=Math.pow(2,28),Di=Math.pow(2,35),Ki=Math.pow(2,42),Mi=Math.pow(2,49),gt=128,pe=127;function Ir(r){if(r<Zu)return 1;if(r<Wu)return 2;if(r<Ju)return 3;if(r<_i)return 4;if(r<Di)return 5;if(r<Ki)return 6;if(r<Mi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Pi(r,t,e=0){switch(Ir(r)){case 8:t[e++]=r&255|gt,r/=128;case 7:t[e++]=r&255|gt,r/=128;case 6:t[e++]=r&255|gt,r/=128;case 5:t[e++]=r&255|gt,r/=128;case 4:t[e++]=r&255|gt,r>>>=7;case 3:t[e++]=r&255|gt,r>>>=7;case 2:t[e++]=r&255|gt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Fi(r,t){let e=r[t],n=0;if(n+=e&pe,e<gt||(e=r[t+1],n+=(e&pe)<<7,e<gt)||(e=r[t+2],n+=(e&pe)<<14,e<gt)||(e=r[t+3],n+=(e&pe)<<21,e<gt)||(e=r[t+4],n+=(e&pe)*_i,e<gt)||(e=r[t+5],n+=(e&pe)*Di,e<gt)||(e=r[t+6],n+=(e&pe)*Ki,e<gt)||(e=r[t+7],n+=(e&pe)*Mi,e<gt))return n;throw new RangeError("Could not decode varint")}var Js=new Float32Array([-0]),ge=new Uint8Array(Js.buffer);function qi(r,t,e){Js[0]=r,t[e]=ge[0],t[e+1]=ge[1],t[e+2]=ge[2],t[e+3]=ge[3]}function ji(r,t){return ge[0]=r[t],ge[1]=r[t+1],ge[2]=r[t+2],ge[3]=r[t+3],Js[0]}var Ys=new Float64Array([-0]),ht=new Uint8Array(Ys.buffer);function $i(r,t,e){Ys[0]=r,t[e]=ht[0],t[e+1]=ht[1],t[e+2]=ht[2],t[e+3]=ht[3],t[e+4]=ht[4],t[e+5]=ht[5],t[e+6]=ht[6],t[e+7]=ht[7]}function zi(r,t){return ht[0]=r[t],ht[1]=r[t+1],ht[2]=r[t+2],ht[3]=r[t+3],ht[4]=r[t+4],ht[5]=r[t+5],ht[6]=r[t+6],ht[7]=r[t+7],Ys[0]}var Yu=BigInt(Number.MAX_SAFE_INTEGER),Xu=BigInt(Number.MIN_SAFE_INTEGER),Et=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 Ue;if(t<Yu&&t>Xu)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>Gi&&(s=0n,++n>Gi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ue;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):Ue}},Ue=new Et(0,0);Ue.toBigInt=function(){return 0n};Ue.zzEncode=Ue.zzDecode=function(){return this};Ue.length=function(){return 1};var Gi=4294967296n;function Zi(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 Wi(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 Xs(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 Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function dn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Qs=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,Tt(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 Tt(this,4);return dn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return dn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=ji(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=zi(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 Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Wi(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(this);while((this.buf[this.pos++]&128)!==0);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 Et(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 Tt(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 Tt(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 Tt(this,8);let t=dn(this.buf,this.pos+=4),e=dn(this.buf,this.pos+=4);return new Et(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Fi(this.buf,this.pos);return this.pos+=Ir(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function to(r){return new Qs(r instanceof Uint8Array?r:r.subarray())}function pn(r,t,e){let n=to(r);return t.decode(n,void 0,e)}var eo={};ft(eo,{base10:()=>Qu});var Qu=se({prefix:"9",name:"base10",alphabet:"0123456789"});var ro={};ft(ro,{base16:()=>tf,base16upper:()=>ef});var tf=Y({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ef=Y({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var no={};ft(no,{base2:()=>rf});var rf=Y({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var so={};ft(so,{base256emoji:()=>cf});var Yi=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}"),nf=Yi.reduce((r,t,e)=>(r[e]=t,r),[]),sf=Yi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function of(r){return r.reduce((t,e)=>(t+=nf[e],t),"")}function af(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=sf[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var cf=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:of,decode:af});var oo={};ft(oo,{base64:()=>Re,base64pad:()=>lf,base64url:()=>uf,base64urlpad:()=>ff});var Re=Y({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),lf=Y({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),uf=Y({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ff=Y({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var io={};ft(io,{base8:()=>hf});var hf=Y({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ao={};ft(ao,{identity:()=>df});var df=Pe({prefix:"\0",name:"identity",encode:r=>ri(r),decode:r=>ei(r)});var C0=new TextEncoder,T0=new TextDecoder;var uo={};ft(uo,{sha256:()=>Qe,sha512:()=>mf});function lo({name:r,code:t,encode:e}){return new co(r,t,e)}var co=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?St(this.code,e):e.then(n=>St(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Qi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Qe=lo({name:"sha2-256",code:18,encode:Qi("SHA-256")}),mf=lo({name:"sha2-512",code:19,encode:Qi("SHA-512")});var fo={...ao,...no,...io,...eo,...ro,...Ss,...Is,...ks,...oo,...so},F0={...uo,...Ts};function ea(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ta=ea("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ho=ea("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=Ot(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),yf={utf8:ta,"utf-8":ta,hex:fo.base16,latin1:ho,ascii:ho,binary:ho,...fo},gn=yf;function q(r,t="utf8"){let e=gn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function po(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Ot(i);s+i>t&&(n=Ot(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Le=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function go(){}var yo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},wf=po();function bf(r){return globalThis.Buffer!=null?Ot(r):wf(r)}var Cr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Le(go,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Le(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new wo((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(mn,10,Et.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Et.fromBigInt(t);return this._push(mn,e.length(),e)}uint64Number(t){return this._push(Pi,Ir(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Et.fromBigInt(t).zzEncode();return this._push(mn,e.length(),e)}sint64Number(t){let e=Et.fromNumber(t).zzEncode();return this._push(mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(mo,1,t?1:0)}fixed32(t){return this._push(Nr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Et.fromBigInt(t);return this._push(Nr,4,e.lo)._push(Nr,4,e.hi)}fixed64Number(t){let e=Et.fromNumber(t);return this._push(Nr,4,e.lo)._push(Nr,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(qi,4,t)}double(t){return this._push($i,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(mo,1,0):this.uint32(e)._push(vf,e,t)}string(t){let e=Zi(t);return e!==0?this.uint32(e)._push(Xs,e,t):this._push(mo,1,0)}fork(){return this.states=new yo(this),this.head=this.tail=new Le(go,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 Le(go,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=bf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function mo(r,t,e){t[e]=r&255}function xf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var wo=class extends Le{next;constructor(t,e){super(xf,t,e),this.next=void 0}};function mn(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 Nr(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 vf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Cr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Bf,t,r),this},Cr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ef,t,r),this});function Bf(r,t,e){t.set(r,e)}function Ef(r,t,e){r.length<40?Xs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function bo(){return new Cr}function yn(r,t){let e=bo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function wn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function xo(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 wn("enum",tr.VARINT,e,n)}function bn(r,t){return wn("message",tr.LENGTH_DELIMITED,r,t)}var ot;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(ot||(ot={}));var vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(vo||(vo={}));(function(r){r.codec=()=>xo(vo)})(ot||(ot={}));var me;(function(r){let t;r.codec=()=>(t==null&&(t=bn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ot.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=ot.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>yn(e,r.codec()),r.decode=(e,n)=>pn(e,r.codec(),n)})(me||(me={}));var Tr;(function(r){let t;r.codec=()=>(t==null&&(t=bn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ot.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=ot.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>yn(e,r.codec()),r.decode=(e,n)=>pn(e,r.codec(),n)})(Tr||(Tr={}));var Kr={};ft(Kr,{MAX_RSA_KEY_SIZE:()=>cs,generateRSAKeyPair:()=>Ya,jwkToJWKKeyPair:()=>Xa,jwkToPkcs1:()=>Df,jwkToPkix:()=>To,jwkToRSAPrivateKey:()=>Ja,pkcs1ToJwk:()=>Ga,pkcs1ToRSAPrivateKey:()=>ls,pkixToJwk:()=>Za,pkixToRSAPublicKey:()=>Wa});var Af=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]),ye=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),we=new Uint32Array(64),Bo=class extends ie{constructor(){super(64,32,8,!1),this.A=ye[0]|0,this.B=ye[1]|0,this.C=ye[2]|0,this.D=ye[3]|0,this.E=ye[4]|0,this.F=ye[5]|0,this.G=ye[6]|0,this.H=ye[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)we[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=we[f-15],y=we[f-2],w=It(h,7)^It(h,18)^h>>>3,m=It(y,17)^It(y,19)^y>>>10;we[f]=m+we[f-7]+w+we[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=It(a,6)^It(a,11)^It(a,25),y=l+h+Qr(a,c,u)+Af[f]+we[f]|0,m=(It(n,2)^It(n,13)^It(n,22))+tn(n,s,o)|0;l=u,u=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+m|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(){we.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var be=Je(()=>new Bo);var M=xs(na());function He(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 xe(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 Bn(...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 Ao(){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=He(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,He(o,8)-n}function sa(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=xe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(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 oa(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 vt(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 Ep=Math.log(2);function En(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ko(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 Qt(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 Rr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ko(this.items)}},Ur=[new Uint8Array([1])],ia="0123456789";var nr="",Ut=new ArrayBuffer(0),So=new Uint8Array(0),Lr="EndOfContent",ca="OCTET STRING",la="BIT STRING";function te(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?M.BufferSourceConverter.toUint8Array(o.valueHex):So}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(!Qt(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:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Wt=class{constructor({blockLength:t=0,error:e=nr,warnings:n=[],valueBeforeDecode:s=So}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.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:M.Convert.ToHex(this.valueBeforeDecodeView)}}};Wt.NAME="baseBlock";var dt=class extends Wt{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'")}};dt.NAME="valueBlock";var An=class extends te(Wt){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?M.BufferSourceConverter.toUint8Array(t.valueHex):So,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=xe(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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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 h=new Uint8Array(l);for(let y=0;y<u.length;y++)h[y]=u[y];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=He(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}}};An.NAME="identificationBlock";var kn=class extends Wt{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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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=He(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=xe(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}}};kn.NAME="lengthBlock";var A={},ct=class extends Wt{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 An(s),this.lenBlock=new kn(s),this.valueBlock=o?new o(s):new dt(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 Rr;e||ua(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():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.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 oa(e,n)}};ct.NAME="BaseBlock";function ua(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)ua(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Sn=class extends ct{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}'`}};Sn.NAME="BaseStringBlock";var In=class extends te(dt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};In.NAME="PrimitiveValueBlock";var fa,Nn=class extends ct{constructor(t={}){super(t,In),this.idBlock.isConstructed=!1}};fa=Nn;A.Primitive=fa;Nn.NAME="PRIMITIVE";function Lf(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 as(r,t=0,e=r.length){let n=t,s=new ct({},dt),o=new Wt;if(!Qt(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=ct;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let u=s.idBlock.isConstructed?new A.Constructed:new A.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?A.Constructed:A.Primitive}return s=Lf(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 Ve(r){if(!r.byteLength){let t=new ct({},dt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return as(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Hf(r,t){return r?1:t}var _t=class extends dt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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(;Hf(this.isIndefiniteForm,n)>0;){let i=as(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===Lr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Lr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Rr;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}};_t.NAME="ConstructedValueBlock";var ha,ve=class extends ct{constructor(t={}){super(t,_t),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} :`}};ha=ve;A.Constructed=ha;ve.NAME="CONSTRUCTED";var Cn=class extends dt{fromBER(t,e,n){return e}toBER(t){return Ut}};Cn.override="EndOfContentValueBlock";var da,Tn=class extends ct{constructor(t={}){super(t,Cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};da=Tn;A.EndOfContent=da;Tn.NAME=Lr;var pa,Jt=class extends ct{constructor(t={}){super(t,dt),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}`}};pa=Jt;A.Null=pa;Jt.NAME="NULL";var Un=class extends te(dt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.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=M.BufferSourceConverter.toUint8Array(t);return Qt(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,Ao.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Un.NAME="BooleanValueBlock";var ga,Rn=class extends ct{constructor(t={}){super(t,Un),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}`}};ga=Rn;A.Boolean=ga;Rn.NAME="BOOLEAN";var Ln=class extends te(_t){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=_t.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===Lr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==ca)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?_t.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Ln.NAME="OctetStringValueBlock";var ma,Yt=class r extends ct{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},Ln),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=as(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?ve.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.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 M.BufferSourceConverter.concat(t)}};ma=Yt;A.OctetString=ma;Yt.NAME=ca;var Hn=class extends te(_t){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=_t.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Lr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==la)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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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=as(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 _t.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}}};Hn.NAME="BitStringValueBlock";var ya,rr=class extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Hn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.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)}`}}};ya=rr;A.BitString=ya;rr.NAME=la;var wa;function Vf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let h=l;h>=0;h--,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=Bn(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=Bn(e,o)),o}function aa(r){if(r>=Ur.length)for(let t=Ur.length;t<=r;t++){let e=new Uint8Array([0]),n=Ur[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=Bn(e,n)),Ur.push(n)}return Ur[r]}function Of(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 Hr=class extends te(dt){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=Ao.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(sa(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=Of(aa(n),e),i="-";break;default:e=Vf(e,aa(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=ia.charAt(e[c]));return a===!1&&(i+=ia.charAt(0)),i}};wa=Hr;Hr.NAME="IntegerValueBlock";Object.defineProperty(wa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ba,X=class r extends ct{constructor(t={}){super(t,Hr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return En(),BigInt(this.valueBlock.toString())}static fromBigInt(t){En();let e=BigInt(t),n=new Rr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new 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()}`}};ba=X;A.Integer=ba;X.NAME="INTEGER";var xa,Vn=class extends X{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};xa=Vn;A.Enumerated=xa;Vn.NAME="ENUMERATED";var Vr=class extends te(dt){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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){En();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=xe(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=M.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}}};Vr.NAME="sidBlock";var On=class extends dt{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.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 ko(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 Vr;if(s>Number.MAX_SAFE_INTEGER){En();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}};On.NAME="ObjectIdentifierValueBlock";var va,kt=class extends ct{constructor(t={}){super(t,On),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()}}};va=kt;A.ObjectIdentifier=va;kt.NAME="OBJECT IDENTIFIER";var Or=class extends te(Wt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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=He(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=xe(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=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Or.NAME="relativeSidBlock";var _n=class extends dt{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 Or;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 ko(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 Or;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}};_n.NAME="RelativeObjectIdentifierValueBlock";var Ba,Dn=class extends ct{constructor(t={}){super(t,_n),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()}}};Ba=Dn;A.RelativeObjectIdentifier=Ba;Dn.NAME="RelativeObjectIdentifier";var Ea,et=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ea=et;A.Sequence=Ea;et.NAME="SEQUENCE";var Aa,Kn=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Aa=Kn;A.Set=Aa;Kn.NAME="SET";var Mn=class extends te(dt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=nr}toJSON(){return{...super.toJSON(),value:this.value}}};Mn.NAME="StringValueBlock";var Pn=class extends Mn{};Pn.NAME="SimpleStringValueBlock";var mt=class extends Sn{constructor({...t}={}){super(t,Pn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.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}};mt.NAME="SIMPLE STRING";var Fn=class extends mt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Fn.NAME="Utf8StringValueBlock";var ka,Xt=class extends Fn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ka=Xt;A.Utf8String=ka;Xt.NAME="UTF8String";var qn=class extends mt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};qn.NAME="BmpStringValueBlock";var Sa,jn=class extends qn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Sa=jn;A.BmpString=Sa;jn.NAME="BMPString";var $n=class extends mt{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=xe(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}};$n.NAME="UniversalStringValueBlock";var Ia,zn=class extends $n{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ia=zn;A.UniversalString=Ia;zn.NAME="UniversalString";var Na,Gn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Na=Gn;A.NumericString=Na;Gn.NAME="NumericString";var Ca,Zn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ca=Zn;A.PrintableString=Ca;Zn.NAME="PrintableString";var Ta,Wn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ta=Wn;A.TeletexString=Ta;Wn.NAME="TeletexString";var Ua,Jn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ua=Jn;A.VideotexString=Ua;Jn.NAME="VideotexString";var Ra,Yn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ra=Yn;A.IA5String=Ra;Yn.NAME="IA5String";var La,Xn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};La=Xn;A.GraphicString=La;Xn.NAME="GraphicString";var Ha,_r=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ha=_r;A.VisibleString=Ha;_r.NAME="VisibleString";var Va,Qn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Va=Qn;A.GeneralString=Va;Qn.NAME="GeneralString";var Oa,ts=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Oa=ts;A.CharacterString=Oa;ts.NAME="CharacterString";var _a,Dr=class extends _r{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,M.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]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(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}}};_a=Dr;A.UTCTime=_a;Dr.NAME="UTCTime";var Da,es=class extends Dr{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,h=n.indexOf("+"),y="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(y=n.substring(h+1),n=n.substring(0,h),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(y.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*w,y.length===4){if(w=parseInt(y.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=f*w}}}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(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Da=es;A.GeneralizedTime=Da;es.NAME="GeneralizedTime";var Ka,rs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ka=rs;A.DATE=Ka;rs.NAME="DATE";var Ma,ns=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ma=ns;A.TimeOfDay=Ma;ns.NAME="TimeOfDay";var Pa,ss=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Pa=ss;A.DateTime=Pa;ss.NAME="DateTime";var Fa,os=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Fa=os;A.Duration=Fa;os.NAME="Duration";var qa,is=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};qa=is;A.TIME=qa;is.NAME="TIME";function Bt(r,t="utf8"){let e=gn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function Oe(r){if(isNaN(r)||r<=0)throw new V("random bytes length must be a Number bigger than 0");return Ye(r)}async function ja(r){let t=await wt.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 _f(t);return{privateKey:e[0],publicKey:e[1]}}async function $a(r,t){let e=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await wt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function za(r,t,e){let n=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return wt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function _f(r){if(r.privateKey==null||r.publicKey==null)throw new V("Private and public key are required");return Promise.all([wt.get().subtle.exportKey("jwk",r.privateKey),wt.get().subtle.exportKey("jwk",r.publicKey)])}function No(r){if(r.kty!=="RSA")throw new V("invalid key type");if(r.n==null)throw new V("invalid key modulus");return q(r.n,"base64url").length*8}var sr=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Kr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Ht.createV1(114,this._multihash)}toString(){return st.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}verify(t,e){return za(this._key,e,t)}},Mr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Kr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}sign(t){return $a(this._key,t)}};var cs=8192,Co=18;function Ga(r){let{result:t}=Ve(r),e=t.valueBlock.value;return{n:Dt(e[1]),e:Dt(e[2]),d:Dt(e[3]),p:Dt(e[4]),q:Dt(e[5]),dp:Dt(e[6]),dq:Dt(e[7]),qi:Dt(e[8]),kty:"RSA",alg:"RS256"}}function Df(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new V("JWK was missing components");let e=new et({value:[new X({value:0}),X.fromBigInt(Kt(q(r.n,"base64url"))),X.fromBigInt(Kt(q(r.e,"base64url"))),X.fromBigInt(Kt(q(r.d,"base64url"))),X.fromBigInt(Kt(q(r.p,"base64url"))),X.fromBigInt(Kt(q(r.q,"base64url"))),X.fromBigInt(Kt(q(r.dp,"base64url"))),X.fromBigInt(Kt(q(r.dq,"base64url"))),X.fromBigInt(Kt(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Za(r){let{result:t}=Ve(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Dt(e[0]),e:Dt(e[1])}}function To(r){if(r.n==null||r.e==null)throw new V("JWK was missing components");let e=new et({value:[new et({value:[new kt({value:"1.2.840.113549.1.1.1"}),new Jt]}),new rr({valueHex:new et({value:[X.fromBigInt(Kt(q(r.n,"base64url"))),X.fromBigInt(Kt(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Dt(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return Bt(t,"base64url")}function Kt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function ls(r){let t=Ga(r);return Ja(t)}function Wa(r){let t=Za(r);if(No(t)>cs)throw new Ke("Key size is too large");let e=be(me.encode({Type:ot.RSA,Data:r})),n=St(Co,e);return new sr(t,n)}function Ja(r){if(No(r)>cs)throw new V("Key size is too large");let t=Xa(r),e=be(me.encode({Type:ot.RSA,Data:To(t.publicKey)})),n=St(Co,e);return new Mr(t.privateKey,new sr(t.publicKey,n))}async function Ya(r){if(r>cs)throw new V("Key size is too large");let t=await ja(r),e=be(me.encode({Type:ot.RSA,Data:To(t.publicKey)})),n=St(Co,e);return new Mr(t.privateKey,new sr(t.publicKey,n))}function Xa(r){if(r==null)throw new V("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var us=class extends We{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Yr(t);let n=oe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ze(this),this.iHash.update(t),this}digestInto(t){Ze(this),Ge(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 us(r,t).update(e).digest();Pr.create=(r,t)=>new us(r,t);function Qa(r){r.lowS!==void 0&&Nt("lowS",r.lowS),r.prehash!==void 0&&Nt("prehash",r.prehash)}function Kf(r){let t=Er(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("invalid 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("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Mf,hexToBytes:Pf}=sn,Uo=class extends Error{constructor(t=""){super(t)}},ee={Err:Uo,_tlv:{encode:(r,t)=>{let{Err:e}=ee;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Se(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Se(s.length/2|128):"";return Se(r)+o+s+t},decode(r,t){let{Err:e}=ee,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=ee;if(r<re)throw new t("integer: negative integers are not allowed");let e=Se(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ee;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Mf(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ee,s=typeof r=="string"?Pf(r):r;Xe(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(u)}},hexFromSig(r){let{_tlv:t,_int:e}=ee,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},re=BigInt(0),it=BigInt(1),Qp=BigInt(2),tc=BigInt(3),tg=BigInt(4);function Ff(r){let t=Kf(r),{Fp:e}=t,n=de(t.n,t.nBitLength),s=t.toBytes||((m,d,b)=>{let B=d.toAffine();return zt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(m=>{let d=m.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:B}});function i(m){let{a:d,b}=t,B=e.sqr(m),p=e.mul(B,m);return e.add(e.add(p,e.mul(m,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return vr(m,it,t.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:B,n:p}=t;if(d&&typeof m!="bigint"){if(ue(m)&&(m=jt(m)),typeof m!="string"||!d.includes(m.length))throw new Error("invalid private key");m=m.padStart(b*2,"0")}let k;try{k=typeof m=="bigint"?m:$t(J("private key",m,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof m)}return B&&(k=$(k,p)),bt("private key",k,it,p),k}function u(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let l=Ce((m,d)=>{let{px:b,py:B,pz:p}=m;if(e.eql(p,e.ONE))return{x:b,y:B};let k=m.is0();d==null&&(d=k?e.ONE:e.inv(p));let R=e.mul(b,d),U=e.mul(B,d),I=e.mul(p,d);if(k)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:R,y:U}}),f=Ce(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=m.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let B=e.sqr(b),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,B){if(this.px=d,this.py=b,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:B}=d||{};if(!d||!e.isValid(b)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=k=>e.eql(k,e.ZERO);return p(b)&&p(B)?h.ZERO:new h(b,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(b[p])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(J("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return ln(h,n,d,b)}_setWindowSize(d){w.setWindowSize(this,d)}assertValidity(){f(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:b,py:B,pz:p}=this,{px:k,py:R,pz:U}=d,I=e.eql(e.mul(b,U),e.mul(k,p)),T=e.eql(e.mul(B,U),e.mul(R,p));return I&&T}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,B=e.mul(b,tc),{px:p,py:k,pz:R}=this,U=e.ZERO,I=e.ZERO,T=e.ZERO,N=e.mul(p,p),G=e.mul(k,k),F=e.mul(R,R),K=e.mul(p,k);return K=e.add(K,K),T=e.mul(p,R),T=e.add(T,T),U=e.mul(d,T),I=e.mul(B,F),I=e.add(U,I),U=e.sub(G,I),I=e.add(G,I),I=e.mul(U,I),U=e.mul(K,U),T=e.mul(B,T),F=e.mul(d,F),K=e.sub(N,F),K=e.mul(d,K),K=e.add(K,T),T=e.add(N,N),N=e.add(T,N),N=e.add(N,F),N=e.mul(N,K),I=e.add(I,N),F=e.mul(k,R),F=e.add(F,F),N=e.mul(F,K),U=e.sub(U,N),T=e.mul(F,G),T=e.add(T,T),T=e.add(T,T),new h(U,I,T)}add(d){u(d);let{px:b,py:B,pz:p}=this,{px:k,py:R,pz:U}=d,I=e.ZERO,T=e.ZERO,N=e.ZERO,G=t.a,F=e.mul(t.b,tc),K=e.mul(b,k),Q=e.mul(B,R),E=e.mul(p,U),C=e.add(b,B),x=e.add(k,R);C=e.mul(C,x),x=e.add(K,Q),C=e.sub(C,x),x=e.add(b,p);let g=e.add(k,U);return x=e.mul(x,g),g=e.add(K,E),x=e.sub(x,g),g=e.add(B,p),I=e.add(R,U),g=e.mul(g,I),I=e.add(Q,E),g=e.sub(g,I),N=e.mul(G,x),I=e.mul(F,E),N=e.add(I,N),I=e.sub(Q,N),N=e.add(Q,N),T=e.mul(I,N),Q=e.add(K,K),Q=e.add(Q,K),E=e.mul(G,E),x=e.mul(F,x),Q=e.add(Q,E),E=e.sub(K,E),E=e.mul(G,E),x=e.add(x,E),K=e.mul(Q,x),T=e.add(T,K),K=e.mul(g,x),I=e.mul(C,I),I=e.sub(I,K),K=e.mul(C,Q),N=e.mul(g,N),N=e.add(N,K),new h(I,T,N)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:b,n:B}=t;bt("scalar",d,re,B);let p=h.ZERO;if(d===re)return p;if(this.is0()||d===it)return this;if(!b||w.hasPrecomputes(this))return w.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:k,k1:R,k2neg:U,k2:I}=b.splitScalar(d),T=p,N=p,G=this;for(;R>re||I>re;)R&it&&(T=T.add(G)),I&it&&(N=N.add(G)),G=G.double(),R>>=it,I>>=it;return k&&(T=T.negate()),U&&(N=N.negate()),N=new h(e.mul(N.px,b.beta),N.py,N.pz),T.add(N)}multiply(d){let{endo:b,n:B}=t;bt("scalar",d,it,B);let p,k;if(b){let{k1neg:R,k1:U,k2neg:I,k2:T}=b.splitScalar(d),{p:N,f:G}=this.wNAF(U),{p:F,f:K}=this.wNAF(T);N=w.constTimeNegate(R,N),F=w.constTimeNegate(I,F),F=new h(e.mul(F.px,b.beta),F.py,F.pz),p=N.add(F),k=G.add(K)}else{let{p:R,f:U}=this.wNAF(d);p=R,k=U}return h.normalizeZ([p,k])[0]}multiplyAndAddUnsafe(d,b,B){let p=h.BASE,k=(U,I)=>I===re||I===it||!U.equals(p)?U.multiplyUnsafe(I):U.multiply(I),R=k(this,b).add(k(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===it)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===it?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Nt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Nt("isCompressed",d),jt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let y=t.nBitLength,w=cn(h,t.endo?Math.ceil(y/2):y);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function qf(r){let t=Er(r);return Vt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function ec(r){let t=qf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return $(E,n)}function a(E){return on(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=Ff({...t,toBytes(E,C,x){let g=C.toAffine(),v=e.toBytes(g.x),S=zt;return Nt("isCompressed",x),x?S(Uint8Array.from([C.hasEvenY()?2:3]),v):S(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(E){let C=E.length,x=E[0],g=E.subarray(1);if(C===s&&(x===2||x===3)){let v=$t(g);if(!vr(v,it,e.ORDER))throw new Error("Point is not on curve");let S=l(v),L;try{L=e.sqrt(S)}catch(P){let O=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+O)}let H=(L&it)===it;return(x&1)===1!==H&&(L=e.neg(L)),{x:v,y:L}}else if(C===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),S=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:S}}else{let v=s,S=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+S+", got "+C)}}}),h=E=>jt(he(E,t.nByteLength));function y(E){let C=n>>it;return E>C}function w(E){return y(E)?i(-E):E}let m=(E,C,x)=>$t(E.slice(C,x));class d{constructor(C,x,g){this.r=C,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(C){let x=t.nByteLength;return C=J("compactSignature",C,x*2),new d(m(C,0,x),m(C,x,2*x))}static fromDER(C){let{r:x,s:g}=ee.toSig(J("DER",C));return new d(x,g)}assertValidity(){bt("r",this.r,it,n),bt("s",this.s,it,n)}addRecoveryBit(C){return new d(this.r,this.s,C)}recoverPublicKey(C){let{r:x,s:g,recovery:v}=this,S=U(J("msgHash",C));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let L=v===2||v===3?x+t.n:x;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let H=v&1?"03":"02",D=c.fromHex(H+h(L)),P=a(L),O=i(-S*P),j=i(g*P),z=c.BASE.multiplyAndAddUnsafe(D,O,j);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return ee.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(E){try{return u(E),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let E=Fs(t.n);return Ii(t.randomBytes(E),t.n)},precompute(E=8,C=c.BASE){return C._setWindowSize(E),C.multiply(BigInt(3)),C}};function B(E,C=!0){return c.fromPrivateKey(E).toRawBytes(C)}function p(E){let C=ue(E),x=typeof E=="string",g=(C||x)&&E.length;return C?g===s||g===o:x?g===2*s||g===2*o:E instanceof c}function k(E,C,x=!0){if(p(E))throw new Error("first arg must be private key");if(!p(C))throw new Error("second arg must be public key");return c.fromHex(C).multiply(u(E)).toRawBytes(x)}let R=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let C=$t(E),x=E.length*8-t.nBitLength;return x>0?C>>BigInt(x):C},U=t.bits2int_modN||function(E){return i(R(E))},I=Br(t.nBitLength);function T(E){return bt("num < 2^"+t.nBitLength,E,re,I),he(E,t.nByteLength)}function N(E,C,x=G){if(["recovered","canonical"].some(nt=>nt in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:S,prehash:L,extraEntropy:H}=x;S==null&&(S=!0),E=J("msgHash",E),Qa(x),L&&(E=J("prehashed msgHash",g(E)));let D=U(E),P=u(C),O=[T(P),T(D)];if(H!=null&&H!==!1){let nt=H===!0?v(e.BYTES):H;O.push(J("extraEntropy",nt))}let j=zt(...O),z=D;function rt(nt){let at=R(nt);if(!f(at))return;let ut=a(at),yt=c.BASE.multiply(at).toAffine(),pt=i(yt.x);if(pt===re)return;let Lt=i(ut*i(z+pt*P));if(Lt===re)return;let Mt=(yt.x===pt?0:2)|Number(yt.y&it),fr=Lt;return S&&y(Lt)&&(fr=w(Lt),Mt^=1),new d(pt,fr,Mt)}return{seed:j,k2sig:rt}}let G={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function K(E,C,x=G){let{seed:g,k2sig:v}=N(E,C,x),S=t;return Ds(S.hash.outputLen,S.nByteLength,S.hmac)(g,v)}c.BASE._setWindowSize(8);function Q(E,C,x,g=F){let v=E;C=J("msgHash",C),x=J("publicKey",x);let{lowS:S,prehash:L,format:H}=g;if(Qa(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(H!==void 0&&H!=="compact"&&H!=="der")throw new Error("format must be compact or der");let D=typeof v=="string"||ue(v),P=!D&&!H&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!D&&!P)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let O,j;try{if(P&&(O=new d(v.r,v.s)),D){try{H!=="compact"&&(O=d.fromDER(v))}catch(Mt){if(!(Mt instanceof ee.Err))throw Mt}!O&&H!=="der"&&(O=d.fromCompact(v))}j=c.fromHex(x)}catch{return!1}if(!O||S&&O.hasHighS())return!1;L&&(C=t.hash(C));let{r:z,s:rt}=O,nt=U(C),at=a(rt),ut=i(nt*at),yt=i(z*at),pt=c.BASE.multiplyAndAddUnsafe(j,ut,yt)?.toAffine();return pt?i(pt.x)===z:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:k,sign:K,verify:Q,ProjectivePoint:c,Signature:d,utils:b}}function jf(r){return{hash:r,hmac:(t,...e)=>Pr(r,t,Us(...e)),randomBytes:Ye}}function rc(r,t){let e=n=>ec({...r,...jf(n)});return{...e(t),create:e}}var oc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),nc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),$f=BigInt(1),Ro=BigInt(2),sc=(r,t)=>(r+t/Ro)/t;function zf(r){let t=oc,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,h=W(f,e,t)*l%t,y=W(h,Ro,t)*u%t,w=W(y,s,t)*y%t,m=W(w,o,t)*w%t,d=W(m,a,t)*m%t,b=W(d,c,t)*d%t,B=W(b,a,t)*m%t,p=W(B,e,t)*l%t,k=W(p,i,t)*w%t,R=W(k,n,t)*u%t,U=W(R,Ro,t);if(!Lo.eql(Lo.sqr(U),r))throw new Error("Cannot find square root");return U}var Lo=de(oc,void 0,void 0,{sqrt:zf}),Rt=rc({a:BigInt(0),b:BigInt(7),Fp:Lo,n:nc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=nc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-$f*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=sc(o*r,t),c=sc(-n*r,t),u=$(r-a*e-c*s,t),l=$(-a*n-c*o,t),f=u>i,h=l>i;if(f&&(u=t-u),h&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}}},be),lg=BigInt(0);var ug=Rt.ProjectivePoint;function Ho(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Ot(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Vo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ic(r,t){let e=Qe.digest(t instanceof Uint8Array?t:t.subarray());if(Vo(e))return e.then(({digest:n})=>Rt.sign(n,r).toDERRawBytes()).catch(n=>{throw new hr(String(n))});try{return Rt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new hr(String(n))}}function ac(r,t,e){let n=Qe.digest(e instanceof Uint8Array?e:e.subarray());if(Vo(n))return n.then(({digest:s})=>Rt.verify(t,s,r)).catch(s=>{throw new dr(String(s))});try{return Rt.verify(t,n.digest,r)}catch(s){throw new dr(String(s))}}var fs=class{type="secp256k1";raw;_key;constructor(t){this._key=uc(t),this.raw=cc(this._key)}toMultihash(){return xr.digest(hn(this))}toCID(){return Ht.createV1(114,this.toMultihash())}toString(){return st.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}verify(t,e){return ac(this._key,e,t)}},hs=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=lc(t),this.publicKey=new fs(e??fc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}sign(t){return ic(this.raw,t)}};function Oo(r){return new hs(r)}function cc(r){return Rt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function lc(r){try{return Rt.getPublicKey(r,!0),r}catch(t){throw new pr(String(t))}}function uc(r){try{return Rt.ProjectivePoint.fromHex(r),r}catch(t){throw new Ke(String(t))}}function fc(r){try{return Rt.getPublicKey(r,!0)}catch(t){throw new pr(String(t))}}function hn(r){return me.encode({Type:ot[r.type],Data:r.raw})}function hc(r){let t=Tr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case ot.RSA:return ls(e);case ot.Ed25519:return Ws(e);case ot.secp256k1:return Oo(e);default:throw new Me}}function dc(r){return r.byteLength===64?Ws(r):r.byteLength===32?Oo(r):ls(r)}function or(r){return Tr.encode({Type:ot[r.type],Data:r.raw})}function pc(r,t,e,n){Yr(r);let s=bi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(ze(o),ze(i),ze(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=oe(t),u=oe(e),l=new Uint8Array(i),f=Pr.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function gc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function mc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=pc(r,t,e,n),u,l=new Uint8Array(4),f=ke(l),h=new Uint8Array(a.outputLen);for(let y=1,w=0;w<o;y++,w+=a.outputLen){let m=i.subarray(w,w+a.outputLen);f.setInt32(0,y,!1),(u=c._cloneInto(u)).update(l).digestInto(h),m.set(h.subarray(0,m.length));for(let d=1;d<s;d++){a._cloneInto(u).update(h).digestInto(h);for(let b=0;b<m.length;b++)m[b]^=h[b]}}return gc(a,c,i,u,h)}async function ds(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=pc(r,t,e,n),l,f=new Uint8Array(4),h=ke(f),y=new Uint8Array(c.outputLen);for(let w=1,m=0;m<o;w++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,w,!1),(l=u._cloneInto(l)).update(f).digestInto(y),d.set(y.subarray(0,d.length)),await yi(s-1,i,()=>{c._cloneInto(l).update(y).digestInto(y);for(let b=0;b<d.length;b++)d[b]^=y[b]})}return gc(c,u,a,l,y)}var Fr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Be=new Uint32Array(80),_o=class extends ie{constructor(){super(64,20,8,!1),this.A=Fr[0]|0,this.B=Fr[1]|0,this.C=Fr[2]|0,this.D=Fr[3]|0,this.E=Fr[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)Be[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Be[c]=Xr(Be[c-3]^Be[c-8]^Be[c-14]^Be[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=Qr(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=tn(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Xr(n,5)+u+a+l+Be[c]|0;a=i,i=o,o=Xr(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(){Be.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},yc=Je(()=>new _o);var wc={sha1:yc,"sha2-256":be,"sha2-512":le};function qr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(wc).join(" / ");throw new V(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=wc[s],i=mc(o,r,t,{c:e,dkLen:n});return Re.encode(i).substring(1)}var ne="/",bc=new TextEncoder().encode(ne),ps=bc[0],jr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==ps)throw new Error("Invalid key")}toString(t="utf8"){return Bt(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ne))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=bc),this._buf[0]!==ps){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ps,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ps;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(ne).slice(1)}type(){return Gf(this.baseNamespace())}name(){return Zf(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ne)||(t+=ne),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ne):new r(t.slice(0,-1).join(ne))}child(t){return this.toString()===ne?t:t.toString()===ne?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Wf(t.map(e=>e.namespaces()))])}};function Gf(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Zf(r){let t=r.split(":");return t[t.length-1]}function Wf(r){return[].concat(...r)}var Nc=xs(Ic(),1),Cc=Nc.default;var Fc=xs(Dc(),1);var cr={};ft(cr,{create:()=>dh,derivedEmptyPasswordKey:()=>ys});var ys={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function dh(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=wt.get();e*=8;async function c(f,h){let y=a.getRandomValues(new Uint8Array(o)),w=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:w};typeof h=="string"&&(h=q(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",ys,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",ys,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(m,d,f);return Ho([y,m.iv,new Uint8Array(b)])}async function u(f,h){let y=f.subarray(0,o),w=f.subarray(o,o+n),m=f.subarray(o+n),d={name:t,iv:w};typeof h=="string"&&(h=q(h));let b;if(h.length===0)try{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},k=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,k,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",ys,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},k=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,k,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,b,m);return new Uint8Array(B)}return{encrypt:c,decrypt:u}}async function Ko(r,t){let n=await cr.create().encrypt(r,t);return Re.encode(n)}async function Mo(r,t,e){if(r.type==="RSA")return mh(r,t,e);if(r.type==="Ed25519")return ph(r,t,e);if(r.type==="secp256k1")return gh(r,t,e);throw new Me}async function ph(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ko(or(r),t);throw new V(`export format '${e}' is not supported`)}async function gh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ko(or(r),t);throw new V("Export format is not supported")}async function mh(r,t,e="pkcs-8"){if(e==="pkcs-8")return yh(r,t);if(e==="libp2p-key")return Ko(or(r),t);throw new V("Export format is not supported")}async function yh(r,t){let e=wt.get(),s=new et({value:[new X({value:0}),new et({value:[new kt({value:"1.2.840.113549.1.1.1"}),new Jt]}),new Yt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Oe(16),a=await ds(le,t,i,{c:1e4,dkLen:32}),c=Oe(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 et({value:[new Yt({valueHex:i}),new X({value:1e4}),new X({value:32}),new et({value:[new kt({value:"1.2.840.113549.2.11"}),new Jt]})]}),h=new et({value:[new kt({value:"1.2.840.113549.1.5.13"}),new et({value:[new et({value:[new kt({value:"1.2.840.113549.1.5.12"}),f]}),new et({value:[new kt({value:"2.16.840.1.101.3.4.1.42"}),new Yt({valueHex:c})]})]})]}),w=new et({value:[h,new Yt({valueHex:l})]}).toBER(),m=new Uint8Array(w,0,w.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...Bt(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
6
+ `)}`:`${e} :`}};ha=ve;A.Constructed=ha;ve.NAME="CONSTRUCTED";var Cn=class extends dt{fromBER(t,e,n){return e}toBER(t){return Ut}};Cn.override="EndOfContentValueBlock";var da,Tn=class extends ct{constructor(t={}){super(t,Cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};da=Tn;A.EndOfContent=da;Tn.NAME=Lr;var pa,Jt=class extends ct{constructor(t={}){super(t,dt),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}`}};pa=Jt;A.Null=pa;Jt.NAME="NULL";var Un=class extends te(dt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.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=M.BufferSourceConverter.toUint8Array(t);return Qt(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,Ao.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Un.NAME="BooleanValueBlock";var ga,Rn=class extends ct{constructor(t={}){super(t,Un),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}`}};ga=Rn;A.Boolean=ga;Rn.NAME="BOOLEAN";var Ln=class extends te(_t){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=_t.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===Lr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==ca)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?_t.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Ln.NAME="OctetStringValueBlock";var ma,Yt=class r extends ct{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},Ln),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=as(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?ve.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.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 M.BufferSourceConverter.concat(t)}};ma=Yt;A.OctetString=ma;Yt.NAME=ca;var Hn=class extends te(_t){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=_t.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Lr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==la)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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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=as(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 _t.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}}};Hn.NAME="BitStringValueBlock";var ya,rr=class extends ct{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Hn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return ve.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)}`}}};ya=rr;A.BitString=ya;rr.NAME=la;var wa;function Vf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let h=l;h>=0;h--,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=Bn(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=Bn(e,o)),o}function aa(r){if(r>=Ur.length)for(let t=Ur.length;t<=r;t++){let e=new Uint8Array([0]),n=Ur[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=Bn(e,n)),Ur.push(n)}return Ur[r]}function Of(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 Hr=class extends te(dt){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=Ao.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(sa(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)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(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=Of(aa(n),e),i="-";break;default:e=Vf(e,aa(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=ia.charAt(e[c]));return a===!1&&(i+=ia.charAt(0)),i}};wa=Hr;Hr.NAME="IntegerValueBlock";Object.defineProperty(wa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ba,X=class r extends ct{constructor(t={}){super(t,Hr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return En(),BigInt(this.valueBlock.toString())}static fromBigInt(t){En();let e=BigInt(t),n=new Rr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new 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()}`}};ba=X;A.Integer=ba;X.NAME="INTEGER";var xa,Vn=class extends X{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};xa=Vn;A.Enumerated=xa;Vn.NAME="ENUMERATED";var Vr=class extends te(dt){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=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){En();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=xe(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=M.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}}};Vr.NAME="sidBlock";var On=class extends dt{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.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 ko(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 Vr;if(s>Number.MAX_SAFE_INTEGER){En();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}};On.NAME="ObjectIdentifierValueBlock";var va,kt=class extends ct{constructor(t={}){super(t,On),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()}}};va=kt;A.ObjectIdentifier=va;kt.NAME="OBJECT IDENTIFIER";var Or=class extends te(Wt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Qt(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)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=He(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=xe(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=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Or.NAME="relativeSidBlock";var _n=class extends dt{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 Or;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 ko(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 Or;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}};_n.NAME="RelativeObjectIdentifierValueBlock";var Ba,Dn=class extends ct{constructor(t={}){super(t,_n),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()}}};Ba=Dn;A.RelativeObjectIdentifier=Ba;Dn.NAME="RelativeObjectIdentifier";var Ea,et=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ea=et;A.Sequence=Ea;et.NAME="SEQUENCE";var Aa,Kn=class extends ve{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Aa=Kn;A.Set=Aa;Kn.NAME="SET";var Mn=class extends te(dt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=nr}toJSON(){return{...super.toJSON(),value:this.value}}};Mn.NAME="StringValueBlock";var Pn=class extends Mn{};Pn.NAME="SimpleStringValueBlock";var mt=class extends Sn{constructor({...t}={}){super(t,Pn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.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}};mt.NAME="SIMPLE STRING";var Fn=class extends mt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Fn.NAME="Utf8StringValueBlock";var ka,Xt=class extends Fn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ka=Xt;A.Utf8String=ka;Xt.NAME="UTF8String";var qn=class extends mt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};qn.NAME="BmpStringValueBlock";var Sa,jn=class extends qn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Sa=jn;A.BmpString=Sa;jn.NAME="BMPString";var $n=class extends mt{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=xe(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}};$n.NAME="UniversalStringValueBlock";var Ia,zn=class extends $n{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ia=zn;A.UniversalString=Ia;zn.NAME="UniversalString";var Na,Gn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Na=Gn;A.NumericString=Na;Gn.NAME="NumericString";var Ca,Zn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ca=Zn;A.PrintableString=Ca;Zn.NAME="PrintableString";var Ta,Wn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ta=Wn;A.TeletexString=Ta;Wn.NAME="TeletexString";var Ua,Jn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ua=Jn;A.VideotexString=Ua;Jn.NAME="VideotexString";var Ra,Yn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ra=Yn;A.IA5String=Ra;Yn.NAME="IA5String";var La,Xn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};La=Xn;A.GraphicString=La;Xn.NAME="GraphicString";var Ha,_r=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ha=_r;A.VisibleString=Ha;_r.NAME="VisibleString";var Va,Qn=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Va=Qn;A.GeneralString=Va;Qn.NAME="GeneralString";var Oa,ts=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Oa=ts;A.CharacterString=Oa;ts.NAME="CharacterString";var _a,Dr=class extends _r{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,M.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]=vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=vt(this.month,2),e[2]=vt(this.day,2),e[3]=vt(this.hour,2),e[4]=vt(this.minute,2),e[5]=vt(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}}};_a=Dr;A.UTCTime=_a;Dr.NAME="UTCTime";var Da,es=class extends Dr{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,h=n.indexOf("+"),y="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(y=n.substring(h+1),n=n.substring(0,h),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let w=parseInt(y.substring(0,2),10);if(isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*w,y.length===4){if(w=parseInt(y.substring(2,4),10),isNaN(w.valueOf()))throw new Error("Wrong input string for conversion");c=f*w}}}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(vt(this.year,4)),e.push(vt(this.month,2)),e.push(vt(this.day,2)),e.push(vt(this.hour,2)),e.push(vt(this.minute,2)),e.push(vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Da=es;A.GeneralizedTime=Da;es.NAME="GeneralizedTime";var Ka,rs=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ka=rs;A.DATE=Ka;rs.NAME="DATE";var Ma,ns=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ma=ns;A.TimeOfDay=Ma;ns.NAME="TimeOfDay";var Pa,ss=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Pa=ss;A.DateTime=Pa;ss.NAME="DateTime";var Fa,os=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Fa=os;A.Duration=Fa;os.NAME="Duration";var qa,is=class extends Xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};qa=is;A.TIME=qa;is.NAME="TIME";function Bt(r,t="utf8"){let e=gn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function Oe(r){if(isNaN(r)||r<=0)throw new V("random bytes length must be a Number bigger than 0");return Ye(r)}async function ja(r){let t=await wt.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 _f(t);return{privateKey:e[0],publicKey:e[1]}}async function $a(r,t){let e=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await wt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function za(r,t,e){let n=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return wt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function _f(r){if(r.privateKey==null||r.publicKey==null)throw new V("Private and public key are required");return Promise.all([wt.get().subtle.exportKey("jwk",r.privateKey),wt.get().subtle.exportKey("jwk",r.publicKey)])}function No(r){if(r.kty!=="RSA")throw new V("invalid key type");if(r.n==null)throw new V("invalid key modulus");return q(r.n,"base64url").length*8}var sr=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Kr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Ht.createV1(114,this._multihash)}toString(){return st.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}verify(t,e){return za(this._key,e,t)}},Mr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Kr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}sign(t){return $a(this._key,t)}};var cs=8192,Co=18;function Ga(r){let{result:t}=Ve(r),e=t.valueBlock.value;return{n:Dt(e[1]),e:Dt(e[2]),d:Dt(e[3]),p:Dt(e[4]),q:Dt(e[5]),dp:Dt(e[6]),dq:Dt(e[7]),qi:Dt(e[8]),kty:"RSA",alg:"RS256"}}function Df(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new V("JWK was missing components");let e=new et({value:[new X({value:0}),X.fromBigInt(Kt(q(r.n,"base64url"))),X.fromBigInt(Kt(q(r.e,"base64url"))),X.fromBigInt(Kt(q(r.d,"base64url"))),X.fromBigInt(Kt(q(r.p,"base64url"))),X.fromBigInt(Kt(q(r.q,"base64url"))),X.fromBigInt(Kt(q(r.dp,"base64url"))),X.fromBigInt(Kt(q(r.dq,"base64url"))),X.fromBigInt(Kt(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Za(r){let{result:t}=Ve(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Dt(e[0]),e:Dt(e[1])}}function To(r){if(r.n==null||r.e==null)throw new V("JWK was missing components");let e=new et({value:[new et({value:[new kt({value:"1.2.840.113549.1.1.1"}),new Jt]}),new rr({valueHex:new et({value:[X.fromBigInt(Kt(q(r.n,"base64url"))),X.fromBigInt(Kt(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Dt(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return Bt(t,"base64url")}function Kt(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function ls(r){let t=Ga(r);return Ja(t)}function Wa(r){let t=Za(r);if(No(t)>cs)throw new Ke("Key size is too large");let e=be(me.encode({Type:ot.RSA,Data:r})),n=St(Co,e);return new sr(t,n)}function Ja(r){if(No(r)>cs)throw new V("Key size is too large");let t=Xa(r),e=be(me.encode({Type:ot.RSA,Data:To(t.publicKey)})),n=St(Co,e);return new Mr(t.privateKey,new sr(t.publicKey,n))}async function Ya(r){if(r>cs)throw new V("Key size is too large");let t=await ja(r),e=be(me.encode({Type:ot.RSA,Data:To(t.publicKey)})),n=St(Co,e);return new Mr(t.privateKey,new sr(t.publicKey,n))}function Xa(r){if(r==null)throw new V("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var us=class extends We{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Yr(t);let n=oe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ze(this),this.iHash.update(t),this}digestInto(t){Ze(this),Ge(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 us(r,t).update(e).digest();Pr.create=(r,t)=>new us(r,t);function Qa(r){r.lowS!==void 0&&Nt("lowS",r.lowS),r.prehash!==void 0&&Nt("prehash",r.prehash)}function Kf(r){let t=Er(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("invalid 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("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Mf,hexToBytes:Pf}=sn,Uo=class extends Error{constructor(t=""){super(t)}},ee={Err:Uo,_tlv:{encode:(r,t)=>{let{Err:e}=ee;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Se(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Se(s.length/2|128):"";return Se(r)+o+s+t},decode(r,t){let{Err:e}=ee,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=ee;if(r<re)throw new t("integer: negative integers are not allowed");let e=Se(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ee;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Mf(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ee,s=typeof r=="string"?Pf(r):r;Xe(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(u)}},hexFromSig(r){let{_tlv:t,_int:e}=ee,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},re=BigInt(0),it=BigInt(1),Qp=BigInt(2),tc=BigInt(3),tg=BigInt(4);function Ff(r){let t=Kf(r),{Fp:e}=t,n=de(t.n,t.nBitLength),s=t.toBytes||((m,d,b)=>{let B=d.toAffine();return zt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(m=>{let d=m.subarray(1),b=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:b,y:B}});function i(m){let{a:d,b}=t,B=e.sqr(m),p=e.mul(B,m);return e.add(e.add(p,e.mul(m,d)),b)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return vr(m,it,t.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:b,wrapPrivateKey:B,n:p}=t;if(d&&typeof m!="bigint"){if(ue(m)&&(m=jt(m)),typeof m!="string"||!d.includes(m.length))throw new Error("invalid private key");m=m.padStart(b*2,"0")}let k;try{k=typeof m=="bigint"?m:$t(J("private key",m,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof m)}return B&&(k=$(k,p)),bt("private key",k,it,p),k}function u(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let l=Ce((m,d)=>{let{px:b,py:B,pz:p}=m;if(e.eql(p,e.ONE))return{x:b,y:B};let k=m.is0();d==null&&(d=k?e.ONE:e.inv(p));let R=e.mul(b,d),U=e.mul(B,d),I=e.mul(p,d);if(k)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:R,y:U}}),f=Ce(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=m.toAffine();if(!e.isValid(d)||!e.isValid(b))throw new Error("bad point: x or y not FE");let B=e.sqr(b),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,b,B){if(this.px=d,this.py=b,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:b,y:B}=d||{};if(!d||!e.isValid(b)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=k=>e.eql(k,e.ZERO);return p(b)&&p(B)?h.ZERO:new h(b,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let b=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(b[p])).map(h.fromAffine)}static fromHex(d){let b=h.fromAffine(o(J("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,b){return ln(h,n,d,b)}_setWindowSize(d){w.setWindowSize(this,d)}assertValidity(){f(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:b,py:B,pz:p}=this,{px:k,py:R,pz:U}=d,I=e.eql(e.mul(b,U),e.mul(k,p)),T=e.eql(e.mul(B,U),e.mul(R,p));return I&&T}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b}=t,B=e.mul(b,tc),{px:p,py:k,pz:R}=this,U=e.ZERO,I=e.ZERO,T=e.ZERO,N=e.mul(p,p),G=e.mul(k,k),F=e.mul(R,R),K=e.mul(p,k);return K=e.add(K,K),T=e.mul(p,R),T=e.add(T,T),U=e.mul(d,T),I=e.mul(B,F),I=e.add(U,I),U=e.sub(G,I),I=e.add(G,I),I=e.mul(U,I),U=e.mul(K,U),T=e.mul(B,T),F=e.mul(d,F),K=e.sub(N,F),K=e.mul(d,K),K=e.add(K,T),T=e.add(N,N),N=e.add(T,N),N=e.add(N,F),N=e.mul(N,K),I=e.add(I,N),F=e.mul(k,R),F=e.add(F,F),N=e.mul(F,K),U=e.sub(U,N),T=e.mul(F,G),T=e.add(T,T),T=e.add(T,T),new h(U,I,T)}add(d){u(d);let{px:b,py:B,pz:p}=this,{px:k,py:R,pz:U}=d,I=e.ZERO,T=e.ZERO,N=e.ZERO,G=t.a,F=e.mul(t.b,tc),K=e.mul(b,k),Q=e.mul(B,R),E=e.mul(p,U),C=e.add(b,B),x=e.add(k,R);C=e.mul(C,x),x=e.add(K,Q),C=e.sub(C,x),x=e.add(b,p);let g=e.add(k,U);return x=e.mul(x,g),g=e.add(K,E),x=e.sub(x,g),g=e.add(B,p),I=e.add(R,U),g=e.mul(g,I),I=e.add(Q,E),g=e.sub(g,I),N=e.mul(G,x),I=e.mul(F,E),N=e.add(I,N),I=e.sub(Q,N),N=e.add(Q,N),T=e.mul(I,N),Q=e.add(K,K),Q=e.add(Q,K),E=e.mul(G,E),x=e.mul(F,x),Q=e.add(Q,E),E=e.sub(K,E),E=e.mul(G,E),x=e.add(x,E),K=e.mul(Q,x),T=e.add(T,K),K=e.mul(g,x),I=e.mul(C,I),I=e.sub(I,K),K=e.mul(C,Q),N=e.mul(g,N),N=e.add(N,K),new h(I,T,N)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return w.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:b,n:B}=t;bt("scalar",d,re,B);let p=h.ZERO;if(d===re)return p;if(this.is0()||d===it)return this;if(!b||w.hasPrecomputes(this))return w.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:k,k1:R,k2neg:U,k2:I}=b.splitScalar(d),T=p,N=p,G=this;for(;R>re||I>re;)R&it&&(T=T.add(G)),I&it&&(N=N.add(G)),G=G.double(),R>>=it,I>>=it;return k&&(T=T.negate()),U&&(N=N.negate()),N=new h(e.mul(N.px,b.beta),N.py,N.pz),T.add(N)}multiply(d){let{endo:b,n:B}=t;bt("scalar",d,it,B);let p,k;if(b){let{k1neg:R,k1:U,k2neg:I,k2:T}=b.splitScalar(d),{p:N,f:G}=this.wNAF(U),{p:F,f:K}=this.wNAF(T);N=w.constTimeNegate(R,N),F=w.constTimeNegate(I,F),F=new h(e.mul(F.px,b.beta),F.py,F.pz),p=N.add(F),k=G.add(K)}else{let{p:R,f:U}=this.wNAF(d);p=R,k=U}return h.normalizeZ([p,k])[0]}multiplyAndAddUnsafe(d,b,B){let p=h.BASE,k=(U,I)=>I===re||I===it||!U.equals(p)?U.multiplyUnsafe(I):U.multiply(I),R=k(this,b).add(k(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:b}=t;if(d===it)return!0;if(b)return b(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:b}=t;return d===it?this:b?b(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Nt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Nt("isCompressed",d),jt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let y=t.nBitLength,w=cn(h,t.endo?Math.ceil(y/2):y);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function qf(r){let t=Er(r);return Vt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function ec(r){let t=qf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return $(E,n)}function a(E){return on(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=Ff({...t,toBytes(E,C,x){let g=C.toAffine(),v=e.toBytes(g.x),S=zt;return Nt("isCompressed",x),x?S(Uint8Array.from([C.hasEvenY()?2:3]),v):S(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(E){let C=E.length,x=E[0],g=E.subarray(1);if(C===s&&(x===2||x===3)){let v=$t(g);if(!vr(v,it,e.ORDER))throw new Error("Point is not on curve");let S=l(v),L;try{L=e.sqrt(S)}catch(P){let O=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+O)}let H=(L&it)===it;return(x&1)===1!==H&&(L=e.neg(L)),{x:v,y:L}}else if(C===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),S=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:S}}else{let v=s,S=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+S+", got "+C)}}}),h=E=>jt(he(E,t.nByteLength));function y(E){let C=n>>it;return E>C}function w(E){return y(E)?i(-E):E}let m=(E,C,x)=>$t(E.slice(C,x));class d{constructor(C,x,g){this.r=C,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(C){let x=t.nByteLength;return C=J("compactSignature",C,x*2),new d(m(C,0,x),m(C,x,2*x))}static fromDER(C){let{r:x,s:g}=ee.toSig(J("DER",C));return new d(x,g)}assertValidity(){bt("r",this.r,it,n),bt("s",this.s,it,n)}addRecoveryBit(C){return new d(this.r,this.s,C)}recoverPublicKey(C){let{r:x,s:g,recovery:v}=this,S=U(J("msgHash",C));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let L=v===2||v===3?x+t.n:x;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let H=(v&1)===0?"02":"03",D=c.fromHex(H+h(L)),P=a(L),O=i(-S*P),j=i(g*P),z=c.BASE.multiplyAndAddUnsafe(D,O,j);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return ee.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let b={isValidPrivateKey(E){try{return u(E),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let E=Fs(t.n);return Ii(t.randomBytes(E),t.n)},precompute(E=8,C=c.BASE){return C._setWindowSize(E),C.multiply(BigInt(3)),C}};function B(E,C=!0){return c.fromPrivateKey(E).toRawBytes(C)}function p(E){let C=ue(E),x=typeof E=="string",g=(C||x)&&E.length;return C?g===s||g===o:x?g===2*s||g===2*o:E instanceof c}function k(E,C,x=!0){if(p(E))throw new Error("first arg must be private key");if(!p(C))throw new Error("second arg must be public key");return c.fromHex(C).multiply(u(E)).toRawBytes(x)}let R=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let C=$t(E),x=E.length*8-t.nBitLength;return x>0?C>>BigInt(x):C},U=t.bits2int_modN||function(E){return i(R(E))},I=Br(t.nBitLength);function T(E){return bt("num < 2^"+t.nBitLength,E,re,I),he(E,t.nByteLength)}function N(E,C,x=G){if(["recovered","canonical"].some(nt=>nt in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:S,prehash:L,extraEntropy:H}=x;S==null&&(S=!0),E=J("msgHash",E),Qa(x),L&&(E=J("prehashed msgHash",g(E)));let D=U(E),P=u(C),O=[T(P),T(D)];if(H!=null&&H!==!1){let nt=H===!0?v(e.BYTES):H;O.push(J("extraEntropy",nt))}let j=zt(...O),z=D;function rt(nt){let at=R(nt);if(!f(at))return;let ut=a(at),yt=c.BASE.multiply(at).toAffine(),pt=i(yt.x);if(pt===re)return;let Lt=i(ut*i(z+pt*P));if(Lt===re)return;let Mt=(yt.x===pt?0:2)|Number(yt.y&it),fr=Lt;return S&&y(Lt)&&(fr=w(Lt),Mt^=1),new d(pt,fr,Mt)}return{seed:j,k2sig:rt}}let G={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function K(E,C,x=G){let{seed:g,k2sig:v}=N(E,C,x),S=t;return Ds(S.hash.outputLen,S.nByteLength,S.hmac)(g,v)}c.BASE._setWindowSize(8);function Q(E,C,x,g=F){let v=E;C=J("msgHash",C),x=J("publicKey",x);let{lowS:S,prehash:L,format:H}=g;if(Qa(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(H!==void 0&&H!=="compact"&&H!=="der")throw new Error("format must be compact or der");let D=typeof v=="string"||ue(v),P=!D&&!H&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!D&&!P)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let O,j;try{if(P&&(O=new d(v.r,v.s)),D){try{H!=="compact"&&(O=d.fromDER(v))}catch(Mt){if(!(Mt instanceof ee.Err))throw Mt}!O&&H!=="der"&&(O=d.fromCompact(v))}j=c.fromHex(x)}catch{return!1}if(!O||S&&O.hasHighS())return!1;L&&(C=t.hash(C));let{r:z,s:rt}=O,nt=U(C),at=a(rt),ut=i(nt*at),yt=i(z*at),pt=c.BASE.multiplyAndAddUnsafe(j,ut,yt)?.toAffine();return pt?i(pt.x)===z:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:k,sign:K,verify:Q,ProjectivePoint:c,Signature:d,utils:b}}function jf(r){return{hash:r,hmac:(t,...e)=>Pr(r,t,Us(...e)),randomBytes:Ye}}function rc(r,t){let e=n=>ec({...r,...jf(n)});return{...e(t),create:e}}var oc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),nc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),$f=BigInt(1),Ro=BigInt(2),sc=(r,t)=>(r+t/Ro)/t;function zf(r){let t=oc,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,h=W(f,e,t)*l%t,y=W(h,Ro,t)*u%t,w=W(y,s,t)*y%t,m=W(w,o,t)*w%t,d=W(m,a,t)*m%t,b=W(d,c,t)*d%t,B=W(b,a,t)*m%t,p=W(B,e,t)*l%t,k=W(p,i,t)*w%t,R=W(k,n,t)*u%t,U=W(R,Ro,t);if(!Lo.eql(Lo.sqr(U),r))throw new Error("Cannot find square root");return U}var Lo=de(oc,void 0,void 0,{sqrt:zf}),Rt=rc({a:BigInt(0),b:BigInt(7),Fp:Lo,n:nc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=nc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-$f*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=sc(o*r,t),c=sc(-n*r,t),u=$(r-a*e-c*s,t),l=$(-a*n-c*o,t),f=u>i,h=l>i;if(f&&(u=t-u),h&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}}},be),lg=BigInt(0);var ug=Rt.ProjectivePoint;function Ho(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Ot(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Vo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ic(r,t){let e=Qe.digest(t instanceof Uint8Array?t:t.subarray());if(Vo(e))return e.then(({digest:n})=>Rt.sign(n,r).toDERRawBytes()).catch(n=>{throw new hr(String(n))});try{return Rt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new hr(String(n))}}function ac(r,t,e){let n=Qe.digest(e instanceof Uint8Array?e:e.subarray());if(Vo(n))return n.then(({digest:s})=>Rt.verify(t,s,r)).catch(s=>{throw new dr(String(s))});try{return Rt.verify(t,n.digest,r)}catch(s){throw new dr(String(s))}}var fs=class{type="secp256k1";raw;_key;constructor(t){this._key=uc(t),this.raw=cc(this._key)}toMultihash(){return xr.digest(hn(this))}toCID(){return Ht.createV1(114,this.toMultihash())}toString(){return st.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}verify(t,e){return ac(this._key,e,t)}},hs=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=lc(t),this.publicKey=new fs(e??fc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Ft(this.raw,t.raw)}sign(t){return ic(this.raw,t)}};function Oo(r){return new hs(r)}function cc(r){return Rt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function lc(r){try{return Rt.getPublicKey(r,!0),r}catch(t){throw new pr(String(t))}}function uc(r){try{return Rt.ProjectivePoint.fromHex(r),r}catch(t){throw new Ke(String(t))}}function fc(r){try{return Rt.getPublicKey(r,!0)}catch(t){throw new pr(String(t))}}function hn(r){return me.encode({Type:ot[r.type],Data:r.raw})}function hc(r){let t=Tr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case ot.RSA:return ls(e);case ot.Ed25519:return Ws(e);case ot.secp256k1:return Oo(e);default:throw new Me}}function dc(r){return r.byteLength===64?Ws(r):r.byteLength===32?Oo(r):ls(r)}function or(r){return Tr.encode({Type:ot[r.type],Data:r.raw})}function pc(r,t,e,n){Yr(r);let s=bi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(ze(o),ze(i),ze(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=oe(t),u=oe(e),l=new Uint8Array(i),f=Pr.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function gc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function mc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=pc(r,t,e,n),u,l=new Uint8Array(4),f=ke(l),h=new Uint8Array(a.outputLen);for(let y=1,w=0;w<o;y++,w+=a.outputLen){let m=i.subarray(w,w+a.outputLen);f.setInt32(0,y,!1),(u=c._cloneInto(u)).update(l).digestInto(h),m.set(h.subarray(0,m.length));for(let d=1;d<s;d++){a._cloneInto(u).update(h).digestInto(h);for(let b=0;b<m.length;b++)m[b]^=h[b]}}return gc(a,c,i,u,h)}async function ds(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=pc(r,t,e,n),l,f=new Uint8Array(4),h=ke(f),y=new Uint8Array(c.outputLen);for(let w=1,m=0;m<o;w++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,w,!1),(l=u._cloneInto(l)).update(f).digestInto(y),d.set(y.subarray(0,d.length)),await yi(s-1,i,()=>{c._cloneInto(l).update(y).digestInto(y);for(let b=0;b<d.length;b++)d[b]^=y[b]})}return gc(c,u,a,l,y)}var Fr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Be=new Uint32Array(80),_o=class extends ie{constructor(){super(64,20,8,!1),this.A=Fr[0]|0,this.B=Fr[1]|0,this.C=Fr[2]|0,this.D=Fr[3]|0,this.E=Fr[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)Be[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Be[c]=Xr(Be[c-3]^Be[c-8]^Be[c-14]^Be[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=Qr(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=tn(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Xr(n,5)+u+a+l+Be[c]|0;a=i,i=o,o=Xr(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(){Be.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},yc=Je(()=>new _o);var wc={sha1:yc,"sha2-256":be,"sha2-512":le};function qr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(wc).join(" / ");throw new V(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=wc[s],i=mc(o,r,t,{c:e,dkLen:n});return Re.encode(i).substring(1)}var ne="/",bc=new TextEncoder().encode(ne),ps=bc[0],jr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==ps)throw new Error("Invalid key")}toString(t="utf8"){return Bt(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ne))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=bc),this._buf[0]!==ps){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ps,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ps;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(ne).slice(1)}type(){return Gf(this.baseNamespace())}name(){return Zf(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ne)||(t+=ne),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ne):new r(t.slice(0,-1).join(ne))}child(t){return this.toString()===ne?t:t.toString()===ne?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Wf(t.map(e=>e.namespaces()))])}};function Gf(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Zf(r){let t=r.split(":");return t[t.length-1]}function Wf(r){return[].concat(...r)}var Nc=xs(Ic(),1),Cc=Nc.default;var Fc=xs(Dc(),1);var cr={};ft(cr,{create:()=>dh,derivedEmptyPasswordKey:()=>ys});var ys={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function dh(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=wt.get();e*=8;async function c(f,h){let y=a.getRandomValues(new Uint8Array(o)),w=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:w};typeof h=="string"&&(h=q(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",ys,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",ys,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(m,d,f);return Ho([y,m.iv,new Uint8Array(b)])}async function u(f,h){let y=f.subarray(0,o),w=f.subarray(o,o+n),m=f.subarray(o+n),d={name:t,iv:w};typeof h=="string"&&(h=q(h));let b;if(h.length===0)try{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},k=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,k,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",ys,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},k=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(p,k,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,b,m);return new Uint8Array(B)}return{encrypt:c,decrypt:u}}async function Ko(r,t){let n=await cr.create().encrypt(r,t);return Re.encode(n)}async function Mo(r,t,e){if(r.type==="RSA")return mh(r,t,e);if(r.type==="Ed25519")return ph(r,t,e);if(r.type==="secp256k1")return gh(r,t,e);throw new Me}async function ph(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ko(or(r),t);throw new V(`export format '${e}' is not supported`)}async function gh(r,t,e="libp2p-key"){if(e==="libp2p-key")return Ko(or(r),t);throw new V("Export format is not supported")}async function mh(r,t,e="pkcs-8"){if(e==="pkcs-8")return yh(r,t);if(e==="libp2p-key")return Ko(or(r),t);throw new V("Export format is not supported")}async function yh(r,t){let e=wt.get(),s=new et({value:[new X({value:0}),new et({value:[new kt({value:"1.2.840.113549.1.1.1"}),new Jt]}),new Yt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Oe(16),a=await ds(le,t,i,{c:1e4,dkLen:32}),c=Oe(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 et({value:[new Yt({valueHex:i}),new X({value:1e4}),new X({value:32}),new et({value:[new kt({value:"1.2.840.113549.2.11"}),new Jt]})]}),h=new et({value:[new kt({value:"1.2.840.113549.1.5.13"}),new et({value:[new et({value:[new kt({value:"1.2.840.113549.1.5.12"}),f]}),new et({value:[new kt({value:"2.16.840.1.101.3.4.1.42"}),new Yt({valueHex:c})]})]})]}),w=new et({value:[h,new Yt({valueHex:l})]}).toBER(),m=new Uint8Array(w,0,w.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...Bt(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
7
  `)}async function Po(r,t){try{let e=await wh(r,t);return hc(e)}catch{}if(!r.includes("BEGIN"))throw new V("Encrypted key was not a libp2p-key or a PEM file");return bh(r,t)}async function wh(r,t){let e=Re.decode(r);return cr.create().decrypt(e,t)}async function bh(r,t){let e=wt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ve(o),{iv:a,salt:c,iterations:u,keySize:l,cipherText:f}=xh(i),h=await ds(le,t,c,{c:u,dkLen:l}),y=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),w=$r(await e.subtle.decrypt({name:"AES-CBC",iv:a},y,f)),{result:m}=Ve(w);n=Pc(m)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Ve(o);n=Pc(i)}else throw new V("Could not parse private key from PEM data");let s=dc(n);if(s.type!=="RSA")throw new V("Could not parse RSA private key from PEM data");return s}function xh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new V("Only pkcs5PBES2 encrypted private keys are supported");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 V("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=$r(o.valueBlock.value[0].getValue()),a=1e4,c=32;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new V("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");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 V("Only AES-CBC encryption schemes are supported")}}}}let f=$r(u.valueBlock.value[1].getValue());return{cipherText:$r(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Pc(r){return $r(r.valueBlock.value[2].getValue())}function $r(r){return new Uint8Array(r,0,r.byteLength)}var vh="/pkcs8/",qo="/info/",zr=new WeakMap,_e={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Fo={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function lr(r){return r==null||typeof r!="string"?!1:r===(0,Fc.default)(r.trim())&&r.length>0}async function lt(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function De(r){return new jr(vh+r)}function ur(r){return new jr(qo+r)}async function Bh(r){let t=or(r),e=await Qe.digest(t);return st.encode(e.bytes).substring(1)}var ws=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Cc(Fo,e),this.self=e.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<_e.minKeyLength)throw new Error(`dek.keyLength must be least ${_e.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<_e.minSaltLength)throw new Error(`dek.saltLength must be least ${_e.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<_e.minIterationCount)throw new Error(`dek.iterationCount must be least ${_e.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?qr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";zr.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[Qo]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},Fo),e=Math.ceil(_e.minSaltLength/3)*3;return t.dek.salt=Bt(Oe(e),"base64"),t}static get options(){return Fo}async findKeyByName(t){if(!lr(t))throw await lt(),new V(`Invalid key name '${t}'`);let e=ur(t);try{let n=await this.components.datastore.get(e);return JSON.parse(Bt(n))}catch(n){throw await lt(),this.log.error(n),new Wr(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:qo};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(Bt(n.value));if(s.id===t)return s}throw new V(`Key with id '${t}' does not exist.`)}catch(e){throw await lt(),e}}async importKey(t,e){if(!lr(t))throw await lt(),new V(`Invalid key name '${t}'`);if(e==null)throw await lt(),new V("Key is required");let n=De(t);if(await this.components.datastore.has(n))throw await lt(),new V(`Key '${t}' already exists`);let o,i;try{o=await Bh(e);let u=zr.get(this);if(u==null)throw new V("dek missing");let l=u.dek;i=await Mo(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(u){throw await lt(),u}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,q(i)),c.put(ur(t),q(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!lr(t))throw await lt(),new V(`Invalid key name '${t}'`);let e=De(t);try{let n=await this.components.datastore.get(e),s=Bt(n),o=zr.get(this);if(o==null)throw new V("dek missing");let i=o.dek;return await Po(s,i)}catch(n){throw await lt(),n}}async removeKey(t){if(!lr(t)||t===this.self)throw await lt(),new V(`Invalid key name '${t}'`);let e=De(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(ur(t)),await s.commit(),n}async listKeys(){let t={prefix:qo},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(Bt(n.value)));return e}async renameKey(t,e){if(!lr(t)||t===this.self)throw await lt(),new V(`Invalid old key name '${t}'`);if(!lr(e)||e===this.self)throw await lt(),new V(`Invalid new key name '${e}'`);let n=De(t),s=De(e),o=ur(t),i=ur(e);if(await this.components.datastore.has(s))throw await lt(),new V(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),u=await this.components.datastore.get(o),l=JSON.parse(Bt(u));l.name=e;let f=this.components.datastore.batch();return f.put(s,c),f.put(i,q(JSON.stringify(l))),f.delete(n),f.delete(o),await f.commit(),l}catch(c){throw await lt(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await lt(),new V(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await lt(),new V(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await lt(),new V(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=zr.get(this);if(n==null)throw new V("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?qr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";zr.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(De(a.name)),u=Bt(c),l=await Po(u,s),f=o.toString(),h=await Mo(l,f,l.type==="RSA"?"pkcs-8":"libp2p-key"),y=this.components.datastore.batch(),w={name:a.name,id:a.id};y.put(De(a.name),q(h)),y.put(ur(a.name),q(JSON.stringify(w))),await y.commit()}this.log("keychain reconstructed")}};function Eh(r={}){return t=>new ws(t,r)}return rl(Ah);})();
8
8
  /*! Bundled license information:
9
9
 
@@ -1,11 +1,11 @@
1
1
  /**
2
2
  * @packageDocumentation
3
3
  *
4
- * - Manages the lifecycle of a key
4
+ * - Manages the life cycle of a key
5
5
  * - Keys are encrypted at rest
6
6
  * - Enforces the use of safe key names
7
7
  * - Uses encrypted PKCS 8 for key storage
8
- * - Uses PBKDF2 for a "stetched" key encryption key
8
+ * - Uses PBKDF2 for a "stretched" key encryption key
9
9
  * - Enforces NIST SP 800-131A and NIST SP 800-132
10
10
  * - Delays reporting errors to slow down brute force attacks
11
11
  *
@@ -26,9 +26,9 @@
26
26
  *
27
27
  * ## Private key storage
28
28
  *
29
- * A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *passPhrase* using **PBKDF2**.
29
+ * A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *pass phrase* using **PBKDF2**.
30
30
  *
31
- * The default options for generating the derived encryption key are in the `dek` object. This, along with the passPhrase, is the input to a `PBKDF2` function.
31
+ * The default options for generating the derived encryption key are in the `dek` object. This, along with the pass phrase, is the input to a `PBKDF2` function.
32
32
  *
33
33
  * ```TypeScript
34
34
  * const defaultOptions = {
@@ -170,7 +170,7 @@ export interface Keychain {
170
170
  *
171
171
  * ```TypeScript
172
172
  * await libp2p.services.keychain.createKey('keyTest', 'RSA', 4096)
173
- * const keyInfo = await libp2p.services.keychain.renameKey('keyTest', 'keyNewNtest')
173
+ * const keyInfo = await libp2p.services.keychain.renameKey('keyTest', 'keyNewTest')
174
174
  * ```
175
175
  */
176
176
  renameKey(oldName: string, newName: string): Promise<KeyInfo>;
package/dist/src/index.js CHANGED
@@ -1,11 +1,11 @@
1
1
  /**
2
2
  * @packageDocumentation
3
3
  *
4
- * - Manages the lifecycle of a key
4
+ * - Manages the life cycle of a key
5
5
  * - Keys are encrypted at rest
6
6
  * - Enforces the use of safe key names
7
7
  * - Uses encrypted PKCS 8 for key storage
8
- * - Uses PBKDF2 for a "stetched" key encryption key
8
+ * - Uses PBKDF2 for a "stretched" key encryption key
9
9
  * - Enforces NIST SP 800-131A and NIST SP 800-132
10
10
  * - Delays reporting errors to slow down brute force attacks
11
11
  *
@@ -26,9 +26,9 @@
26
26
  *
27
27
  * ## Private key storage
28
28
  *
29
- * A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *passPhrase* using **PBKDF2**.
29
+ * A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *pass phrase* using **PBKDF2**.
30
30
  *
31
- * The default options for generating the derived encryption key are in the `dek` object. This, along with the passPhrase, is the input to a `PBKDF2` function.
31
+ * The default options for generating the derived encryption key are in the `dek` object. This, along with the pass phrase, is the input to a `PBKDF2` function.
32
32
  *
33
33
  * ```TypeScript
34
34
  * const defaultOptions = {
@@ -11,7 +11,7 @@ declare const defaultOptions: {
11
11
  };
12
12
  export declare function keyId(key: PrivateKey): Promise<string>;
13
13
  /**
14
- * Manages the lifecycle of a key. Keys are encrypted at rest using PKCS #8.
14
+ * Manages the life cycle of a key. Keys are encrypted at rest using PKCS #8.
15
15
  *
16
16
  * A key in the store has two entries
17
17
  * - '/info/*key-name*', contains the KeyInfo for the key
@@ -68,7 +68,7 @@ export async function keyId(key) {
68
68
  return base58btc.encode(hash.bytes).substring(1);
69
69
  }
70
70
  /**
71
- * Manages the lifecycle of a key. Keys are encrypted at rest using PKCS #8.
71
+ * Manages the life cycle of a key. Keys are encrypted at rest using PKCS #8.
72
72
  *
73
73
  * A key in the store has two entries
74
74
  * - '/info/*key-name*', contains the KeyInfo for the key
@@ -135,9 +135,9 @@ export class Keychain {
135
135
  await randomDelay();
136
136
  throw new InvalidParametersError(`Invalid key name '${name}'`);
137
137
  }
138
- const dsname = DsInfoName(name);
138
+ const datastoreName = DsInfoName(name);
139
139
  try {
140
- const res = await this.components.datastore.get(dsname);
140
+ const res = await this.components.datastore.get(datastoreName);
141
141
  return JSON.parse(uint8ArrayToString(res));
142
142
  }
143
143
  catch (err) {
@@ -173,8 +173,8 @@ export class Keychain {
173
173
  await randomDelay();
174
174
  throw new InvalidParametersError('Key is required');
175
175
  }
176
- const dsname = DsName(name);
177
- const exists = await this.components.datastore.has(dsname);
176
+ const datastoreName = DsName(name);
177
+ const exists = await this.components.datastore.has(datastoreName);
178
178
  if (exists) {
179
179
  await randomDelay();
180
180
  throw new InvalidParametersError(`Key '${name}' already exists`);
@@ -199,7 +199,7 @@ export class Keychain {
199
199
  id: kid
200
200
  };
201
201
  const batch = this.components.datastore.batch();
202
- batch.put(dsname, uint8ArrayFromString(pem));
202
+ batch.put(datastoreName, uint8ArrayFromString(pem));
203
203
  batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)));
204
204
  await batch.commit();
205
205
  return keyInfo;
@@ -209,9 +209,9 @@ export class Keychain {
209
209
  await randomDelay();
210
210
  throw new InvalidParametersError(`Invalid key name '${name}'`);
211
211
  }
212
- const dsname = DsName(name);
212
+ const datastoreName = DsName(name);
213
213
  try {
214
- const res = await this.components.datastore.get(dsname);
214
+ const res = await this.components.datastore.get(datastoreName);
215
215
  const pem = uint8ArrayToString(res);
216
216
  const cached = privates.get(this);
217
217
  if (cached == null) {
@@ -230,10 +230,10 @@ export class Keychain {
230
230
  await randomDelay();
231
231
  throw new InvalidParametersError(`Invalid key name '${name}'`);
232
232
  }
233
- const dsname = DsName(name);
233
+ const datastoreName = DsName(name);
234
234
  const keyInfo = await this.findKeyByName(name);
235
235
  const batch = this.components.datastore.batch();
236
- batch.delete(dsname);
236
+ batch.delete(datastoreName);
237
237
  batch.delete(DsInfoName(name));
238
238
  await batch.commit();
239
239
  return keyInfo;
@@ -269,24 +269,24 @@ export class Keychain {
269
269
  await randomDelay();
270
270
  throw new InvalidParametersError(`Invalid new key name '${newName}'`);
271
271
  }
272
- const oldDsname = DsName(oldName);
273
- const newDsname = DsName(newName);
272
+ const oldDatastoreName = DsName(oldName);
273
+ const newDatastoreName = DsName(newName);
274
274
  const oldInfoName = DsInfoName(oldName);
275
275
  const newInfoName = DsInfoName(newName);
276
- const exists = await this.components.datastore.has(newDsname);
276
+ const exists = await this.components.datastore.has(newDatastoreName);
277
277
  if (exists) {
278
278
  await randomDelay();
279
279
  throw new InvalidParametersError(`Key '${newName}' already exists`);
280
280
  }
281
281
  try {
282
- const pem = await this.components.datastore.get(oldDsname);
282
+ const pem = await this.components.datastore.get(oldDatastoreName);
283
283
  const res = await this.components.datastore.get(oldInfoName);
284
284
  const keyInfo = JSON.parse(uint8ArrayToString(res));
285
285
  keyInfo.name = newName;
286
286
  const batch = this.components.datastore.batch();
287
- batch.put(newDsname, pem);
287
+ batch.put(newDatastoreName, pem);
288
288
  batch.put(newInfoName, uint8ArrayFromString(JSON.stringify(keyInfo)));
289
- batch.delete(oldDsname);
289
+ batch.delete(oldDatastoreName);
290
290
  batch.delete(oldInfoName);
291
291
  await batch.commit();
292
292
  return keyInfo;
@@ -1 +1 @@
1
- {"version":3,"file":"keychain.js","sourceRoot":"","sources":["../../src/keychain.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"keychain.js","sourceRoot":"","sources":["../../src/keychain.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/keychain",
3
- "version": "5.1.0",
3
+ "version": "5.1.1",
4
4
  "description": "Key management and cryptographically protected messages",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/keychain#readme",
@@ -59,8 +59,8 @@
59
59
  "test:electron-main": "aegir test -t electron-main"
60
60
  },
61
61
  "dependencies": {
62
- "@libp2p/crypto": "^5.0.12",
63
- "@libp2p/interface": "^2.6.0",
62
+ "@libp2p/crypto": "^5.0.13",
63
+ "@libp2p/interface": "^2.6.1",
64
64
  "@noble/hashes": "^1.6.1",
65
65
  "asn1js": "^3.0.5",
66
66
  "interface-datastore": "^8.3.1",
@@ -70,8 +70,8 @@
70
70
  "uint8arrays": "^5.1.0"
71
71
  },
72
72
  "devDependencies": {
73
- "@libp2p/logger": "^5.1.9",
74
- "aegir": "^45.0.5",
73
+ "@libp2p/logger": "^5.1.10",
74
+ "aegir": "^45.1.1",
75
75
  "datastore-core": "^10.0.2"
76
76
  },
77
77
  "sideEffects": false
package/src/index.ts CHANGED
@@ -1,11 +1,11 @@
1
1
  /**
2
2
  * @packageDocumentation
3
3
  *
4
- * - Manages the lifecycle of a key
4
+ * - Manages the life cycle of a key
5
5
  * - Keys are encrypted at rest
6
6
  * - Enforces the use of safe key names
7
7
  * - Uses encrypted PKCS 8 for key storage
8
- * - Uses PBKDF2 for a "stetched" key encryption key
8
+ * - Uses PBKDF2 for a "stretched" key encryption key
9
9
  * - Enforces NIST SP 800-131A and NIST SP 800-132
10
10
  * - Delays reporting errors to slow down brute force attacks
11
11
  *
@@ -26,9 +26,9 @@
26
26
  *
27
27
  * ## Private key storage
28
28
  *
29
- * A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *passPhrase* using **PBKDF2**.
29
+ * A private key is stored as an encrypted PKCS 8 structure in the PEM format. It is protected by a key generated from the key chain's *pass phrase* using **PBKDF2**.
30
30
  *
31
- * The default options for generating the derived encryption key are in the `dek` object. This, along with the passPhrase, is the input to a `PBKDF2` function.
31
+ * The default options for generating the derived encryption key are in the `dek` object. This, along with the pass phrase, is the input to a `PBKDF2` function.
32
32
  *
33
33
  * ```TypeScript
34
34
  * const defaultOptions = {
@@ -185,7 +185,7 @@ export interface Keychain {
185
185
  *
186
186
  * ```TypeScript
187
187
  * await libp2p.services.keychain.createKey('keyTest', 'RSA', 4096)
188
- * const keyInfo = await libp2p.services.keychain.renameKey('keyTest', 'keyNewNtest')
188
+ * const keyInfo = await libp2p.services.keychain.renameKey('keyTest', 'keyNewTest')
189
189
  * ```
190
190
  */
191
191
  renameKey(oldName: string, newName: string): Promise<KeyInfo>
package/src/keychain.ts CHANGED
@@ -82,7 +82,7 @@ export async function keyId (key: PrivateKey): Promise<string> {
82
82
  }
83
83
 
84
84
  /**
85
- * Manages the lifecycle of a key. Keys are encrypted at rest using PKCS #8.
85
+ * Manages the life cycle of a key. Keys are encrypted at rest using PKCS #8.
86
86
  *
87
87
  * A key in the store has two entries
88
88
  * - '/info/*key-name*', contains the KeyInfo for the key
@@ -164,10 +164,10 @@ export class Keychain implements KeychainInterface {
164
164
  throw new InvalidParametersError(`Invalid key name '${name}'`)
165
165
  }
166
166
 
167
- const dsname = DsInfoName(name)
167
+ const datastoreName = DsInfoName(name)
168
168
 
169
169
  try {
170
- const res = await this.components.datastore.get(dsname)
170
+ const res = await this.components.datastore.get(datastoreName)
171
171
  return JSON.parse(uint8ArrayToString(res))
172
172
  } catch (err: any) {
173
173
  await randomDelay()
@@ -206,8 +206,8 @@ export class Keychain implements KeychainInterface {
206
206
  await randomDelay()
207
207
  throw new InvalidParametersError('Key is required')
208
208
  }
209
- const dsname = DsName(name)
210
- const exists = await this.components.datastore.has(dsname)
209
+ const datastoreName = DsName(name)
210
+ const exists = await this.components.datastore.has(datastoreName)
211
211
  if (exists) {
212
212
  await randomDelay()
213
213
  throw new InvalidParametersError(`Key '${name}' already exists`)
@@ -235,7 +235,7 @@ export class Keychain implements KeychainInterface {
235
235
  id: kid
236
236
  }
237
237
  const batch = this.components.datastore.batch()
238
- batch.put(dsname, uint8ArrayFromString(pem))
238
+ batch.put(datastoreName, uint8ArrayFromString(pem))
239
239
  batch.put(DsInfoName(name), uint8ArrayFromString(JSON.stringify(keyInfo)))
240
240
  await batch.commit()
241
241
 
@@ -248,9 +248,9 @@ export class Keychain implements KeychainInterface {
248
248
  throw new InvalidParametersError(`Invalid key name '${name}'`)
249
249
  }
250
250
 
251
- const dsname = DsName(name)
251
+ const datastoreName = DsName(name)
252
252
  try {
253
- const res = await this.components.datastore.get(dsname)
253
+ const res = await this.components.datastore.get(datastoreName)
254
254
  const pem = uint8ArrayToString(res)
255
255
  const cached = privates.get(this)
256
256
 
@@ -273,10 +273,10 @@ export class Keychain implements KeychainInterface {
273
273
  throw new InvalidParametersError(`Invalid key name '${name}'`)
274
274
  }
275
275
 
276
- const dsname = DsName(name)
276
+ const datastoreName = DsName(name)
277
277
  const keyInfo = await this.findKeyByName(name)
278
278
  const batch = this.components.datastore.batch()
279
- batch.delete(dsname)
279
+ batch.delete(datastoreName)
280
280
  batch.delete(DsInfoName(name))
281
281
  await batch.commit()
282
282
 
@@ -317,27 +317,27 @@ export class Keychain implements KeychainInterface {
317
317
  await randomDelay()
318
318
  throw new InvalidParametersError(`Invalid new key name '${newName}'`)
319
319
  }
320
- const oldDsname = DsName(oldName)
321
- const newDsname = DsName(newName)
320
+ const oldDatastoreName = DsName(oldName)
321
+ const newDatastoreName = DsName(newName)
322
322
  const oldInfoName = DsInfoName(oldName)
323
323
  const newInfoName = DsInfoName(newName)
324
324
 
325
- const exists = await this.components.datastore.has(newDsname)
325
+ const exists = await this.components.datastore.has(newDatastoreName)
326
326
  if (exists) {
327
327
  await randomDelay()
328
328
  throw new InvalidParametersError(`Key '${newName}' already exists`)
329
329
  }
330
330
 
331
331
  try {
332
- const pem = await this.components.datastore.get(oldDsname)
332
+ const pem = await this.components.datastore.get(oldDatastoreName)
333
333
  const res = await this.components.datastore.get(oldInfoName)
334
334
 
335
335
  const keyInfo = JSON.parse(uint8ArrayToString(res))
336
336
  keyInfo.name = newName
337
337
  const batch = this.components.datastore.batch()
338
- batch.put(newDsname, pem)
338
+ batch.put(newDatastoreName, pem)
339
339
  batch.put(newInfoName, uint8ArrayFromString(JSON.stringify(keyInfo)))
340
- batch.delete(oldDsname)
340
+ batch.delete(oldDatastoreName)
341
341
  batch.delete(oldInfoName)
342
342
  await batch.commit()
343
343
  return keyInfo