@libp2p/keychain 4.1.6-dd7b329c4 → 4.1.6-e1ca9cced
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.js +3 -3
- package/dist/src/index.d.ts +31 -51
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +2 -2
- package/dist/src/index.js.map +1 -1
- package/dist/src/keychain.d.ts +9 -54
- package/dist/src/keychain.d.ts.map +1 -1
- package/dist/src/keychain.js +100 -255
- package/dist/src/keychain.js.map +1 -1
- package/dist/src/utils/constants.d.ts +4 -0
- package/dist/src/utils/constants.d.ts.map +1 -0
- package/dist/src/utils/constants.js +4 -0
- package/dist/src/utils/constants.js.map +1 -0
- package/dist/src/utils/export.d.ts +33 -0
- package/dist/src/utils/export.d.ts.map +1 -0
- package/dist/src/utils/export.js +183 -0
- package/dist/src/utils/export.js.map +1 -0
- package/dist/src/utils/import.d.ts +15 -0
- package/dist/src/utils/import.d.ts.map +1 -0
- package/dist/src/utils/import.js +137 -0
- package/dist/src/utils/import.js.map +1 -0
- package/package.json +9 -9
- package/src/index.ts +33 -56
- package/src/keychain.ts +113 -278
- package/src/utils/constants.ts +3 -0
- package/src/utils/export.ts +210 -0
- package/src/utils/import.ts +174 -0
- package/dist/src/errors.d.ts +0 -18
- package/dist/src/errors.d.ts.map +0 -1
- package/dist/src/errors.js +0 -19
- package/dist/src/errors.js.map +0 -1
- package/dist/src/util.d.ts +0 -12
- package/dist/src/util.d.ts.map +0 -1
- package/dist/src/util.js +0 -17
- package/dist/src/util.js.map +0 -1
- package/src/errors.ts +0 -17
- package/src/util.ts +0 -16
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PKeychain = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PKeychain=(()=>{var Jc=Object.create;var tn=Object.defineProperty;var Xc=Object.getOwnPropertyDescriptor;var Qc=Object.getOwnPropertyNames;var tl=Object.getPrototypeOf,el=Object.prototype.hasOwnProperty;var Ne=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ct=(r,t)=>{for(var e in t)tn(r,e,{get:t[e],enumerable:!0})},Qo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Qc(t))!el.call(r,s)&&s!==e&&tn(r,s,{get:()=>t[s],enumerable:!(n=Xc(t,s))||n.enumerable});return r};var xs=(r,t,e)=>(e=r!=null?Jc(tl(r)):{},Qo(t||!r||!r.__esModule?tn(e,"default",{value:r,enumerable:!0}):e,r)),rl=r=>Qo(tn({},"__esModule",{value:!0}),r);var ca=Ne(fr=>{"use strict";var _f="[object ArrayBuffer]",te=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===_f}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}},Bo="string",Nf=/^[0-9a-f]+$/i,Tf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Cf=/^[a-zA-Z0-9-_]+$/,Sn=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=te.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Rt=class{static toString(t,e=!1){let n=te.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}},kn=class r{static isHex(t){return typeof t===Bo&&Nf.test(t)}static isBase64(t){return typeof t===Bo&&Tf.test(t)}static isBase64Url(t){return typeof t===Bo&&Cf.test(t)}static ToString(t,e="utf8"){let n=te.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 Rt.toString(n,!0);case"utf16":case"utf16be":return Rt.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 Rt.fromString(t,!0);case"utf16":case"utf16be":return Rt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=te.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 Sn.fromString(t);case"utf16":case"utf16be":return Rt.fromString(t);case"utf16le":case"usc2":return Rt.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 Sn.toString(t);case"utf16":case"utf16be":return Rt.toString(t);case"utf16le":case"usc2":return Rt.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=te.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=te.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 Rt.toString(t,e)}static FromUtf16String(t,e=!1){return Rt.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,"")||""}};kn.DEFAULT_UTF8_ENCODING="utf8";function Lf(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 Uf(...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 Df(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}fr.BufferSourceConverter=te;fr.Convert=kn;fr.assign=Lf;fr.combine=Uf;fr.isEqual=Df});var Bc=Ne((Ay,vc)=>{"use strict";vc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var _c=Ne((Ic,Rc)=>{"use strict";var ys=Bc(),{hasOwnProperty:Sc}=Object.prototype,{propertyIsEnumerable:xh}=Object,wr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),Eh=Ic,Ac={concatArrays:!1,ignoreUndefined:!1},ms=r=>{let t=[];for(let e in r)Sc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)xh.call(r,n)&&t.push(n)}return t};function xr(r){return Array.isArray(r)?vh(r):ys(r)?Bh(r):r}function vh(r){let t=r.slice(0,0);return ms(r).forEach(e=>{wr(t,e,xr(r[e]))}),t}function Bh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return ms(r).forEach(e=>{wr(t,e,xr(r[e]))}),t}var kc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?wr(r,s,qo(r[s],t[s],n)):wr(r,s,xr(t[s])))}),r),Ah=(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++)Sc.call(o,a)&&(i.push(String(a)),o===r?wr(n,s++,o[a]):wr(n,s++,xr(o[a])));n=kc(n,o,ms(o).filter(a=>!i.includes(a)),e)}),n};function qo(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Ah(r,t,e):!ys(t)||!ys(r)?xr(t):kc(r,t,ms(t),e)}Rc.exports=function(...r){let t=qo(xr(Ac),this!==Eh&&this||{},Ac),e={_:{}};for(let n of r)if(n!==void 0){if(!ys(n))throw new TypeError("`"+n+"` is not an Option Object");e=qo(e,{_:n},t)}return e._}});var Lc=Ne((ky,Cc)=>{"use strict";function Sh(r){return r>=55296&&r<=56319}function kh(r){return r>=56320&&r<=57343}Cc.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],Sh(i)&&kh(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 Dc=Ne((Iy,Uc)=>{"use strict";function Ih(r){return r>=55296&&r<=56319}function Rh(r){return r>=56320&&r<=57343}Uc.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),Rh(s)?o!=null&&Ih(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 Oc=Ne((Ry,Vc)=>{"use strict";var _h=Lc(),Nh=Dc();Vc.exports=_h.bind(null,Nh)});var Pc=Ne((_y,Kc)=>{"use strict";var Th=Oc(),Ch=/[\/\?<>\\:\*\|"]/g,Lh=/[\x00-\x1f\x80-\x9f]/g,Uh=/^\.+$/,Dh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Vh=/[\. ]+$/;function Hc(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(Dh,t).replace(Vh,t);return Th(e,255)}Kc.exports=function(r,t){var e=t&&t.replacement||"",n=Hc(r,e);return e===""?n:Hc(n,"")}});var Kh={};ct(Kh,{keychain:()=>Hh});var mt={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var Es=Symbol.for("@libp2p/peer-id");var B=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var ti=Symbol.for("@libp2p/service-capabilities"),qh=Symbol.for("@libp2p/service-dependencies");var Eo={};ct(Eo,{Ed25519PrivateKey:()=>Fe,Ed25519PublicKey:()=>Lr,generateKeyPair:()=>Rf,generateKeyPairFromSeed:()=>na,unmarshalEd25519PrivateKey:()=>kf,unmarshalEd25519PublicKey:()=>If});var ks={};ct(ks,{base58btc:()=>bt,base58flickr:()=>cl});var pd=new Uint8Array(0);function ei(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 Yt(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 ri(r){return new TextEncoder().encode(r)}function ni(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(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var y=0,d=0,m=0,v=x.length;m!==v&&x[m]===0;)m++,y++;for(var g=(v-m)*l+1>>>0,A=new Uint8Array(g);m!==v;){for(var L=x[m],C=0,I=g-1;(L!==0||C<d)&&I!==-1;I--,C++)L+=256*A[I]>>>0,A[I]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");d=C,m++}for(var R=g-d;R!==g&&A[R]===0;)R++;for(var T=c.repeat(y);R<g;++R)T+=r.charAt(A[R]);return T}function h(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var y=0;if(x[y]!==" "){for(var d=0,m=0;x[y]===c;)d++,y++;for(var v=(x.length-y)*u+1>>>0,g=new Uint8Array(v);x[y];){var A=e[x.charCodeAt(y)];if(A===255)return;for(var L=0,C=v-1;(A!==0||L<m)&&C!==-1;C--,L++)A+=a*g[C]>>>0,g[C]=A%256>>>0,A=A/256>>>0;if(A!==0)throw new Error("Non-zero carry");m=L,y++}if(x[y]!==" "){for(var I=v-m;I!==v&&g[I]===0;)I++;for(var R=new Uint8Array(d+(v-I)),T=d;I!==v;)R[T++]=g[I++];return R}}}function w(x){var y=h(x);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:w}}var sl=nl,ol=sl,oi=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){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return ii(this,t)}},As=class{decoders;constructor(t){this.decoders=t}or(t){return ii(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 ii(r,t){return new As({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ss=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 Ye({name:r,prefix:t,encode:e,decode:n}){return new Ss(r,t,e,n)}function ue({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=oi(e,r);return Ye({prefix:t,name:r,encode:n,decode:o=>Yt(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 X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ye({prefix:t,name:r,encode(s){return al(s,n,e)},decode(s){return il(s,n,e,r)}})}var bt=ue({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),cl=ue({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Rs={};ct(Rs,{identity:()=>Gt});var ll=li,ai=128,ul=127,fl=~ul,hl=Math.pow(2,31);function li(r,t,e){t=t||[],e=e||0;for(var n=e;r>=hl;)t[e++]=r&255|ai,r/=128;for(;r&fl;)t[e++]=r&255|ai,r>>>=7;return t[e]=r|0,li.bytes=e-n+1,t}var dl=Is,pl=128,ci=127;function Is(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Is.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&ci)<<s:(i&ci)*Math.pow(2,s),s+=7}while(i>=pl);return Is.bytes=o-n,e}var gl=Math.pow(2,7),yl=Math.pow(2,14),ml=Math.pow(2,21),bl=Math.pow(2,28),wl=Math.pow(2,35),xl=Math.pow(2,42),El=Math.pow(2,49),vl=Math.pow(2,56),Bl=Math.pow(2,63),Al=function(r){return r<gl?1:r<yl?2:r<ml?3:r<bl?4:r<wl?5:r<xl?6:r<El?7:r<vl?8:r<Bl?9:10},Sl={encode:ll,decode:dl,encodingLength:Al},kl=Sl,Br=kl;function Ar(r,t=0){return[Br.decode(r,t),Br.decode.bytes]}function Ge(r,t,e=0){return Br.encode(r,t,e),t}function ze(r){return Br.encodingLength(r)}function Vt(r,t){let e=t.byteLength,n=ze(r),s=n+ze(e),o=new Uint8Array(s+e);return Ge(r,o,0),Ge(e,o,n),o.set(t,s),new We(r,e,t,o)}function Sr(r){let t=Yt(r),[e,n]=Ar(t),[s,o]=Ar(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new We(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&&ei(r.bytes,e.bytes)}}var We=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var fi=0,Il="identity",hi=Yt;function Rl(r){return Vt(fi,hi(r))}var Gt={code:fi,name:Il,encode:hi,digest:Rl};var Ts={};ct(Ts,{sha256:()=>ht,sha512:()=>_l});function Ns({name:r,code:t,encode:e}){return new _s(r,t,e)}var _s=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?Vt(this.code,e):e.then(n=>Vt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function pi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ht=Ns({name:"sha2-256",code:18,encode:pi("SHA-256")}),_l=Ns({name:"sha2-512",code:19,encode:pi("SHA-512")});function kt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ot(r=0){return new Uint8Array(r)}function Cs(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}var Ls={};ct(Ls,{base10:()=>Nl});var Nl=ue({prefix:"9",name:"base10",alphabet:"0123456789"});var Us={};ct(Us,{base16:()=>Tl,base16upper:()=>Cl});var Tl=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Cl=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ds={};ct(Ds,{base2:()=>Ll});var Ll=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Vs={};ct(Vs,{base256emoji:()=>Hl});var gi=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}"),Ul=gi.reduce((r,t,e)=>(r[e]=t,r),[]),Dl=gi.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Vl(r){return r.reduce((t,e)=>(t+=Ul[e],t),"")}function Ol(r){let t=[];for(let e of r){let n=Dl[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Hl=Ye({prefix:"\u{1F680}",name:"base256emoji",encode:Vl,decode:Ol});var Os={};ct(Os,{base32:()=>Je,base32hex:()=>Fl,base32hexpad:()=>ql,base32hexpadupper:()=>jl,base32hexupper:()=>$l,base32pad:()=>Pl,base32padupper:()=>Ml,base32upper:()=>Kl,base32z:()=>Yl});var Je=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Kl=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Pl=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Ml=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Fl=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),$l=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ql=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),jl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Yl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Hs={};ct(Hs,{base36:()=>Gl,base36upper:()=>zl});var Gl=ue({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),zl=ue({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ks={};ct(Ks,{base64:()=>Te,base64pad:()=>Wl,base64url:()=>Zl,base64urlpad:()=>Jl});var Te=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Wl=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Zl=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Jl=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ps={};ct(Ps,{base8:()=>Xl});var Xl=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ms={};ct(Ms,{identity:()=>Ql});var Ql=Ye({prefix:"\0",name:"identity",encode:r=>ni(r),decode:r=>ri(r)});var Fd=new TextEncoder,$d=new TextDecoder;function yi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return nu(e,Fs(r),t??bt.encoder);default:return su(e,Fs(r),t??Je.encoder)}}var mi=new WeakMap;function Fs(r){let t=mi.get(r);if(t==null){let e=new Map;return mi.set(r,e),e}return t}var fe=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!==kr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ou)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=Vt(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 yi(this,t)}toJSON(){return{"/":yi(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??bi(n,s,o.bytes))}else if(e[iu]===!0){let{version:n,multihash:s,code:o}=e,i=Sr(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!==kr)throw new Error(`Version 0 CID must use dag-pb (code: ${kr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=bi(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,kr,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=Yt(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 We(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]=Ar(t.subarray(e));return e+=h,f},s=n(),o=kr;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]=ru(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 Fs(o).set(n,t),o}};function ru(r,t){switch(r[0]){case"Q":{let e=t??bt;return[bt.prefix,e.decode(`${bt.prefix}${r}`)]}case bt.prefix:{let e=t??bt;return[bt.prefix,e.decode(r)]}case Je.prefix:{let e=t??Je;return[Je.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function nu(r,t,e){let{prefix:n}=e;if(n!==bt.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 su(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 kr=112,ou=18;function bi(r,t,e){let n=ze(r),s=n+ze(t),o=new Uint8Array(s+e.byteLength);return Ge(r,o,0),Ge(t,o,n),o.set(e,s),o}var iu=Symbol.for("@ipld/js-cid/CID");var Xe={...Ms,...Ds,...Ps,...Ls,...Us,...Os,...Hs,...ks,...Ks,...Vs},o0={...Ts,...Rs};function xi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var wi=xi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),$s=xi("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}),au={utf8:wi,"utf-8":wi,hex:Xe.base16,latin1:$s,ascii:$s,binary:$s,...Xe},rn=au;function P(r,t="utf8"){let e=rn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function It(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Qe(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function cu(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function tr(r,...t){if(!cu(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function nn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Qe(r.outputLen),Qe(r.blockLen)}function er(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 Ei(r,t){tr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Ce=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Le=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),_t=(r,t)=>r<<32-t|r>>>t,sn=(r,t)=>r<<t|r>>>32-t>>>0,w0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var lu=async()=>{};async function vi(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 lu(),n+=o)}}function Bi(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function he(r){return typeof r=="string"&&(r=Bi(r)),tr(r),r}function qs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];tr(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 rr=class{clone(){return this._cloneInto()}},uu={}.toString;function Ai(r,t){if(t!==void 0&&uu.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function nr(r){let t=n=>r().update(he(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function sr(r=32){if(Ce&&typeof Ce.getRandomValues=="function")return Ce.getRandomValues(new Uint8Array(r));if(Ce&&typeof Ce.randomBytes=="function")return Ce.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function fu(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var on=(r,t,e)=>r&t^~r&e,an=(r,t,e)=>r&t^r&e^t&e,de=class extends rr{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=Le(this.buffer)}update(t){er(this);let{view:e,buffer:n,blockLen:s}=this;t=he(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=Le(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){er(this),Ei(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;fu(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Le(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 cn=BigInt(4294967295),js=BigInt(32);function Si(r,t=!1){return t?{h:Number(r&cn),l:Number(r>>js&cn)}:{h:Number(r>>js&cn)|0,l:Number(r&cn)|0}}function hu(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}=Si(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var du=(r,t)=>BigInt(r>>>0)<<js|BigInt(t>>>0),pu=(r,t,e)=>r>>>e,gu=(r,t,e)=>r<<32-e|t>>>e,yu=(r,t,e)=>r>>>e|t<<32-e,mu=(r,t,e)=>r<<32-e|t>>>e,bu=(r,t,e)=>r<<64-e|t>>>e-32,wu=(r,t,e)=>r>>>e-32|t<<64-e,xu=(r,t)=>t,Eu=(r,t)=>r,vu=(r,t,e)=>r<<e|t>>>32-e,Bu=(r,t,e)=>t<<e|r>>>32-e,Au=(r,t,e)=>t<<e-32|r>>>64-e,Su=(r,t,e)=>r<<e-32|t>>>64-e;function ku(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Iu=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Ru=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,_u=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Nu=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Tu=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Cu=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Lu={fromBig:Si,split:hu,toBig:du,shrSH:pu,shrSL:gu,rotrSH:yu,rotrSL:mu,rotrBH:bu,rotrBL:wu,rotr32H:xu,rotr32L:Eu,rotlSH:vu,rotlSL:Bu,rotlBH:Au,rotlBL:Su,add:ku,add3L:Iu,add3H:Ru,add4L:_u,add4H:Nu,add5H:Cu,add5L:Tu},V=Lu;var[Uu,Du]=V.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))),pe=new Uint32Array(80),ge=new Uint32Array(80),Ys=class extends de{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:w,Gl:x,Hh:y,Hl:d}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,w,x,y,d]}set(t,e,n,s,o,i,a,c,u,l,f,h,w,x,y,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=w|0,this.Gl=x|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let g=0;g<16;g++,e+=4)pe[g]=t.getUint32(e),ge[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let A=pe[g-15]|0,L=ge[g-15]|0,C=V.rotrSH(A,L,1)^V.rotrSH(A,L,8)^V.shrSH(A,L,7),I=V.rotrSL(A,L,1)^V.rotrSL(A,L,8)^V.shrSL(A,L,7),R=pe[g-2]|0,T=ge[g-2]|0,rt=V.rotrSH(R,T,19)^V.rotrBH(R,T,61)^V.shrSH(R,T,6),q=V.rotrSL(R,T,19)^V.rotrBL(R,T,61)^V.shrSL(R,T,6),O=V.add4L(I,q,ge[g-7],ge[g-16]),nt=V.add4H(O,C,rt,pe[g-7],pe[g-16]);pe[g]=nt|0,ge[g]=O|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:w,Fl:x,Gh:y,Gl:d,Hh:m,Hl:v}=this;for(let g=0;g<80;g++){let A=V.rotrSH(f,h,14)^V.rotrSH(f,h,18)^V.rotrBH(f,h,41),L=V.rotrSL(f,h,14)^V.rotrSL(f,h,18)^V.rotrBL(f,h,41),C=f&w^~f&y,I=h&x^~h&d,R=V.add5L(v,L,I,Du[g],ge[g]),T=V.add5H(R,m,A,C,Uu[g],pe[g]),rt=R|0,q=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),O=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),nt=n&o^n&a^o&a,S=s&i^s&c^i&c;m=y|0,v=d|0,y=w|0,d=x|0,w=f|0,x=h|0,{h:f,l:h}=V.add(u|0,l|0,T|0,rt|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let _=V.add3L(rt,O,S);n=V.add3H(_,T,q,nt),s=_|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=V.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=V.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=V.add(this.Eh|0,this.El|0,f|0,h|0),{h:w,l:x}=V.add(this.Fh|0,this.Fl|0,w|0,x|0),{h:y,l:d}=V.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:m,l:v}=V.add(this.Hh|0,this.Hl|0,m|0,v|0),this.set(n,s,o,i,a,c,u,l,f,h,w,x,y,d,m,v)}roundClean(){pe.fill(0),ge.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Ue=nr(()=>new Ys);var un={};ct(un,{aInRange:()=>vt,abool:()=>Nt,abytes:()=>or,bitGet:()=>Mu,bitLen:()=>Js,bitMask:()=>Rr,bitSet:()=>Fu,bytesToHex:()=>Wt,bytesToNumberBE:()=>Zt,bytesToNumberLE:()=>me,concatBytes:()=>Jt,createHmacDrbg:()=>Xs,ensureBytes:()=>Q,equalBytes:()=>Ku,hexToBytes:()=>Ve,hexToNumber:()=>Zs,inRange:()=>Ir,isBytes:()=>ye,memoized:()=>He,notImplemented:()=>qu,numberToBytesBE:()=>be,numberToBytesLE:()=>Oe,numberToHexUnpadded:()=>De,numberToVarBytesBE:()=>Hu,utf8ToBytes:()=>Pu,validateObject:()=>Ht});var Ws=BigInt(0),ln=BigInt(1),Vu=BigInt(2);function ye(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function or(r){if(!ye(r))throw new Error("Uint8Array expected")}function Nt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var Ou=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Wt(r){or(r);let t="";for(let e=0;e<r.length;e++)t+=Ou[r[e]];return t}function De(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Zs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var zt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function ki(r){if(r>=zt._0&&r<=zt._9)return r-zt._0;if(r>=zt._A&&r<=zt._F)return r-(zt._A-10);if(r>=zt._a&&r<=zt._f)return r-(zt._a-10)}function Ve(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=ki(r.charCodeAt(o)),a=ki(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 Zt(r){return Zs(Wt(r))}function me(r){return or(r),Zs(Wt(Uint8Array.from(r).reverse()))}function be(r,t){return Ve(r.toString(16).padStart(t*2,"0"))}function Oe(r,t){return be(r,t).reverse()}function Hu(r){return Ve(De(r))}function Q(r,t,e){let n;if(typeof t=="string")try{n=Ve(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(ye(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function Jt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];or(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 Ku(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 Pu(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Gs=r=>typeof r=="bigint"&&Ws<=r;function Ir(r,t,e){return Gs(r)&&Gs(t)&&Gs(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!Ir(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function Js(r){let t;for(t=0;r>Ws;r>>=ln,t+=1);return t}function Mu(r,t){return r>>BigInt(t)&ln}function Fu(r,t,e){return r|(e?ln:Ws)<<BigInt(t)}var Rr=r=>(Vu<<BigInt(r-1))-ln,zs=r=>new Uint8Array(r),Ii=r=>Uint8Array.from(r);function Xs(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=zs(r),s=zs(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=zs())=>{s=a(Ii([0]),f),n=a(),f.length!==0&&(s=a(Ii([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 w=n.slice();h.push(w),f+=n.length}return Jt(...h)};return(f,h)=>{i(),c(f);let w;for(;!(w=h(u()));)c();return i(),w}}var $u={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"||ye(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ht(r,t,e={}){let n=(s,o,i)=>{let a=$u[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var qu=()=>{throw new Error("not implemented")};function He(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 ot=BigInt(0),Z=BigInt(1),Ke=BigInt(2),ju=BigInt(3),Qs=BigInt(4),Ri=BigInt(5),_i=BigInt(8),Yu=BigInt(9),Gu=BigInt(16);function G(r,t){let e=r%t;return e>=ot?e:t+e}function zu(r,t,e){if(e<=ot||t<ot)throw new Error("Expected power/modulo > 0");if(e===Z)return ot;let n=Z;for(;t>ot;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >ot;)n*=n,n%=e;return n}function fn(r,t){if(r===ot||t<=ot)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=G(r,t),n=t,s=ot,o=Z,i=Z,a=ot;for(;e!==ot;){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 G(s,t)}function Wu(r){let t=(r-Z)/Ke,e,n,s;for(e=r-Z,n=0;e%Ke===ot;e/=Ke,n++);for(s=Ke;s<r&&zu(s,t,r)!==r-Z;s++);if(n===1){let i=(r+Z)/Qs;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)/Ke;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 w=1;for(let y=a.sqr(h);w<u&&!a.eql(y,a.ONE);w++)y=a.sqr(y);let x=a.pow(l,Z<<BigInt(u-w-1));l=a.sqr(x),f=a.mul(f,x),h=a.mul(h,l),u=w}return f}}function Zu(r){if(r%Qs===ju){let t=(r+Z)/Qs;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%_i===Ri){let t=(r-Ri)/_i;return function(n,s){let o=n.mul(s,Ke),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ke),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%Gu,Wu(r)}var Ni=(r,t)=>(G(r,t)&Z)===Z,Ju=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function to(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Ju.reduce((n,s)=>(n[s]="function",n),t);return Ht(r,e)}function Xu(r,t,e){if(e<ot)throw new Error("Expected power > 0");if(e===ot)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>ot;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Qu(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 eo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function we(r,t,e=!1,n={}){if(r<=ot)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=eo(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Zu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:Rr(s),ZERO:ot,ONE:Z,create:c=>G(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ot<=c&&c<r},is0:c=>c===ot,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,u)=>c===u,sqr:c=>G(c*c,r),add:(c,u)=>G(c+u,r),sub:(c,u)=>G(c-u,r),mul:(c,u)=>G(c*u,r),pow:(c,u)=>Xu(a,c,u),div:(c,u)=>G(c*fn(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>fn(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Qu(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Oe(c,o):be(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?me(c):Zt(c)}});return Object.freeze(a)}function Ti(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 ro(r){let t=Ti(r);return t+Math.ceil(t/2)}function Ci(r,t,e=!1){let n=r.length,s=Ti(t),o=ro(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?Zt(r):me(r),a=G(i,t-Z)+Z;return e?Oe(a,s):be(a,s)}var ef=BigInt(0),no=BigInt(1),so=new WeakMap,Li=new WeakMap;function hn(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>ef;)i&no&&(a=a.add(c)),c=c.double(),i>>=no;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),u=[],l=o,f=l;for(let h=0;h<a;h++){f=l,u.push(f);for(let w=1;w<c;w++)f=f.add(l),u.push(f);l=f.double()}return u},wNAF(o,i,a){let{windows:c,windowSize:u}=s(o),l=r.ZERO,f=r.BASE,h=BigInt(2**o-1),w=2**o,x=BigInt(o);for(let y=0;y<c;y++){let d=y*u,m=Number(a&h);a>>=x,m>u&&(m-=w,a+=no);let v=d,g=d+Math.abs(m)-1,A=y%2!==0,L=m<0;m===0?f=f.add(e(A,i[v])):l=l.add(e(L,i[g]))}return{p:l,f}},wNAFCached(o,i,a){let c=Li.get(o)||1,u=so.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&so.set(o,a(u))),this.wNAF(c,u,i)},setWindowSize(o,i){n(i),Li.set(o,i),so.delete(o)}}}function dn(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,f)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${f}`)}),e.forEach((l,f)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${f}`)});let s=Js(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,u=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let w=n[h],x=Number(w>>BigInt(l)&BigInt(i));a[x]=a[x].add(e[h])}let f=r.ZERO;for(let h=a.length-1,w=r.ZERO;h>0;h--)w=w.add(a[h]),f=f.add(w);if(u=u.add(f),l!==0)for(let h=0;h<o;h++)u=u.double()}return u}function _r(r){return to(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...eo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Tt=BigInt(0),Bt=BigInt(1),pn=BigInt(2),rf=BigInt(8),nf={zip215:!0};function sf(r){let t=_r(r);return Ht(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=sf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=pn<<BigInt(a*8)-Bt,l=e.create,f=we(t.n,t.nBitLength),h=t.uvRatio||((b,p)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(p))}}catch{return{isValid:!1,value:Tt}}}),w=t.adjustScalarBytes||(b=>b),x=t.domain||((b,p,E)=>{if(Nt("phflag",E),p.length||E)throw new Error("Contexts/pre-hash are not supported");return b});function y(b,p){vt("coordinate "+b,p,Tt,u)}function d(b){if(!(b instanceof g))throw new Error("ExtendedPoint expected")}let m=He((b,p)=>{let{ex:E,ey:N,ez:U}=b,D=b.is0();p==null&&(p=D?rf:e.inv(U));let H=l(E*p),F=l(N*p),K=l(U*p);if(D)return{x:Tt,y:Bt};if(K!==Bt)throw new Error("invZ was invalid");return{x:H,y:F}}),v=He(b=>{let{a:p,d:E}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:N,ey:U,ez:D,et:H}=b,F=l(N*N),K=l(U*U),Y=l(D*D),W=l(Y*Y),it=l(F*p),at=l(Y*l(it+K)),ft=l(W+l(E*l(F*K)));if(at!==ft)throw new Error("bad point: equation left != right (1)");let yt=l(N*U),st=l(D*H);if(yt!==st)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,E,N,U){this.ex=p,this.ey=E,this.ez=N,this.et=U,y("x",p),y("y",E),y("z",N),y("t",U),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:E,y:N}=p||{};return y("x",E),y("y",N),new g(E,N,Bt,l(E*N))}static normalizeZ(p){let E=e.invertBatch(p.map(N=>N.ez));return p.map((N,U)=>N.toAffine(E[U])).map(g.fromAffine)}static msm(p,E){return dn(g,f,p,E)}_setWindowSize(p){C.setWindowSize(this,p)}assertValidity(){v(this)}equals(p){d(p);let{ex:E,ey:N,ez:U}=this,{ex:D,ey:H,ez:F}=p,K=l(E*F),Y=l(D*U),W=l(N*F),it=l(H*U);return K===Y&&W===it}is0(){return this.equals(g.ZERO)}negate(){return new g(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:p}=t,{ex:E,ey:N,ez:U}=this,D=l(E*E),H=l(N*N),F=l(pn*l(U*U)),K=l(p*D),Y=E+N,W=l(l(Y*Y)-D-H),it=K+H,at=it-F,ft=K-H,yt=l(W*at),st=l(it*ft),Et=l(W*ft),jt=l(at*it);return new g(yt,st,jt,Et)}add(p){d(p);let{a:E,d:N}=t,{ex:U,ey:D,ez:H,et:F}=this,{ex:K,ey:Y,ez:W,et:it}=p;if(E===BigInt(-1)){let Yo=l((D-U)*(Y+K)),Go=l((D+U)*(Y-K)),ws=l(Go-Yo);if(ws===Tt)return this.double();let zo=l(H*pn*it),Wo=l(F*pn*W),Zo=Wo+zo,Jo=Go+Yo,Xo=Wo-zo,Gc=l(Zo*ws),zc=l(Jo*Xo),Wc=l(Zo*Xo),Zc=l(ws*Jo);return new g(Gc,zc,Zc,Wc)}let at=l(U*K),ft=l(D*Y),yt=l(F*N*it),st=l(H*W),Et=l((U+D)*(K+Y)-at-ft),jt=st-yt,Er=st+yt,vr=l(ft-E*at),$c=l(Et*jt),qc=l(Er*vr),jc=l(Et*vr),Yc=l(jt*Er);return new g($c,qc,Yc,jc)}subtract(p){return this.add(p.negate())}wNAF(p){return C.wNAFCached(this,p,g.normalizeZ)}multiply(p){let E=p;vt("scalar",E,Bt,n);let{p:N,f:U}=this.wNAF(E);return g.normalizeZ([N,U])[0]}multiplyUnsafe(p){let E=p;return vt("scalar",E,Tt,n),E===Tt?L:this.equals(L)||E===Bt?this:this.equals(A)?this.wNAF(E).p:C.unsafeLadder(this,E)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return C.unsafeLadder(this,n).is0()}toAffine(p){return m(this,p)}clearCofactor(){let{h:p}=t;return p===Bt?this:this.multiplyUnsafe(p)}static fromHex(p,E=!1){let{d:N,a:U}=t,D=e.BYTES;p=Q("pointHex",p,D),Nt("zip215",E);let H=p.slice(),F=p[D-1];H[D-1]=F&-129;let K=me(H),Y=E?u:e.ORDER;vt("pointHex.y",K,Tt,Y);let W=l(K*K),it=l(W-Bt),at=l(N*W-U),{isValid:ft,value:yt}=h(it,at);if(!ft)throw new Error("Point.fromHex: invalid y coordinate");let st=(yt&Bt)===Bt,Et=(F&128)!==0;if(!E&&yt===Tt&&Et)throw new Error("Point.fromHex: x=0 and x_0=1");return Et!==st&&(yt=l(-yt)),g.fromAffine({x:yt,y:K})}static fromPrivateKey(p){return T(p).point}toRawBytes(){let{x:p,y:E}=this.toAffine(),N=Oe(E,e.BYTES);return N[N.length-1]|=p&Bt?128:0,N}toHex(){return Wt(this.toRawBytes())}}g.BASE=new g(t.Gx,t.Gy,Bt,l(t.Gx*t.Gy)),g.ZERO=new g(Tt,Bt,Bt,Tt);let{BASE:A,ZERO:L}=g,C=hn(g,a*8);function I(b){return G(b,n)}function R(b){return I(me(b))}function T(b){let p=a;b=Q("private key",b,p);let E=Q("hashed private key",o(b),2*p),N=w(E.slice(0,p)),U=E.slice(p,2*p),D=R(N),H=A.multiply(D),F=H.toRawBytes();return{head:N,prefix:U,scalar:D,point:H,pointBytes:F}}function rt(b){return T(b).pointBytes}function q(b=new Uint8Array,...p){let E=Jt(...p);return R(o(x(E,Q("context",b),!!s)))}function O(b,p,E={}){b=Q("message",b),s&&(b=s(b));let{prefix:N,scalar:U,pointBytes:D}=T(p),H=q(E.context,N,b),F=A.multiply(H).toRawBytes(),K=q(E.context,F,D,b),Y=I(H+K*U);vt("signature.s",Y,Tt,n);let W=Jt(F,Oe(Y,e.BYTES));return Q("result",W,a*2)}let nt=nf;function S(b,p,E,N=nt){let{context:U,zip215:D}=N,H=e.BYTES;b=Q("signature",b,2*H),p=Q("message",p),D!==void 0&&Nt("zip215",D),s&&(p=s(p));let F=me(b.slice(H,2*H)),K,Y,W;try{K=g.fromHex(E,D),Y=g.fromHex(b.slice(0,H),D),W=A.multiplyUnsafe(F)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let it=q(U,Y.toRawBytes(),K.toRawBytes(),p);return Y.add(K.multiplyUnsafe(it)).subtract(W).clearCofactor().equals(g.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:rt,sign:O,verify:S,ExtendedPoint:g,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,p=g.BASE){return p._setWindowSize(b),p.multiply(BigInt(3)),p}}}}var oo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Di=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),F0=BigInt(0),of=BigInt(1),Vi=BigInt(2),$0=BigInt(3),af=BigInt(5),cf=BigInt(8);function lf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=oo,a=r*r%o*r%o,c=J(a,Vi,o)*a%o,u=J(c,of,o)*r%o,l=J(u,af,o)*u%o,f=J(l,t,o)*l%o,h=J(f,e,o)*f%o,w=J(h,n,o)*h%o,x=J(w,s,o)*w%o,y=J(x,s,o)*w%o,d=J(y,t,o)*l%o;return{pow_p_5_8:J(d,Vi,o)*r%o,b2:a}}function uf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ff(r,t){let e=oo,n=G(t*t*t,e),s=G(n*n*t,e),o=lf(r*s).pow_p_5_8,i=G(r*n*o,e),a=G(t*i*i,e),c=i,u=G(i*Di,e),l=a===r,f=a===G(-r,e),h=a===G(-r*Di,e);return l&&(i=c),(f||h)&&(i=u),Ni(i,e)&&(i=G(-i,e)),{isValid:l||f,value:i}}var hf=we(oo,void 0,!0),df={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:hf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:cf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ue,randomBytes:sr,adjustScalarBytes:uf,uvRatio:ff},ir=Ui(df);var ar=32,Xt=64,gn=32;function Oi(){let r=ir.utils.randomPrivateKey(),t=ir.getPublicKey(r);return{privateKey:Mi(r,t),publicKey:t}}function Hi(r){if(r.length!==gn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=ir.getPublicKey(t);return{privateKey:Mi(t,e),publicKey:e}}function Ki(r,t){let e=r.subarray(0,gn);return ir.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Pi(r,t,e){return ir.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Mi(r,t){let e=new Uint8Array(Xt);for(let n=0;n<gn;n++)e[n]=r[n],e[gn+n]=t[n];return e}var io={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function yn(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=mt.get();e*=8;async function c(f,h){let w=a.getRandomValues(new Uint8Array(o)),x=a.getRandomValues(new Uint8Array(n)),y={name:t,iv:x};typeof h=="string"&&(h=P(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",io,{name:"AES-GCM"},!0,["encrypt"]);try{let v={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(v,g,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",io,{name:"AES-GCM"},!0,["encrypt"])}}else{let v={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(v,g,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(y,d,f);return Cs([w,y.iv,new Uint8Array(m)])}async function u(f,h){let w=f.subarray(0,o),x=f.subarray(o,o+n),y=f.subarray(o+n),d={name:t,iv:x};typeof h=="string"&&(h=P(h));let m;if(h.length===0)try{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(g,A,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",io,{name:"AES-GCM"},!0,["decrypt"])}else{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(g,A,{name:t,length:e},!0,["decrypt"])}let v=await a.subtle.decrypt(d,m,y);return new Uint8Array(v)}return{encrypt:c,decrypt:u}}async function cr(r,t){let n=await yn().encrypt(r,t);return Te.encode(n)}var gf=Math.pow(2,7),yf=Math.pow(2,14),mf=Math.pow(2,21),$i=Math.pow(2,28),qi=Math.pow(2,35),ji=Math.pow(2,42),Yi=Math.pow(2,49),wt=128,xe=127;function Nr(r){if(r<gf)return 1;if(r<yf)return 2;if(r<mf)return 3;if(r<$i)return 4;if(r<qi)return 5;if(r<ji)return 6;if(r<Yi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Gi(r,t,e=0){switch(Nr(r)){case 8:t[e++]=r&255|wt,r/=128;case 7:t[e++]=r&255|wt,r/=128;case 6:t[e++]=r&255|wt,r/=128;case 5:t[e++]=r&255|wt,r/=128;case 4:t[e++]=r&255|wt,r>>>=7;case 3:t[e++]=r&255|wt,r>>>=7;case 2:t[e++]=r&255|wt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function zi(r,t){let e=r[t],n=0;if(n+=e&xe,e<wt||(e=r[t+1],n+=(e&xe)<<7,e<wt)||(e=r[t+2],n+=(e&xe)<<14,e<wt)||(e=r[t+3],n+=(e&xe)<<21,e<wt)||(e=r[t+4],n+=(e&xe)*$i,e<wt)||(e=r[t+5],n+=(e&xe)*qi,e<wt)||(e=r[t+6],n+=(e&xe)*ji,e<wt)||(e=r[t+7],n+=(e&xe)*Yi,e<wt))return n;throw new RangeError("Could not decode varint")}var ao=new Float32Array([-0]),Ee=new Uint8Array(ao.buffer);function Wi(r,t,e){ao[0]=r,t[e]=Ee[0],t[e+1]=Ee[1],t[e+2]=Ee[2],t[e+3]=Ee[3]}function Zi(r,t){return Ee[0]=r[t],Ee[1]=r[t+1],Ee[2]=r[t+2],Ee[3]=r[t+3],ao[0]}var co=new Float64Array([-0]),pt=new Uint8Array(co.buffer);function Ji(r,t,e){co[0]=r,t[e]=pt[0],t[e+1]=pt[1],t[e+2]=pt[2],t[e+3]=pt[3],t[e+4]=pt[4],t[e+5]=pt[5],t[e+6]=pt[6],t[e+7]=pt[7]}function Xi(r,t){return pt[0]=r[t],pt[1]=r[t+1],pt[2]=r[t+2],pt[3]=r[t+3],pt[4]=r[t+4],pt[5]=r[t+5],pt[6]=r[t+6],pt[7]=r[t+7],co[0]}var bf=BigInt(Number.MAX_SAFE_INTEGER),wf=BigInt(Number.MIN_SAFE_INTEGER),St=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 Pe;if(t<bf&&t>wf)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>Qi&&(s=0n,++n>Qi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Pe;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):Pe}},Pe=new St(0,0);Pe.toBigInt=function(){return 0n};Pe.zzEncode=Pe.zzDecode=function(){return this};Pe.length=function(){return 1};var Qi=4294967296n;function ta(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 ea(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 lo(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 Ct(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function mn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var uo=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,Ct(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 Ct(this,4);return mn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ct(this,4);return mn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ct(this,4);let t=Zi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ct(this,4);let t=Xi(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 Ct(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ea(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ct(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ct(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 St(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 Ct(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 Ct(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 Ct(this,8);let t=mn(this.buf,this.pos+=4),e=mn(this.buf,this.pos+=4);return new St(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=zi(this.buf,this.pos);return this.pos+=Nr(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 fo(r){return new uo(r instanceof Uint8Array?r:r.subarray())}function bn(r,t,e){let n=fo(r);return t.decode(n,void 0,e)}function ho(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 Me=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function po(){}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}},xf=ho();function Ef(r){return globalThis.Buffer!=null?Ot(r):xf(r)}var Cr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Me(po,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Me(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new mo((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(wn,10,St.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=St.fromBigInt(t);return this._push(wn,e.length(),e)}uint64Number(t){return this._push(Gi,Nr(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=St.fromBigInt(t).zzEncode();return this._push(wn,e.length(),e)}sint64Number(t){let e=St.fromNumber(t).zzEncode();return this._push(wn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(go,1,t?1:0)}fixed32(t){return this._push(Tr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=St.fromBigInt(t);return this._push(Tr,4,e.lo)._push(Tr,4,e.hi)}fixed64Number(t){let e=St.fromNumber(t);return this._push(Tr,4,e.lo)._push(Tr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Wi,4,t)}double(t){return this._push(Ji,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(go,1,0):this.uint32(e)._push(Bf,e,t)}string(t){let e=ta(t);return e!==0?this.uint32(e)._push(lo,e,t):this._push(go,1,0)}fork(){return this.states=new yo(this),this.head=this.tail=new Me(po,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 Me(po,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=Ef(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function go(r,t,e){t[e]=r&255}function vf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var mo=class extends Me{next;constructor(t,e){super(vf,t,e),this.next=void 0}};function wn(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 Tr(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 Bf(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(Af,t,r),this},Cr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Sf,t,r),this});function Af(r,t,e){t.set(r,e)}function Sf(r,t,e){r.length<40?lo(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(P(r),e)}function bo(){return new Cr}function xn(r,t){let e=bo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var lr;(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"})(lr||(lr={}));function En(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function wo(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 En("enum",lr.VARINT,e,n)}function vn(r,t){return En("message",lr.LENGTH_DELIMITED,r,t)}var tt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(tt||(tt={}));var xo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(xo||(xo={}));(function(r){r.codec=()=>wo(xo)})(tt||(tt={}));var Qt;(function(r){let t;r.codec=()=>(t==null&&(t=vn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),tt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=tt.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>xn(e,r.codec()),r.decode=e=>bn(e,r.codec())})(Qt||(Qt={}));var Kt;(function(r){let t;r.codec=()=>(t==null&&(t=vn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),tt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=tt.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>xn(e,r.codec()),r.decode=e=>bn(e,r.codec())})(Kt||(Kt={}));var Lr=class{_key;constructor(t){this._key=ur(t,ar)}verify(t,e){return Pi(this._key,e,t)}marshal(){return this._key}get bytes(){return Qt.encode({Type:tt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return It(t)?t.then(({bytes:e})=>e):t.bytes}},Fe=class{_key;_publicKey;constructor(t,e){this._key=ur(t,Xt),this._publicKey=ur(e,ar)}sign(t){return Ki(this._key,t)}get public(){return new Lr(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:tt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return It(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Gt.digest(this.public.bytes);return bt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return cr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function kf(r){if(r.length>Xt){r=ur(r,Xt+ar);let n=r.subarray(0,Xt),s=r.subarray(Xt,r.length);return new Fe(n,s)}r=ur(r,Xt);let t=r.subarray(0,Xt),e=r.subarray(ar);return new Fe(t,e)}function If(r){return r=ur(r,ar),new Lr(r)}async function Rf(){let{privateKey:r,publicKey:t}=Oi();return new Fe(r,t)}async function na(r){let{privateKey:t,publicKey:e}=Hi(r);return new Fe(t,e)}function ur(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new B(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function j(r,t="utf8"){let e=rn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}async function sa(r,t){let e=Te.decode(r);return yn().decrypt(e,t)}var Co={};ct(Co,{MAX_RSA_KEY_SIZE:()=>jr,RsaPrivateKey:()=>gr,RsaPublicKey:()=>qr,fromJwk:()=>Xf,generateKeyPair:()=>Qf,unmarshalRsaPrivateKey:()=>No,unmarshalRsaPublicKey:()=>Jf});function Pt(r){if(isNaN(r)||r<=0)throw new B("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return sr(r)}var Se={};ct(Se,{exportToPem:()=>Gf,importFromPem:()=>_o,jwkToPkcs1:()=>$f,jwkToPkix:()=>jf,pkcs1ToJwk:()=>Ff,pkixToJwk:()=>qf});var An=class extends rr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,nn(t);let n=he(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 er(this),this.iHash.update(t),this}digestInto(t){er(this),tr(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()}},Ur=(r,t,e)=>new An(r,t).update(e).digest();Ur.create=(r,t)=>new An(r,t);function oa(r,t,e,n){nn(r);let s=Ai({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Qe(o),Qe(i),Qe(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=he(t),u=he(e),l=new Uint8Array(i),f=Ur.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function ia(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function aa(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=oa(r,t,e,n),u,l=new Uint8Array(4),f=Le(l),h=new Uint8Array(a.outputLen);for(let w=1,x=0;x<o;w++,x+=a.outputLen){let y=i.subarray(x,x+a.outputLen);f.setInt32(0,w,!1),(u=c._cloneInto(u)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(u).update(h).digestInto(h);for(let m=0;m<y.length;m++)y[m]^=h[m]}}return ia(a,c,i,u,h)}async function vo(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=oa(r,t,e,n),l,f=new Uint8Array(4),h=Le(f),w=new Uint8Array(c.outputLen);for(let x=1,y=0;y<o;x++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,x,!1),(l=u._cloneInto(l)).update(f).digestInto(w),d.set(w.subarray(0,d.length)),await vi(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<d.length;m++)d[m]^=w[m]})}return ia(c,u,a,l,w)}var M=xs(ca());function $e(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 ve(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 In(...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=$e(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,$e(o,8)-n}function la(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=ve(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ve(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 ua(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 At(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 Qp=Math.log(2);function Rn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function So(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 se(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 Vr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return So(this.items)}},Dr=[new Uint8Array([1])],fa="0123456789";var dr="",Ut=new ArrayBuffer(0),ko=new Uint8Array(0),Or="EndOfContent",da="OCTET STRING",pa="BIT STRING";function oe(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):ko}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(!se(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 ee=class{constructor({blockLength:t=0,error:e=dr,warnings:n=[],valueBeforeDecode:s=ko}={}){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)}}};ee.NAME="baseBlock";var gt=class extends ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};gt.NAME="valueBlock";var _n=class extends oe(ee){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):ko,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=ve(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(!se(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 w=0;w<u.length;w++)h[w]=u[w];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=$e(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}}};_n.NAME="identificationBlock";var Nn=class extends ee{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(!se(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=$e(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=ve(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}}};Nn.NAME="lengthBlock";var k={},dt=class extends ee{constructor({name:t=dr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new _n(s),this.lenBlock=new Nn(s),this.valueBlock=o?new o(s):new gt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Vr;e||ga(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 ua(e,n)}};dt.NAME="BaseBlock";function ga(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)ga(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Tn=class extends dt{constructor({value:t=dr,...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}'`}};Tn.NAME="BaseStringBlock";var Cn=class extends oe(gt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Cn.NAME="PrimitiveValueBlock";var ya,Ln=class extends dt{constructor(t={}){super(t,Cn),this.idBlock.isConstructed=!1}};ya=Ln;k.Primitive=ya;Ln.NAME="PRIMITIVE";function Of(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 hs(r,t=0,e=r.length){let n=t,s=new dt({},gt),o=new ee;if(!se(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=dt;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let u=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Of(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 pr(r){if(!r.byteLength){let t=new dt({},gt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return hs(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Hf(r,t){return r?1:t}var Mt=class extends gt{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(!se(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=hs(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===Or)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Or?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Vr;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}};Mt.NAME="ConstructedValueBlock";var ma,Be=class extends dt{constructor(t={}){super(t,Mt),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 qc=Object.create;var zr=Object.defineProperty;var jc=Object.getOwnPropertyDescriptor;var zc=Object.getOwnPropertyNames;var Gc=Object.getPrototypeOf,Zc=Object.prototype.hasOwnProperty;var Be=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ht=(r,t)=>{for(var e in t)zr(r,e,{get:t[e],enumerable:!0})},zo=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of zc(t))!Zc.call(r,s)&&s!==e&&zr(r,s,{get:()=>t[s],enumerable:!(n=jc(t,s))||n.enumerable});return r};var ys=(r,t,e)=>(e=r!=null?qc(Gc(r)):{},zo(t||!r||!r.__esModule?zr(e,"default",{value:r,enumerable:!0}):e,r)),Wc=r=>zo(zr({},"__esModule",{value:!0}),r);var Ji=Be(tr=>{"use strict";var xf="[object ArrayBuffer]",Gt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===xf}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}},wo="string",vf=/^[0-9a-f]+$/i,Bf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Ef=/^[a-zA-Z0-9-_]+$/,yn=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=Gt.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=Gt.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}},bn=class r{static isHex(t){return typeof t===wo&&vf.test(t)}static isBase64(t){return typeof t===wo&&Bf.test(t)}static isBase64Url(t){return typeof t===wo&&Ef.test(t)}static ToString(t,e="utf8"){let n=Gt.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=Gt.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 yn.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 yn.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=Gt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Gt.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,"")||""}};bn.DEFAULT_UTF8_ENCODING="utf8";function Af(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 kf(...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 Sf(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}tr.BufferSourceConverter=Gt;tr.Convert=bn;tr.assign=Af;tr.combine=kf;tr.isEqual=Sf});var pc=Be((cm,dc)=>{"use strict";dc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var xc=Be((bc,wc)=>{"use strict";var hs=pc(),{hasOwnProperty:mc}=Object.prototype,{propertyIsEnumerable:jf}=Object,or=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),zf=bc,gc={concatArrays:!1,ignoreUndefined:!1},ds=r=>{let t=[];for(let e in r)mc.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 ir(r){return Array.isArray(r)?Gf(r):hs(r)?Zf(r):r}function Gf(r){let t=r.slice(0,0);return ds(r).forEach(e=>{or(t,e,ir(r[e]))}),t}function Zf(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return ds(r).forEach(e=>{or(t,e,ir(r[e]))}),t}var yc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?or(r,s,Lo(r[s],t[s],n)):or(r,s,ir(t[s])))}),r),Wf=(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++)mc.call(o,a)&&(i.push(String(a)),o===r?or(n,s++,o[a]):or(n,s++,ir(o[a])));n=yc(n,o,ds(o).filter(a=>!i.includes(a)),e)}),n};function Lo(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Wf(r,t,e):!hs(t)||!hs(r)?ir(t):yc(r,t,ds(t),e)}wc.exports=function(...r){let t=Lo(ir(gc),this!==zf&&this||{},gc),e={_:{}};for(let n of r)if(n!==void 0){if(!hs(n))throw new TypeError("`"+n+"` is not an Option Object");e=Lo(e,{_:n},t)}return e._}});var Ac=Be((um,Ec)=>{"use strict";function Jf(r){return r>=55296&&r<=56319}function Yf(r){return r>=56320&&r<=57343}Ec.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],Jf(i)&&Yf(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 Sc=Be((fm,kc)=>{"use strict";function Xf(r){return r>=55296&&r<=56319}function Qf(r){return r>=56320&&r<=57343}kc.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),Qf(s)?o!=null&&Xf(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 Nc=Be((hm,Ic)=>{"use strict";var th=Ac(),eh=Sc();Ic.exports=th.bind(null,eh)});var Uc=Be((dm,Tc)=>{"use strict";var rh=Nc(),nh=/[\/\?<>\\:\*\|"]/g,sh=/[\x00-\x1f\x80-\x9f]/g,oh=/^\.+$/,ih=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,ah=/[\. ]+$/;function Cc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(nh,t).replace(sh,t).replace(oh,t).replace(ih,t).replace(ah,t);return rh(e,255)}Tc.exports=function(r,t){var e=t&&t.replacement||"",n=Cc(r,e);return e===""?n:Cc(n,"")}});var wh={};ht(wh,{keychain:()=>bh});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"}},Gr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Go={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Gr("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=Go;var _=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},De=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 Zr=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Ke=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Zo=Symbol.for("@libp2p/service-capabilities"),Ih=Symbol.for("@libp2p/service-dependencies");var Bs={};ht(Bs,{base58btc:()=>it,base58flickr:()=>el});var Yh=new Uint8Array(0);function Wo(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Mt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Jo(r){return new TextEncoder().encode(r)}function Yo(r){return new TextDecoder().decode(r)}function Jc(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(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var m=0,d=0,y=0,B=x.length;y!==B&&x[y]===0;)y++,m++;for(var g=(B-y)*l+1>>>0,E=new Uint8Array(g);y!==B;){for(var R=x[y],U=0,S=g-1;(R!==0||U<d)&&S!==-1;S--,U++)R+=256*E[S]>>>0,E[S]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=U,y++}for(var I=g-d;I!==g&&E[I]===0;)I++;for(var T=c.repeat(m);I<g;++I)T+=r.charAt(E[I]);return T}function h(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var m=0;if(x[m]!==" "){for(var d=0,y=0;x[m]===c;)d++,m++;for(var B=(x.length-m)*u+1>>>0,g=new Uint8Array(B);x[m];){var E=e[x.charCodeAt(m)];if(E===255)return;for(var R=0,U=B-1;(E!==0||R<y)&&U!==-1;U--,R++)E+=a*g[U]>>>0,g[U]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");y=R,m++}if(x[m]!==" "){for(var S=B-y;S!==B&&g[S]===0;)S++;for(var I=new Uint8Array(d+(B-S)),T=d;S!==B;)I[T++]=g[S++];return I}}}function w(x){var m=h(x);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:w}}var Yc=Jc,Xc=Yc,Qo=Xc;var bs=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")}},ws=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return ti(this,t)}},xs=class{decoders;constructor(t){this.decoders=t}or(t){return ti(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 ti(r,t){return new xs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var vs=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 bs(t,e,n),this.decoder=new ws(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Me({name:r,prefix:t,encode:e,decode:n}){return new vs(r,t,e,n)}function ne({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Qo(e,r);return Me({prefix:t,name:r,encode:n,decode:o=>Mt(s(o))})}function Qc(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 tl(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 J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Me({prefix:t,name:r,encode(s){return tl(s,n,e)},decode(s){return Qc(s,n,e,r)}})}var it=ne({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),el=ne({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Es={};ht(Es,{base32:()=>Pe,base32hex:()=>ol,base32hexpad:()=>al,base32hexpadupper:()=>cl,base32hexupper:()=>il,base32pad:()=>nl,base32padupper:()=>sl,base32upper:()=>rl,base32z:()=>ll});var Pe=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),rl=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),nl=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),sl=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ol=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),il=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),al=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),cl=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ll=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ul=ni,ei=128,fl=127,hl=~fl,dl=Math.pow(2,31);function ni(r,t,e){t=t||[],e=e||0;for(var n=e;r>=dl;)t[e++]=r&255|ei,r/=128;for(;r&hl;)t[e++]=r&255|ei,r>>>=7;return t[e]=r|0,ni.bytes=e-n+1,t}var pl=As,gl=128,ri=127;function As(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw As.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&ri)<<s:(i&ri)*Math.pow(2,s),s+=7}while(i>=gl);return As.bytes=o-n,e}var ml=Math.pow(2,7),yl=Math.pow(2,14),bl=Math.pow(2,21),wl=Math.pow(2,28),xl=Math.pow(2,35),vl=Math.pow(2,42),Bl=Math.pow(2,49),El=Math.pow(2,56),Al=Math.pow(2,63),kl=function(r){return r<ml?1:r<yl?2:r<bl?3:r<wl?4:r<xl?5:r<vl?6:r<Bl?7:r<El?8:r<Al?9:10},Sl={encode:ul,decode:pl,encodingLength:kl},Il=Sl,gr=Il;function mr(r,t=0){return[gr.decode(r,t),gr.decode.bytes]}function Fe(r,t,e=0){return gr.encode(r,t,e),t}function $e(r){return gr.encodingLength(r)}function St(r,t){let e=t.byteLength,n=$e(r),s=n+$e(e),o=new Uint8Array(s+e);return Fe(r,o,0),Fe(e,o,n),o.set(t,s),new qe(r,e,t,o)}function si(r){let t=Mt(r),[e,n]=mr(t),[s,o]=mr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new qe(e,s,i,t)}function oi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wo(r.bytes,e.bytes)}}var qe=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function ii(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Cl(e,ks(r),t??it.encoder);default:return Tl(e,ks(r),t??Pe.encoder)}}var ai=new WeakMap;function ks(r){let t=ai.get(r);if(t==null){let e=new Map;return ai.set(r,e),e}return t}var Lt=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!==Ul)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&&oi(t.multihash,n.multihash)}toString(t){return ii(this,t)}toJSON(){return{"/":ii(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??ci(n,s,o.bytes))}else if(e[Rl]===!0){let{version:n,multihash:s,code:o}=e,i=si(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=ci(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=Mt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new qe(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]=mr(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]=Nl(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 ks(o).set(n,t),o}};function Nl(r,t){switch(r[0]){case"Q":{let e=t??it;return[it.prefix,e.decode(`${it.prefix}${r}`)]}case it.prefix:{let e=t??it;return[it.prefix,e.decode(r)]}case Pe.prefix:{let e=t??Pe;return[Pe.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Cl(r,t,e){let{prefix:n}=e;if(n!==it.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 Tl(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,Ul=18;function ci(r,t,e){let n=$e(r),s=n+$e(t),o=new Uint8Array(s+e.byteLength);return Fe(r,o,0),Fe(t,o,n),o.set(e,s),o}var Rl=Symbol.for("@ipld/js-cid/CID");var Ss={};ht(Ss,{identity:()=>wr});var li=0,Ll="identity",ui=Mt;function _l(r){return St(li,ui(r))}var wr={code:li,name:Ll,encode:ui,digest:_l};function Pt(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 je(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Hl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function ze(r,...t){if(!Hl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Jr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");je(r.outputLen),je(r.blockLen)}function Ge(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function fi(r,t){ze(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Ee=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Ae=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),It=(r,t)=>r<<32-t|r>>>t,Yr=(r,t)=>r<<t|r>>>32-t>>>0,bd=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Vl=async()=>{};async function hi(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 Vl(),n+=o)}}function di(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function se(r){return typeof r=="string"&&(r=di(r)),ze(r),r}function Is(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ze(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var Ze=class{clone(){return this._cloneInto()}},Ol={}.toString;function pi(r,t){if(t!==void 0&&Ol.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function We(r){let t=n=>r().update(se(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Je(r=32){if(Ee&&typeof Ee.getRandomValues=="function")return Ee.getRandomValues(new Uint8Array(r));if(Ee&&typeof Ee.randomBytes=="function")return Ee.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Dl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var Xr=(r,t,e)=>r&t^~r&e,Qr=(r,t,e)=>r&t^r&e^t&e,oe=class extends Ze{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Ae(this.buffer)}update(t){Ge(this);let{view:e,buffer:n,blockLen:s}=this;t=se(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=Ae(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ge(this),fi(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;Dl(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Ae(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 tn=BigInt(4294967295),Ns=BigInt(32);function gi(r,t=!1){return t?{h:Number(r&tn),l:Number(r>>Ns&tn)}:{h:Number(r>>Ns&tn)|0,l:Number(r&tn)|0}}function Kl(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}=gi(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Ml=(r,t)=>BigInt(r>>>0)<<Ns|BigInt(t>>>0),Pl=(r,t,e)=>r>>>e,Fl=(r,t,e)=>r<<32-e|t>>>e,$l=(r,t,e)=>r>>>e|t<<32-e,ql=(r,t,e)=>r<<32-e|t>>>e,jl=(r,t,e)=>r<<64-e|t>>>e-32,zl=(r,t,e)=>r>>>e-32|t<<64-e,Gl=(r,t)=>t,Zl=(r,t)=>r,Wl=(r,t,e)=>r<<e|t>>>32-e,Jl=(r,t,e)=>t<<e|r>>>32-e,Yl=(r,t,e)=>t<<e-32|r>>>64-e,Xl=(r,t,e)=>r<<e-32|t>>>64-e;function Ql(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var tu=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),eu=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ru=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),nu=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,su=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ou=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var iu={fromBig:gi,split:Kl,toBig:Ml,shrSH:Pl,shrSL:Fl,rotrSH:$l,rotrSL:ql,rotrBH:jl,rotrBL:zl,rotr32H:Gl,rotr32L:Zl,rotlSH:Wl,rotlSL:Jl,rotlBH:Yl,rotlBL:Xl,add:Ql,add3L:tu,add3H:eu,add4L:ru,add4H:nu,add5H:ou,add5L:su},V=iu;var[au,cu]=V.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))),ie=new Uint32Array(80),ae=new Uint32Array(80),Cs=class extends oe{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:w,Gl:x,Hh:m,Hl:d}=this;return[t,e,n,s,o,i,a,c,u,l,f,h,w,x,m,d]}set(t,e,n,s,o,i,a,c,u,l,f,h,w,x,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=w|0,this.Gl=x|0,this.Hh=m|0,this.Hl=d|0}process(t,e){for(let g=0;g<16;g++,e+=4)ie[g]=t.getUint32(e),ae[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let E=ie[g-15]|0,R=ae[g-15]|0,U=V.rotrSH(E,R,1)^V.rotrSH(E,R,8)^V.shrSH(E,R,7),S=V.rotrSL(E,R,1)^V.rotrSL(E,R,8)^V.shrSL(E,R,7),I=ie[g-2]|0,T=ae[g-2]|0,Q=V.rotrSH(I,T,19)^V.rotrBH(I,T,61)^V.shrSH(I,T,6),F=V.rotrSL(I,T,19)^V.rotrBL(I,T,61)^V.shrSL(I,T,6),O=V.add4L(S,F,ae[g-7],ae[g-16]),tt=V.add4H(O,U,Q,ie[g-7],ie[g-16]);ie[g]=tt|0,ae[g]=O|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:w,Fl:x,Gh:m,Gl:d,Hh:y,Hl:B}=this;for(let g=0;g<80;g++){let E=V.rotrSH(f,h,14)^V.rotrSH(f,h,18)^V.rotrBH(f,h,41),R=V.rotrSL(f,h,14)^V.rotrSL(f,h,18)^V.rotrBL(f,h,41),U=f&w^~f&m,S=h&x^~h&d,I=V.add5L(B,R,S,cu[g],ae[g]),T=V.add5H(I,y,E,U,au[g],ie[g]),Q=I|0,F=V.rotrSH(n,s,28)^V.rotrBH(n,s,34)^V.rotrBH(n,s,39),O=V.rotrSL(n,s,28)^V.rotrBL(n,s,34)^V.rotrBL(n,s,39),tt=n&o^n&a^o&a,A=s&i^s&c^i&c;y=m|0,B=d|0,m=w|0,d=x|0,w=f|0,x=h|0,{h:f,l:h}=V.add(u|0,l|0,T|0,Q|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=V.add3L(Q,O,A);n=V.add3H(N,T,F,tt),s=N|0}({h:n,l:s}=V.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=V.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=V.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=V.add(this.Eh|0,this.El|0,f|0,h|0),{h:w,l:x}=V.add(this.Fh|0,this.Fl|0,w|0,x|0),{h:m,l:d}=V.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:y,l:B}=V.add(this.Hh|0,this.Hl|0,y|0,B|0),this.set(n,s,o,i,a,c,u,l,f,h,w,x,m,d,y,B)}roundClean(){ie.fill(0),ae.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 ce=We(()=>new Cs);var rn={};ht(rn,{aInRange:()=>xt,abool:()=>Nt,abytes:()=>Ye,bitGet:()=>pu,bitLen:()=>_s,bitMask:()=>vr,bitSet:()=>gu,bytesToHex:()=>$t,bytesToNumberBE:()=>qt,bytesToNumberLE:()=>ue,concatBytes:()=>jt,createHmacDrbg:()=>Hs,ensureBytes:()=>Y,equalBytes:()=>hu,hexToBytes:()=>Se,hexToNumber:()=>Ls,inRange:()=>xr,isBytes:()=>le,memoized:()=>Ne,notImplemented:()=>yu,numberToBytesBE:()=>fe,numberToBytesLE:()=>Ie,numberToHexUnpadded:()=>ke,numberToVarBytesBE:()=>fu,utf8ToBytes:()=>du,validateObject:()=>_t});var Rs=BigInt(0),en=BigInt(1),lu=BigInt(2);function le(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ye(r){if(!le(r))throw new Error("Uint8Array expected")}function Nt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var uu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function $t(r){Ye(r);let t="";for(let e=0;e<r.length;e++)t+=uu[r[e]];return t}function ke(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Ls(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ft={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function mi(r){if(r>=Ft._0&&r<=Ft._9)return r-Ft._0;if(r>=Ft._A&&r<=Ft._F)return r-(Ft._A-10);if(r>=Ft._a&&r<=Ft._f)return r-(Ft._a-10)}function Se(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=mi(r.charCodeAt(o)),a=mi(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 qt(r){return Ls($t(r))}function ue(r){return Ye(r),Ls($t(Uint8Array.from(r).reverse()))}function fe(r,t){return Se(r.toString(16).padStart(t*2,"0"))}function Ie(r,t){return fe(r,t).reverse()}function fu(r){return Se(ke(r))}function Y(r,t,e){let n;if(typeof t=="string")try{n=Se(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(le(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function jt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ye(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 hu(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 du(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Ts=r=>typeof r=="bigint"&&Rs<=r;function xr(r,t,e){return Ts(r)&&Ts(t)&&Ts(e)&&t<=r&&r<e}function xt(r,t,e,n){if(!xr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function _s(r){let t;for(t=0;r>Rs;r>>=en,t+=1);return t}function pu(r,t){return r>>BigInt(t)&en}function gu(r,t,e){return r|(e?en:Rs)<<BigInt(t)}var vr=r=>(lu<<BigInt(r-1))-en,Us=r=>new Uint8Array(r),yi=r=>Uint8Array.from(r);function Hs(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=Us(r),s=Us(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Us())=>{s=a(yi([0]),f),n=a(),f.length!==0&&(s=a(yi([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 w=n.slice();h.push(w),f+=n.length}return jt(...h)};return(f,h)=>{i(),c(f);let w;for(;!(w=h(u()));)c();return i(),w}}var mu={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||le(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function _t(r,t,e={}){let n=(s,o,i)=>{let a=mu[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var yu=()=>{throw new Error("not implemented")};function Ne(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 rt=BigInt(0),G=BigInt(1),Ce=BigInt(2),bu=BigInt(3),Vs=BigInt(4),bi=BigInt(5),wi=BigInt(8),wu=BigInt(9),xu=BigInt(16);function j(r,t){let e=r%t;return e>=rt?e:t+e}function vu(r,t,e){if(e<=rt||t<rt)throw new Error("Expected power/modulo > 0");if(e===G)return rt;let n=G;for(;t>rt;)t&G&&(n=n*r%e),r=r*r%e,t>>=G;return n}function Z(r,t,e){let n=r;for(;t-- >rt;)n*=n,n%=e;return n}function nn(r,t){if(r===rt||t<=rt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=j(r,t),n=t,s=rt,o=G,i=G,a=rt;for(;e!==rt;){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!==G)throw new Error("invert: does not exist");return j(s,t)}function Bu(r){let t=(r-G)/Ce,e,n,s;for(e=r-G,n=0;e%Ce===rt;e/=Ce,n++);for(s=Ce;s<r&&vu(s,t,r)!==r-G;s++);if(n===1){let i=(r+G)/Vs;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))throw new Error("Cannot find square root");return l}}let o=(e+G)/Ce;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 w=1;for(let m=a.sqr(h);w<u&&!a.eql(m,a.ONE);w++)m=a.sqr(m);let x=a.pow(l,G<<BigInt(u-w-1));l=a.sqr(x),f=a.mul(f,x),h=a.mul(h,l),u=w}return f}}function Eu(r){if(r%Vs===bu){let t=(r+G)/Vs;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%wi===bi){let t=(r-bi)/wi;return function(n,s){let o=n.mul(s,Ce),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ce),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%xu,Bu(r)}var xi=(r,t)=>(j(r,t)&G)===G,Au=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Os(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Au.reduce((n,s)=>(n[s]="function",n),t);return _t(r,e)}function ku(r,t,e){if(e<rt)throw new Error("Expected power > 0");if(e===rt)return r.ONE;if(e===G)return t;let n=r.ONE,s=t;for(;e>rt;)e&G&&(n=r.mul(n,s)),s=r.sqr(s),e>>=G;return n}function Su(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 Ds(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function he(r,t,e=!1,n={}){if(r<=rt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Ds(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Eu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:vr(s),ZERO:rt,ONE:G,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return rt<=c&&c<r},is0:c=>c===rt,isOdd:c=>(c&G)===G,neg:c=>j(-c,r),eql:(c,u)=>c===u,sqr:c=>j(c*c,r),add:(c,u)=>j(c+u,r),sub:(c,u)=>j(c-u,r),mul:(c,u)=>j(c*u,r),pow:(c,u)=>ku(a,c,u),div:(c,u)=>j(c*nn(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>nn(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Su(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Ie(c,o):fe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?ue(c):qt(c)}});return Object.freeze(a)}function vi(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 Ks(r){let t=vi(r);return t+Math.ceil(t/2)}function Bi(r,t,e=!1){let n=r.length,s=vi(t),o=Ks(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?qt(r):ue(r),a=j(i,t-G)+G;return e?Ie(a,s):fe(a,s)}var Nu=BigInt(0),Ms=BigInt(1),Ps=new WeakMap,Ei=new WeakMap;function sn(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>Nu;)i&Ms&&(a=a.add(c)),c=c.double(),i>>=Ms;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),u=[],l=o,f=l;for(let h=0;h<a;h++){f=l,u.push(f);for(let w=1;w<c;w++)f=f.add(l),u.push(f);l=f.double()}return u},wNAF(o,i,a){let{windows:c,windowSize:u}=s(o),l=r.ZERO,f=r.BASE,h=BigInt(2**o-1),w=2**o,x=BigInt(o);for(let m=0;m<c;m++){let d=m*u,y=Number(a&h);a>>=x,y>u&&(y-=w,a+=Ms);let B=d,g=d+Math.abs(y)-1,E=m%2!==0,R=y<0;y===0?f=f.add(e(E,i[B])):l=l.add(e(R,i[g]))}return{p:l,f}},wNAFCached(o,i,a){let c=Ei.get(o)||1,u=Ps.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&Ps.set(o,a(u))),this.wNAF(c,u,i)},setWindowSize(o,i){n(i),Ei.set(o,i),Ps.delete(o)}}}function on(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((l,f)=>{if(!t.isValid(l))throw new Error(`wrong scalar at index ${f}`)}),e.forEach((l,f)=>{if(!(l instanceof r))throw new Error(`wrong point at index ${f}`)});let s=_s(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,u=r.ZERO;for(let l=c;l>=0;l-=o){a.fill(r.ZERO);for(let h=0;h<n.length;h++){let w=n[h],x=Number(w>>BigInt(l)&BigInt(i));a[x]=a[x].add(e[h])}let f=r.ZERO;for(let h=a.length-1,w=r.ZERO;h>0;h--)w=w.add(a[h]),f=f.add(w);if(u=u.add(f),l!==0)for(let h=0;h<o;h++)u=u.double()}return u}function Br(r){return Os(r.Fp),_t(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ds(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ct=BigInt(0),vt=BigInt(1),an=BigInt(2),Cu=BigInt(8),Tu={zip215:!0};function Uu(r){let t=Br(r);return _t(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ai(r){let t=Uu(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,u=an<<BigInt(a*8)-vt,l=e.create,f=he(t.n,t.nBitLength),h=t.uvRatio||((b,p)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(p))}}catch{return{isValid:!1,value:Ct}}}),w=t.adjustScalarBytes||(b=>b),x=t.domain||((b,p,v)=>{if(Nt("phflag",v),p.length||v)throw new Error("Contexts/pre-hash are not supported");return b});function m(b,p){xt("coordinate "+b,p,Ct,u)}function d(b){if(!(b instanceof g))throw new Error("ExtendedPoint expected")}let y=Ne((b,p)=>{let{ex:v,ey:C,ez:L}=b,H=b.is0();p==null&&(p=H?Cu:e.inv(L));let D=l(v*p),P=l(C*p),K=l(L*p);if(H)return{x:Ct,y:vt};if(K!==vt)throw new Error("invZ was invalid");return{x:D,y:P}}),B=Ne(b=>{let{a:p,d:v}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:H,et:D}=b,P=l(C*C),K=l(L*L),q=l(H*H),z=l(q*q),st=l(P*p),ot=l(q*l(st+K)),lt=l(z+l(v*l(P*K)));if(ot!==lt)throw new Error("bad point: equation left != right (1)");let gt=l(C*L),et=l(H*D);if(gt!==et)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(p,v,C,L){this.ex=p,this.ey=v,this.ez=C,this.et=L,m("x",p),m("y",v),m("z",C),m("t",L),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof g)throw new Error("extended point not allowed");let{x:v,y:C}=p||{};return m("x",v),m("y",C),new g(v,C,vt,l(v*C))}static normalizeZ(p){let v=e.invertBatch(p.map(C=>C.ez));return p.map((C,L)=>C.toAffine(v[L])).map(g.fromAffine)}static msm(p,v){return on(g,f,p,v)}_setWindowSize(p){U.setWindowSize(this,p)}assertValidity(){B(this)}equals(p){d(p);let{ex:v,ey:C,ez:L}=this,{ex:H,ey:D,ez:P}=p,K=l(v*P),q=l(H*L),z=l(C*P),st=l(D*L);return K===q&&z===st}is0(){return this.equals(g.ZERO)}negate(){return new g(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:p}=t,{ex:v,ey:C,ez:L}=this,H=l(v*v),D=l(C*C),P=l(an*l(L*L)),K=l(p*H),q=v+C,z=l(l(q*q)-H-D),st=K+D,ot=st-P,lt=K-D,gt=l(z*ot),et=l(st*lt),bt=l(z*lt),Kt=l(ot*st);return new g(gt,et,Kt,bt)}add(p){d(p);let{a:v,d:C}=t,{ex:L,ey:H,ez:D,et:P}=this,{ex:K,ey:q,ez:z,et:st}=p;if(v===BigInt(-1)){let Ko=l((H-L)*(q+K)),Mo=l((H+L)*(q-K)),ms=l(Mo-Ko);if(ms===Ct)return this.double();let Po=l(D*an*st),Fo=l(P*an*z),$o=Fo+Po,qo=Mo+Ko,jo=Fo-Po,Mc=l($o*ms),Pc=l(qo*jo),Fc=l($o*jo),$c=l(ms*qo);return new g(Mc,Pc,$c,Fc)}let ot=l(L*K),lt=l(H*q),gt=l(P*C*st),et=l(D*z),bt=l((L+H)*(K+q)-ot-lt),Kt=et-gt,ur=et+gt,fr=l(lt-v*ot),Vc=l(bt*Kt),Oc=l(ur*fr),Dc=l(bt*fr),Kc=l(Kt*ur);return new g(Vc,Oc,Kc,Dc)}subtract(p){return this.add(p.negate())}wNAF(p){return U.wNAFCached(this,p,g.normalizeZ)}multiply(p){let v=p;xt("scalar",v,vt,n);let{p:C,f:L}=this.wNAF(v);return g.normalizeZ([C,L])[0]}multiplyUnsafe(p){let v=p;return xt("scalar",v,Ct,n),v===Ct?R:this.equals(R)||v===vt?this:this.equals(E)?this.wNAF(v).p:U.unsafeLadder(this,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return U.unsafeLadder(this,n).is0()}toAffine(p){return y(this,p)}clearCofactor(){let{h:p}=t;return p===vt?this:this.multiplyUnsafe(p)}static fromHex(p,v=!1){let{d:C,a:L}=t,H=e.BYTES;p=Y("pointHex",p,H),Nt("zip215",v);let D=p.slice(),P=p[H-1];D[H-1]=P&-129;let K=ue(D),q=v?u:e.ORDER;xt("pointHex.y",K,Ct,q);let z=l(K*K),st=l(z-vt),ot=l(C*z-L),{isValid:lt,value:gt}=h(st,ot);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let et=(gt&vt)===vt,bt=(P&128)!==0;if(!v&>===Ct&&bt)throw new Error("Point.fromHex: x=0 and x_0=1");return bt!==et&&(gt=l(-gt)),g.fromAffine({x:gt,y:K})}static fromPrivateKey(p){return T(p).point}toRawBytes(){let{x:p,y:v}=this.toAffine(),C=Ie(v,e.BYTES);return C[C.length-1]|=p&vt?128:0,C}toHex(){return $t(this.toRawBytes())}}g.BASE=new g(t.Gx,t.Gy,vt,l(t.Gx*t.Gy)),g.ZERO=new g(Ct,vt,vt,Ct);let{BASE:E,ZERO:R}=g,U=sn(g,a*8);function S(b){return j(b,n)}function I(b){return S(ue(b))}function T(b){let p=a;b=Y("private key",b,p);let v=Y("hashed private key",o(b),2*p),C=w(v.slice(0,p)),L=v.slice(p,2*p),H=I(C),D=E.multiply(H),P=D.toRawBytes();return{head:C,prefix:L,scalar:H,point:D,pointBytes:P}}function Q(b){return T(b).pointBytes}function F(b=new Uint8Array,...p){let v=jt(...p);return I(o(x(v,Y("context",b),!!s)))}function O(b,p,v={}){b=Y("message",b),s&&(b=s(b));let{prefix:C,scalar:L,pointBytes:H}=T(p),D=F(v.context,C,b),P=E.multiply(D).toRawBytes(),K=F(v.context,P,H,b),q=S(D+K*L);xt("signature.s",q,Ct,n);let z=jt(P,Ie(q,e.BYTES));return Y("result",z,a*2)}let tt=Tu;function A(b,p,v,C=tt){let{context:L,zip215:H}=C,D=e.BYTES;b=Y("signature",b,2*D),p=Y("message",p),H!==void 0&&Nt("zip215",H),s&&(p=s(p));let P=ue(b.slice(D,2*D)),K,q,z;try{K=g.fromHex(v,H),q=g.fromHex(b.slice(0,D),H),z=E.multiplyUnsafe(P)}catch{return!1}if(!H&&K.isSmallOrder())return!1;let st=F(L,q.toRawBytes(),K.toRawBytes(),p);return q.add(K.multiplyUnsafe(st)).subtract(z).clearCofactor().equals(g.ZERO)}return E._setWindowSize(8),{CURVE:t,getPublicKey:Q,sign:O,verify:A,ExtendedPoint:g,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,p=g.BASE){return p._setWindowSize(b),p.multiply(BigInt(3)),p}}}}var Fs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ki=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Pd=BigInt(0),Ru=BigInt(1),Si=BigInt(2),Fd=BigInt(3),Lu=BigInt(5),_u=BigInt(8);function Hu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Fs,a=r*r%o*r%o,c=Z(a,Si,o)*a%o,u=Z(c,Ru,o)*r%o,l=Z(u,Lu,o)*u%o,f=Z(l,t,o)*l%o,h=Z(f,e,o)*f%o,w=Z(h,n,o)*h%o,x=Z(w,s,o)*w%o,m=Z(x,s,o)*w%o,d=Z(m,t,o)*l%o;return{pow_p_5_8:Z(d,Si,o)*r%o,b2:a}}function Vu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Ou(r,t){let e=Fs,n=j(t*t*t,e),s=j(n*n*t,e),o=Hu(r*s).pow_p_5_8,i=j(r*n*o,e),a=j(t*i*i,e),c=i,u=j(i*ki,e),l=a===r,f=a===j(-r,e),h=a===j(-r*ki,e);return l&&(i=c),(f||h)&&(i=u),xi(i,e)&&(i=j(-i,e)),{isValid:l||f,value:i}}var Du=he(Fs,void 0,!0),Ku={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Du,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:_u,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ce,randomBytes:Je,adjustScalarBytes:Vu,uvRatio:Ou},$s=Ai(Ku);var Er=32,zt=64,Mu=32;function Ii(r,t){let e=r.subarray(0,Mu);return $s.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Ni(r,t,e){return $s.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var cn=class{type="Ed25519";raw;constructor(t){this.raw=kr(t,Er)}toMultihash(){return wr.digest(ln(this))}toCID(){return Lt.createV1(114,this.toMultihash())}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Pt(this.raw,t.raw)}verify(t,e){return Ni(this.raw,e,t)}},Ar=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=kr(t,zt),this.publicKey=new cn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Pt(this.raw,t.raw)}sign(t){return Ii(this.raw,t)}};function qs(r){if(r.length>zt){r=kr(r,zt+Er);let n=r.subarray(0,zt),s=r.subarray(zt,r.length);return new Ar(n,s)}r=kr(r,zt);let t=r.subarray(0,zt),e=r.subarray(Er);return new Ar(t,e)}function kr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new _(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Ht(r=0){return new Uint8Array(r)}var Pu=Math.pow(2,7),Fu=Math.pow(2,14),$u=Math.pow(2,21),Ti=Math.pow(2,28),Ui=Math.pow(2,35),Ri=Math.pow(2,42),Li=Math.pow(2,49),mt=128,de=127;function Sr(r){if(r<Pu)return 1;if(r<Fu)return 2;if(r<$u)return 3;if(r<Ti)return 4;if(r<Ui)return 5;if(r<Ri)return 6;if(r<Li)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function _i(r,t,e=0){switch(Sr(r)){case 8:t[e++]=r&255|mt,r/=128;case 7:t[e++]=r&255|mt,r/=128;case 6:t[e++]=r&255|mt,r/=128;case 5:t[e++]=r&255|mt,r/=128;case 4:t[e++]=r&255|mt,r>>>=7;case 3:t[e++]=r&255|mt,r>>>=7;case 2:t[e++]=r&255|mt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Hi(r,t){let e=r[t],n=0;if(n+=e&de,e<mt||(e=r[t+1],n+=(e&de)<<7,e<mt)||(e=r[t+2],n+=(e&de)<<14,e<mt)||(e=r[t+3],n+=(e&de)<<21,e<mt)||(e=r[t+4],n+=(e&de)*Ti,e<mt)||(e=r[t+5],n+=(e&de)*Ui,e<mt)||(e=r[t+6],n+=(e&de)*Ri,e<mt)||(e=r[t+7],n+=(e&de)*Li,e<mt))return n;throw new RangeError("Could not decode varint")}var js=new Float32Array([-0]),pe=new Uint8Array(js.buffer);function Vi(r,t,e){js[0]=r,t[e]=pe[0],t[e+1]=pe[1],t[e+2]=pe[2],t[e+3]=pe[3]}function Oi(r,t){return pe[0]=r[t],pe[1]=r[t+1],pe[2]=r[t+2],pe[3]=r[t+3],js[0]}var zs=new Float64Array([-0]),dt=new Uint8Array(zs.buffer);function Di(r,t,e){zs[0]=r,t[e]=dt[0],t[e+1]=dt[1],t[e+2]=dt[2],t[e+3]=dt[3],t[e+4]=dt[4],t[e+5]=dt[5],t[e+6]=dt[6],t[e+7]=dt[7]}function Ki(r,t){return dt[0]=r[t],dt[1]=r[t+1],dt[2]=r[t+2],dt[3]=r[t+3],dt[4]=r[t+4],dt[5]=r[t+5],dt[6]=r[t+6],dt[7]=r[t+7],zs[0]}var qu=BigInt(Number.MAX_SAFE_INTEGER),ju=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 Te;if(t<qu&&t>ju)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>Mi&&(s=0n,++n>Mi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Te;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Te}},Te=new Et(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var Mi=4294967296n;function Pi(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 Fi(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 Gs(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 un(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Zs=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 un(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return un(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Oi(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=Ki(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 Fi(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=un(this.buf,this.pos+=4),e=un(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=Hi(this.buf,this.pos);return this.pos+=Sr(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 Ws(r){return new Zs(r instanceof Uint8Array?r:r.subarray())}function fn(r,t,e){let n=Ws(r);return t.decode(n,void 0,e)}var Js={};ht(Js,{base10:()=>zu});var zu=ne({prefix:"9",name:"base10",alphabet:"0123456789"});var Ys={};ht(Ys,{base16:()=>Gu,base16upper:()=>Zu});var Gu=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Zu=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Xs={};ht(Xs,{base2:()=>Wu});var Wu=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Qs={};ht(Qs,{base256emoji:()=>tf});var qi=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}"),Ju=qi.reduce((r,t,e)=>(r[e]=t,r),[]),Yu=qi.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Xu(r){return r.reduce((t,e)=>(t+=Ju[e],t),"")}function Qu(r){let t=[];for(let e of r){let n=Yu[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var tf=Me({prefix:"\u{1F680}",name:"base256emoji",encode:Xu,decode:Qu});var to={};ht(to,{base36:()=>ef,base36upper:()=>rf});var ef=ne({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),rf=ne({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var eo={};ht(eo,{base64:()=>Ue,base64pad:()=>nf,base64url:()=>sf,base64urlpad:()=>of});var Ue=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),nf=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),sf=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),of=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ro={};ht(ro,{base8:()=>af});var af=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var no={};ht(no,{identity:()=>cf});var cf=Me({prefix:"\0",name:"identity",encode:r=>Yo(r),decode:r=>Jo(r)});var A0=new TextEncoder,k0=new TextDecoder;var io={};ht(io,{sha256:()=>Xe,sha512:()=>ff});function oo({name:r,code:t,encode:e}){return new so(r,t,e)}var so=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 zi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Xe=oo({name:"sha2-256",code:18,encode:zi("SHA-256")}),ff=oo({name:"sha2-512",code:19,encode:zi("SHA-512")});var ao={...no,...Xs,...ro,...Js,...Ys,...Es,...to,...Bs,...eo,...Qs},O0={...io,...Ss};function Zi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Gi=Zi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),co=Zi("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=Ht(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),hf={utf8:Gi,"utf-8":Gi,hex:ao.base16,latin1:co,ascii:co,binary:co,...ao},hn=hf;function $(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function lo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Ht(i);s+i>t&&(n=Ht(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Re=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function uo(){}var ho=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},df=lo();function pf(r){return globalThis.Buffer!=null?Ht(r):df(r)}var Nr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Re(uo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Re(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new po((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(dn,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(dn,e.length(),e)}uint64Number(t){return this._push(_i,Sr(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(dn,e.length(),e)}sint64Number(t){let e=Et.fromNumber(t).zzEncode();return this._push(dn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(fo,1,t?1:0)}fixed32(t){return this._push(Ir,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Et.fromBigInt(t);return this._push(Ir,4,e.lo)._push(Ir,4,e.hi)}fixed64Number(t){let e=Et.fromNumber(t);return this._push(Ir,4,e.lo)._push(Ir,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(Vi,4,t)}double(t){return this._push(Di,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(fo,1,0):this.uint32(e)._push(mf,e,t)}string(t){let e=Pi(t);return e!==0?this.uint32(e)._push(Gs,e,t):this._push(fo,1,0)}fork(){return this.states=new ho(this),this.head=this.tail=new Re(uo,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 Re(uo,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=pf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function fo(r,t,e){t[e]=r&255}function gf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var po=class extends Re{next;constructor(t,e){super(gf,t,e),this.next=void 0}};function dn(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 Ir(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 mf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Nr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(yf,t,r),this},Nr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(bf,t,r),this});function yf(r,t,e){t.set(r,e)}function bf(r,t,e){r.length<40?Gs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set($(r),e)}function go(){return new Nr}function pn(r,t){let e=go();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Qe;(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"})(Qe||(Qe={}));function gn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function mo(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 gn("enum",Qe.VARINT,e,n)}function mn(r,t){return gn("message",Qe.LENGTH_DELIMITED,r,t)}var at;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(at||(at={}));var yo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(yo||(yo={}));(function(r){r.codec=()=>mo(yo)})(at||(at={}));var ge;(function(r){let t;r.codec=()=>(t==null&&(t=mn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),at.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=at.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>pn(e,r.codec()),r.decode=(e,n)=>fn(e,r.codec(),n)})(ge||(ge={}));var Cr;(function(r){let t;r.codec=()=>(t==null&&(t=mn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),at.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=at.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>pn(e,r.codec()),r.decode=(e,n)=>fn(e,r.codec(),n)})(Cr||(Cr={}));var Dr={};ht(Dr,{MAX_RSA_KEY_SIZE:()=>os,generateRSAKeyPair:()=>qa,jwkToJWKKeyPair:()=>ja,jwkToPkcs1:()=>Lf,jwkToPkix:()=>So,jwkToRSAPrivateKey:()=>$a,pkcs1ToJwk:()=>Ma,pkcs1ToRSAPrivateKey:()=>is,pkixToJwk:()=>Pa,pkixToRSAPublicKey:()=>Fa});var wf=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]),me=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),ye=new Uint32Array(64),bo=class extends oe{constructor(){super(64,32,8,!1),this.A=me[0]|0,this.B=me[1]|0,this.C=me[2]|0,this.D=me[3]|0,this.E=me[4]|0,this.F=me[5]|0,this.G=me[6]|0,this.H=me[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)ye[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=ye[f-15],w=ye[f-2],x=It(h,7)^It(h,18)^h>>>3,m=It(w,17)^It(w,19)^w>>>10;ye[f]=m+ye[f-7]+x+ye[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),w=l+h+Xr(a,c,u)+wf[f]+ye[f]|0,m=(It(n,2)^It(n,13)^It(n,22))+Qr(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+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(){ye.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var be=We(()=>new bo);var M=ys(Ji());function Le(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 we(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 wn(...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 xo(){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=Le(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,Le(o,8)-n}function Yi(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=we(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=we(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 Xi(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 Bt(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 bp=Math.log(2);function xn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function vo(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 Xt(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 Ur=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return vo(this.items)}},Tr=[new Uint8Array([1])],Qi="0123456789";var rr="",Ut=new ArrayBuffer(0),Bo=new Uint8Array(0),Rr="EndOfContent",ea="OCTET STRING",ra="BIT STRING";function Qt(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):Bo}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(!Xt(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 Zt=class{constructor({blockLength:t=0,error:e=rr,warnings:n=[],valueBeforeDecode:s=Bo}={}){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)}}};Zt.NAME="baseBlock";var pt=class extends Zt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};pt.NAME="valueBlock";var vn=class extends Qt(Zt){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):Bo,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=we(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(!Xt(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 w=0;w<u.length;w++)h[w]=u[w];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=o[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Le(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}}};vn.NAME="identificationBlock";var Bn=class extends Zt{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(!Xt(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=Le(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=we(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}}};Bn.NAME="lengthBlock";var k={},ut=class extends Zt{constructor({name:t=rr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new vn(s),this.lenBlock=new Bn(s),this.valueBlock=o?new o(s):new pt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new Ur;e||na(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 Xi(e,n)}};ut.NAME="BaseBlock";function na(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)na(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var En=class extends ut{constructor({value:t=rr,...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}'`}};En.NAME="BaseStringBlock";var An=class extends Qt(pt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};An.NAME="PrimitiveValueBlock";var sa,kn=class extends ut{constructor(t={}){super(t,An),this.idBlock.isConstructed=!1}};sa=kn;k.Primitive=sa;kn.NAME="PRIMITIVE";function Nf(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 ss(r,t=0,e=r.length){let n=t,s=new ut({},pt),o=new Zt;if(!Xt(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=ut;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let u=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;u.idBlock=s.idBlock,u.lenBlock=s.lenBlock,u.warnings=s.warnings,s=u}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Nf(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 _e(r){if(!r.byteLength){let t=new ut({},pt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ss(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Cf(r,t){return r?1:t}var Vt=class extends pt{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(!Xt(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(;Cf(this.isIndefiniteForm,n)>0;){let i=ss(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===Rr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Rr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Ur;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}};Vt.NAME="ConstructedValueBlock";var oa,xe=class extends ut{constructor(t={}){super(t,Vt),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} :`}};ma=Be;k.Constructed=ma;Be.NAME="CONSTRUCTED";var Un=class extends gt{fromBER(t,e,n){return e}toBER(t){return Ut}};Un.override="EndOfContentValueBlock";var ba,Dn=class extends dt{constructor(t={}){super(t,Un),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ba=Dn;k.EndOfContent=ba;Dn.NAME=Or;var wa,Ae=class extends dt{constructor(t={}){super(t,gt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};wa=Ae;k.Null=wa;Ae.NAME="NULL";var Vn=class extends oe(gt){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 se(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}}};Vn.NAME="BooleanValueBlock";var xa,On=class extends dt{constructor(t={}){super(t,Vn),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}`}};xa=On;k.Boolean=xa;On.NAME="BOOLEAN";var Hn=class extends oe(Mt){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=Mt.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===Or){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==da)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?Mt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Hn.NAME="OctetStringValueBlock";var Ea,re=class r extends dt{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=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=hs(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?Be.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)}};Ea=re;k.OctetString=Ea;re.NAME=da;var Kn=class extends oe(Mt){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=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Or){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==pa)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(!se(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=hs(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 Mt.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}}};Kn.NAME="BitStringValueBlock";var va,hr=class extends dt{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},Kn),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 Be.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)}`}}};va=hr;k.BitString=va;hr.NAME=pa;var Ba;function Kf(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=In(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=In(e,o)),o}function ha(r){if(r>=Dr.length)for(let t=Dr.length;t<=r;t++){let e=new Uint8Array([0]),n=Dr[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=In(e,n)),Dr.push(n)}return Dr[r]}function Pf(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 oe(gt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Ao.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(la(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=Pf(ha(n),e),i="-";break;default:e=Kf(e,ha(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=fa.charAt(e[c]));return a===!1&&(i+=fa.charAt(0)),i}};Ba=Hr;Hr.NAME="IntegerValueBlock";Object.defineProperty(Ba.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Aa,et=class r extends dt{constructor(t={}){super(t,Hr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Rn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Rn();let e=BigInt(t),n=new Vr,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()}`}};Aa=et;k.Integer=Aa;et.NAME="INTEGER";var Sa,Pn=class extends et{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Sa=Pn;k.Enumerated=Sa;Pn.NAME="ENUMERATED";var Kr=class extends oe(gt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(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=$e(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Rn();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=ve(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}}};Kr.NAME="sidBlock";var Mn=class extends gt{constructor({value:t=dr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Kr;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 So(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 Kr;if(s>Number.MAX_SAFE_INTEGER){Rn();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}};Mn.NAME="ObjectIdentifierValueBlock";var ka,Lt=class extends dt{constructor(t={}){super(t,Mn),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()}}};ka=Lt;k.ObjectIdentifier=ka;Lt.NAME="OBJECT IDENTIFIER";var Pr=class extends oe(ee){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(!se(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=$e(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=ve(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}}};Pr.NAME="relativeSidBlock";var Fn=class extends gt{constructor({value:t=dr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Pr;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 So(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 Pr;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}};Fn.NAME="RelativeObjectIdentifierValueBlock";var Ia,$n=class extends dt{constructor(t={}){super(t,Fn),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()}}};Ia=$n;k.RelativeObjectIdentifier=Ia;$n.NAME="RelativeObjectIdentifier";var Ra,lt=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ra=lt;k.Sequence=Ra;lt.NAME="SEQUENCE";var _a,qn=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};_a=qn;k.Set=_a;qn.NAME="SET";var jn=class extends oe(gt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=dr}toJSON(){return{...super.toJSON(),value:this.value}}};jn.NAME="StringValueBlock";var Yn=class extends jn{};Yn.NAME="SimpleStringValueBlock";var xt=class extends Tn{constructor({...t}={}){super(t,Yn)}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}};xt.NAME="SIMPLE STRING";var Gn=class extends xt{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}};Gn.NAME="Utf8StringValueBlock";var Na,ne=class extends Gn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Na=ne;k.Utf8String=Na;ne.NAME="UTF8String";var zn=class extends xt{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))}};zn.NAME="BmpStringValueBlock";var Ta,Wn=class extends zn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Ta=Wn;k.BmpString=Ta;Wn.NAME="BMPString";var Zn=class extends xt{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=ve(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}};Zn.NAME="UniversalStringValueBlock";var Ca,Jn=class extends Zn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ca=Jn;k.UniversalString=Ca;Jn.NAME="UniversalString";var La,Xn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};La=Xn;k.NumericString=La;Xn.NAME="NumericString";var Ua,Qn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ua=Qn;k.PrintableString=Ua;Qn.NAME="PrintableString";var Da,ts=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Da=ts;k.TeletexString=Da;ts.NAME="TeletexString";var Va,es=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Va=es;k.VideotexString=Va;es.NAME="VideotexString";var Oa,rs=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Oa=rs;k.IA5String=Oa;rs.NAME="IA5String";var Ha,ns=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ha=ns;k.GraphicString=Ha;ns.NAME="GraphicString";var Ka,Mr=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ka=Mr;k.VisibleString=Ka;Mr.NAME="VisibleString";var Pa,ss=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Pa=ss;k.GeneralString=Pa;ss.NAME="GeneralString";var Ma,os=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ma=os;k.CharacterString=Ma;os.NAME="CharacterString";var Fa,Fr=class extends Mr{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]=At(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=At(this.month,2),e[2]=At(this.day,2),e[3]=At(this.hour,2),e[4]=At(this.minute,2),e[5]=At(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}}};Fa=Fr;k.UTCTime=Fa;Fr.NAME="UTCTime";var $a,is=class extends Fr{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("+"),w="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(w=n.substring(h+1),n=n.substring(0,h),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let x=parseInt(w.substring(0,2),10);if(isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*x,w.length===4){if(x=parseInt(w.substring(2,4),10),isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");c=f*x}}}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(At(this.year,4)),e.push(At(this.month,2)),e.push(At(this.day,2)),e.push(At(this.hour,2)),e.push(At(this.minute,2)),e.push(At(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(At(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};$a=is;k.GeneralizedTime=$a;is.NAME="GeneralizedTime";var qa,as=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};qa=as;k.DATE=qa;as.NAME="DATE";var ja,cs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};ja=cs;k.TimeOfDay=ja;cs.NAME="TimeOfDay";var Ya,ls=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ya=ls;k.DateTime=Ya;ls.NAME="DateTime";var Ga,us=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ga=us;k.Duration=Ga;us.NAME="Duration";var za,fs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};za=fs;k.TIME=za;fs.NAME="TIME";function Ff(r){let{result:t}=pr(r),e=t.valueBlock.value;return{n:j(Ft(e[1].toBigInt()),"base64url"),e:j(Ft(e[2].toBigInt()),"base64url"),d:j(Ft(e[3].toBigInt()),"base64url"),p:j(Ft(e[4].toBigInt()),"base64url"),q:j(Ft(e[5].toBigInt()),"base64url"),dp:j(Ft(e[6].toBigInt()),"base64url"),dq:j(Ft(e[7].toBigInt()),"base64url"),qi:j(Ft(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function $f(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 B("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new lt({value:[new et({value:0}),et.fromBigInt($t(P(r.n,"base64url"))),et.fromBigInt($t(P(r.e,"base64url"))),et.fromBigInt($t(P(r.d,"base64url"))),et.fromBigInt($t(P(r.p,"base64url"))),et.fromBigInt($t(P(r.q,"base64url"))),et.fromBigInt($t(P(r.dp,"base64url"))),et.fromBigInt($t(P(r.dq,"base64url"))),et.fromBigInt($t(P(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function qf(r){let{result:t}=pr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:j(Ft(e[0].toBigInt()),"base64url"),e:j(Ft(e[1].toBigInt()),"base64url")}}function jf(r){if(r.n==null||r.e==null)throw new B("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new lt({value:[new lt({value:[new Lt({value:"1.2.840.113549.1.1.1"}),new Ae]}),new hr({valueHex:new lt({value:[et.fromBigInt($t(P(r.n,"base64url"))),et.fromBigInt($t(P(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ft(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function $t(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Yf=16,Io=32,Ro=1e4;async function Gf(r,t){let e=mt.get(),s=new lt({value:[new et({value:0}),new lt({value:[new Lt({value:"1.2.840.113549.1.1.1"}),new Ae]}),new re({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Pt(Yf),a=await vo(Ue,t,i,{c:Ro,dkLen:Io}),c=Pt(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 lt({value:[new re({valueHex:i}),new et({value:Ro}),new et({value:Io}),new lt({value:[new Lt({value:"1.2.840.113549.2.11"}),new Ae]})]}),h=new lt({value:[new Lt({value:"1.2.840.113549.1.5.13"}),new lt({value:[new lt({value:[new Lt({value:"1.2.840.113549.1.5.12"}),f]}),new lt({value:[new Lt({value:"2.16.840.1.101.3.4.1.42"}),new re({valueHex:c})]})]})]}),x=new lt({value:[h,new re({valueHex:l})]}).toBER(),y=new Uint8Array(x,0,x.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function _o(r,t){let e=mt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=P(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=pr(s),{iv:i,salt:a,iterations:c,keySize:u,cipherText:l}=zf(o),f=await vo(Ue,t,a,{c,dkLen:u}),h=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),w=$r(await e.subtle.decrypt({name:"AES-CBC",iv:i},h,l)),{result:x}=pr(w);n=Wa(x)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=P(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=pr(s);n=Wa(o)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return No(n)}function zf(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new B("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new B("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=$r(o.valueBlock.value[0].getValue()),a=Ro,c=Io;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 B("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=t.valueBlock.value[1].valueBlock.value[1],l=u.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new B("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}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 Wa(r){return $r(r.valueBlock.value[2].getValue())}function $r(r){return new Uint8Array(r,0,r.byteLength)}async function Za(r){let t=await mt.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 Qa(t);return{privateKey:e[0],publicKey:e[1]}}async function To(r){let e=[await mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Wf(r)],n=await Qa({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ja(r,t){let e=await mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await mt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Xa(r,t,e){let n=await mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return mt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Qa(r){if(r.privateKey==null||r.publicKey==null)throw new B("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([mt.get().subtle.exportKey("jwk",r.privateKey),mt.get().subtle.exportKey("jwk",r.publicKey)])}async function Wf(r){return mt.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function ds(r){if(r.kty!=="RSA")throw new B("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new B("invalid key modulus","ERR_INVALID_KEY_MODULUS");return P(r.n,"base64url").length*8}var jr=8192,qr=class{_key;constructor(t){this._key=t}verify(t,e){return Xa(this._key,e,t)}marshal(){return Se.jwkToPkix(this._key)}get bytes(){return Qt.encode({Type:tt.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return It(t)?t.then(({bytes:e})=>e):t.bytes}},gr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Pt(16)}sign(t){return Ja(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new qr(this._publicKey)}marshal(){return Se.jwkToPkcs1(this._key)}get bytes(){return Kt.encode({Type:tt.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return It(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return j(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Se.exportToPem(this,t);if(e==="libp2p-key")return cr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function No(r){let t=Se.pkcs1ToJwk(r);if(ds(t)>jr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await To(t);return new gr(e.privateKey,e.publicKey)}function Jf(r){let t=Se.pkixToJwk(r);if(ds(t)>jr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new qr(t)}async function Xf(r){if(ds(r)>jr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await To(r);return new gr(t.privateKey,t.publicKey)}async function Qf(r){if(r>jr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Za(r);return new gr(t.privateKey,t.publicKey)}var Oo={};ct(Oo,{Secp256k1PrivateKey:()=>Gr,Secp256k1PublicKey:()=>Yr,generateKeyPair:()=>hh,unmarshalSecp256k1PrivateKey:()=>uh,unmarshalSecp256k1PublicKey:()=>fh});var th=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]),ke=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ie=new Uint32Array(64),Lo=class extends de{constructor(){super(64,32,8,!1),this.A=ke[0]|0,this.B=ke[1]|0,this.C=ke[2]|0,this.D=ke[3]|0,this.E=ke[4]|0,this.F=ke[5]|0,this.G=ke[6]|0,this.H=ke[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)Ie[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=Ie[f-15],w=Ie[f-2],x=_t(h,7)^_t(h,18)^h>>>3,y=_t(w,17)^_t(w,19)^w>>>10;Ie[f]=y+Ie[f-7]+x+Ie[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=_t(a,6)^_t(a,11)^_t(a,25),w=l+h+on(a,c,u)+th[f]+Ie[f]|0,y=(_t(n,2)^_t(n,13)^_t(n,22))+an(n,s,o)|0;l=u,u=c,c=a,a=i+w|0,i=o,o=s,s=n,n=w+y|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(){Ie.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var ps=nr(()=>new Lo);function tc(r){r.lowS!==void 0&&Nt("lowS",r.lowS),r.prehash!==void 0&&Nt("prehash",r.prehash)}function eh(r){let t=_r(r);Ht(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:rh,hexToBytes:nh}=un,ie={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=ie;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=De(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?De(s.length/2|128):"";return`${De(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=ie,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}=ie;if(r<ae)throw new t("integer: negative integers are not allowed");let e=De(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=ie;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 rh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ie,s=typeof r=="string"?nh(r):r;or(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}=ie,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},ae=BigInt(0),ut=BigInt(1),Sg=BigInt(2),ec=BigInt(3),kg=BigInt(4);function sh(r){let t=eh(r),{Fp:e}=t,n=we(t.n,t.nBitLength),s=t.toBytes||((y,d,m)=>{let v=d.toAffine();return Jt(Uint8Array.from([4]),e.toBytes(v.x),e.toBytes(v.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),m=e.fromBytes(d.subarray(0,e.BYTES)),v=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:m,y:v}});function i(y){let{a:d,b:m}=t,v=e.sqr(y),g=e.mul(v,y);return e.add(e.add(g,e.mul(y,d)),m)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return Ir(y,ut,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:m,wrapPrivateKey:v,n:g}=t;if(d&&typeof y!="bigint"){if(ye(y)&&(y=Wt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let A;try{A=typeof y=="bigint"?y:Zt(Q("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return v&&(A=G(A,g)),vt("private key",A,ut,g),A}function u(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=He((y,d)=>{let{px:m,py:v,pz:g}=y;if(e.eql(g,e.ONE))return{x:m,y:v};let A=y.is0();d==null&&(d=A?e.ONE:e.inv(g));let L=e.mul(m,d),C=e.mul(v,d),I=e.mul(g,d);if(A)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:L,y:C}}),f=He(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=y.toAffine();if(!e.isValid(d)||!e.isValid(m))throw new Error("bad point: x or y not FE");let v=e.sqr(m),g=i(d);if(!e.eql(v,g))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,m,v){if(this.px=d,this.py=m,this.pz=v,d==null||!e.isValid(d))throw new Error("x required");if(m==null||!e.isValid(m))throw new Error("y required");if(v==null||!e.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:m,y:v}=d||{};if(!d||!e.isValid(m)||!e.isValid(v))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let g=A=>e.eql(A,e.ZERO);return g(m)&&g(v)?h.ZERO:new h(m,v,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=e.invertBatch(d.map(v=>v.pz));return d.map((v,g)=>v.toAffine(m[g])).map(h.fromAffine)}static fromHex(d){let m=h.fromAffine(o(Q("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,m){return dn(h,n,d,m)}_setWindowSize(d){x.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:m,py:v,pz:g}=this,{px:A,py:L,pz:C}=d,I=e.eql(e.mul(m,C),e.mul(A,g)),R=e.eql(e.mul(v,C),e.mul(L,g));return I&&R}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:m}=t,v=e.mul(m,ec),{px:g,py:A,pz:L}=this,C=e.ZERO,I=e.ZERO,R=e.ZERO,T=e.mul(g,g),rt=e.mul(A,A),q=e.mul(L,L),O=e.mul(g,A);return O=e.add(O,O),R=e.mul(g,L),R=e.add(R,R),C=e.mul(d,R),I=e.mul(v,q),I=e.add(C,I),C=e.sub(rt,I),I=e.add(rt,I),I=e.mul(C,I),C=e.mul(O,C),R=e.mul(v,R),q=e.mul(d,q),O=e.sub(T,q),O=e.mul(d,O),O=e.add(O,R),R=e.add(T,T),T=e.add(R,T),T=e.add(T,q),T=e.mul(T,O),I=e.add(I,T),q=e.mul(A,L),q=e.add(q,q),T=e.mul(q,O),C=e.sub(C,T),R=e.mul(q,rt),R=e.add(R,R),R=e.add(R,R),new h(C,I,R)}add(d){u(d);let{px:m,py:v,pz:g}=this,{px:A,py:L,pz:C}=d,I=e.ZERO,R=e.ZERO,T=e.ZERO,rt=t.a,q=e.mul(t.b,ec),O=e.mul(m,A),nt=e.mul(v,L),S=e.mul(g,C),_=e.add(m,v),b=e.add(A,L);_=e.mul(_,b),b=e.add(O,nt),_=e.sub(_,b),b=e.add(m,g);let p=e.add(A,C);return b=e.mul(b,p),p=e.add(O,S),b=e.sub(b,p),p=e.add(v,g),I=e.add(L,C),p=e.mul(p,I),I=e.add(nt,S),p=e.sub(p,I),T=e.mul(rt,b),I=e.mul(q,S),T=e.add(I,T),I=e.sub(nt,T),T=e.add(nt,T),R=e.mul(I,T),nt=e.add(O,O),nt=e.add(nt,O),S=e.mul(rt,S),b=e.mul(q,b),nt=e.add(nt,S),S=e.sub(O,S),S=e.mul(rt,S),b=e.add(b,S),O=e.mul(nt,b),R=e.add(R,O),O=e.mul(p,b),I=e.mul(_,I),I=e.sub(I,O),O=e.mul(_,nt),T=e.mul(p,T),T=e.add(T,O),new h(I,R,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return x.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){vt("scalar",d,ae,t.n);let m=h.ZERO;if(d===ae)return m;if(d===ut)return this;let{endo:v}=t;if(!v)return x.unsafeLadder(this,d);let{k1neg:g,k1:A,k2neg:L,k2:C}=v.splitScalar(d),I=m,R=m,T=this;for(;A>ae||C>ae;)A&ut&&(I=I.add(T)),C&ut&&(R=R.add(T)),T=T.double(),A>>=ut,C>>=ut;return g&&(I=I.negate()),L&&(R=R.negate()),R=new h(e.mul(R.px,v.beta),R.py,R.pz),I.add(R)}multiply(d){let{endo:m,n:v}=t;vt("scalar",d,ut,v);let g,A;if(m){let{k1neg:L,k1:C,k2neg:I,k2:R}=m.splitScalar(d),{p:T,f:rt}=this.wNAF(C),{p:q,f:O}=this.wNAF(R);T=x.constTimeNegate(L,T),q=x.constTimeNegate(I,q),q=new h(e.mul(q.px,m.beta),q.py,q.pz),g=T.add(q),A=rt.add(O)}else{let{p:L,f:C}=this.wNAF(d);g=L,A=C}return h.normalizeZ([g,A])[0]}multiplyAndAddUnsafe(d,m,v){let g=h.BASE,A=(C,I)=>I===ae||I===ut||!C.equals(g)?C.multiplyUnsafe(I):C.multiply(I),L=A(this,m).add(A(d,v));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:m}=t;if(d===ut)return!0;if(m)return m(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:m}=t;return d===ut?this:m?m(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),Wt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let w=t.nBitLength,x=hn(h,t.endo?Math.ceil(w/2):w);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function oh(r){let t=_r(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function rc(r){let t=oh(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(S){return G(S,n)}function a(S){return fn(S,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=sh({...t,toBytes(S,_,b){let p=_.toAffine(),E=e.toBytes(p.x),N=Jt;return Nt("isCompressed",b),b?N(Uint8Array.from([_.hasEvenY()?2:3]),E):N(Uint8Array.from([4]),E,e.toBytes(p.y))},fromBytes(S){let _=S.length,b=S[0],p=S.subarray(1);if(_===s&&(b===2||b===3)){let E=Zt(p);if(!Ir(E,ut,e.ORDER))throw new Error("Point is not on curve");let N=l(E),U;try{U=e.sqrt(N)}catch(F){let K=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+K)}let D=(U&ut)===ut;return(b&1)===1!==D&&(U=e.neg(U)),{x:E,y:U}}else if(_===o&&b===4){let E=e.fromBytes(p.subarray(0,e.BYTES)),N=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:E,y:N}}else throw new Error(`Point of length ${_} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=S=>Wt(be(S,t.nByteLength));function w(S){let _=n>>ut;return S>_}function x(S){return w(S)?i(-S):S}let y=(S,_,b)=>Zt(S.slice(_,b));class d{constructor(_,b,p){this.r=_,this.s=b,this.recovery=p,this.assertValidity()}static fromCompact(_){let b=t.nByteLength;return _=Q("compactSignature",_,b*2),new d(y(_,0,b),y(_,b,2*b))}static fromDER(_){let{r:b,s:p}=ie.toSig(Q("DER",_));return new d(b,p)}assertValidity(){vt("r",this.r,ut,n),vt("s",this.s,ut,n)}addRecoveryBit(_){return new d(this.r,this.s,_)}recoverPublicKey(_){let{r:b,s:p,recovery:E}=this,N=C(Q("msgHash",_));if(E==null||![0,1,2,3].includes(E))throw new Error("recovery id invalid");let U=E===2||E===3?b+t.n:b;if(U>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=E&1?"03":"02",H=c.fromHex(D+h(U)),F=a(U),K=i(-N*F),Y=i(p*F),W=c.BASE.multiplyAndAddUnsafe(H,K,Y);if(!W)throw new Error("point at infinify");return W.assertValidity(),W}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ve(this.toDERHex())}toDERHex(){return ie.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ve(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let m={isValidPrivateKey(S){try{return u(S),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let S=ro(t.n);return Ci(t.randomBytes(S),t.n)},precompute(S=8,_=c.BASE){return _._setWindowSize(S),_.multiply(BigInt(3)),_}};function v(S,_=!0){return c.fromPrivateKey(S).toRawBytes(_)}function g(S){let _=ye(S),b=typeof S=="string",p=(_||b)&&S.length;return _?p===s||p===o:b?p===2*s||p===2*o:S instanceof c}function A(S,_,b=!0){if(g(S))throw new Error("first arg must be private key");if(!g(_))throw new Error("second arg must be public key");return c.fromHex(_).multiply(u(S)).toRawBytes(b)}let L=t.bits2int||function(S){let _=Zt(S),b=S.length*8-t.nBitLength;return b>0?_>>BigInt(b):_},C=t.bits2int_modN||function(S){return i(L(S))},I=Rr(t.nBitLength);function R(S){return vt(`num < 2^${t.nBitLength}`,S,ae,I),be(S,t.nByteLength)}function T(S,_,b=rt){if(["recovered","canonical"].some(at=>at in b))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:E}=t,{lowS:N,prehash:U,extraEntropy:D}=b;N==null&&(N=!0),S=Q("msgHash",S),tc(b),U&&(S=Q("prehashed msgHash",p(S)));let H=C(S),F=u(_),K=[R(F),R(H)];if(D!=null&&D!==!1){let at=D===!0?E(e.BYTES):D;K.push(Q("extraEntropy",at))}let Y=Jt(...K),W=H;function it(at){let ft=L(at);if(!f(ft))return;let yt=a(ft),st=c.BASE.multiply(ft).toAffine(),Et=i(st.x);if(Et===ae)return;let jt=i(yt*i(W+Et*F));if(jt===ae)return;let Er=(st.x===Et?0:2)|Number(st.y&ut),vr=jt;return N&&w(jt)&&(vr=x(jt),Er^=1),new d(Et,vr,Er)}return{seed:Y,k2sig:it}}let rt={lowS:t.lowS,prehash:!1},q={lowS:t.lowS,prehash:!1};function O(S,_,b=rt){let{seed:p,k2sig:E}=T(S,_,b),N=t;return Xs(N.hash.outputLen,N.nByteLength,N.hmac)(p,E)}c.BASE._setWindowSize(8);function nt(S,_,b,p=q){let E=S;if(_=Q("msgHash",_),b=Q("publicKey",b),"strict"in p)throw new Error("options.strict was renamed to lowS");tc(p);let{lowS:N,prehash:U}=p,D,H;try{if(typeof E=="string"||ye(E))try{D=d.fromDER(E)}catch(st){if(!(st instanceof ie.Err))throw st;D=d.fromCompact(E)}else if(typeof E=="object"&&typeof E.r=="bigint"&&typeof E.s=="bigint"){let{r:st,s:Et}=E;D=new d(st,Et)}else throw new Error("PARSE");H=c.fromHex(b)}catch(st){if(st.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(N&&D.hasHighS())return!1;U&&(_=t.hash(_));let{r:F,s:K}=D,Y=C(_),W=a(K),it=i(Y*W),at=i(F*W),ft=c.BASE.multiplyAndAddUnsafe(H,it,at)?.toAffine();return ft?i(ft.x)===F:!1}return{CURVE:t,getPublicKey:v,getSharedSecret:A,sign:O,verify:nt,ProjectivePoint:c,Signature:d,utils:m}}function ih(r){return{hash:r,hmac:(t,...e)=>Ur(r,t,qs(...e)),randomBytes:sr}}function nc(r,t){let e=n=>rc({...r,...ih(n)});return Object.freeze({...e(t),create:e})}var ic=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),sc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),ah=BigInt(1),Uo=BigInt(2),oc=(r,t)=>(r+t/Uo)/t;function ch(r){let t=ic,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=J(l,e,t)*l%t,h=J(f,e,t)*l%t,w=J(h,Uo,t)*u%t,x=J(w,s,t)*w%t,y=J(x,o,t)*x%t,d=J(y,a,t)*y%t,m=J(d,c,t)*d%t,v=J(m,a,t)*y%t,g=J(v,e,t)*l%t,A=J(g,i,t)*x%t,L=J(A,n,t)*u%t,C=J(L,Uo,t);if(!Do.eql(Do.sqr(C),r))throw new Error("Cannot find square root");return C}var Do=we(ic,void 0,void 0,{sqrt:ch}),Dt=nc({a:BigInt(0),b:BigInt(7),Fp:Do,n:sc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=sc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-ah*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=oc(o*r,t),c=oc(-n*r,t),u=G(r-a*e-c*s,t),l=G(-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}}}},ps),Dg=BigInt(0);var Vg=Dt.ProjectivePoint;function ac(){return Dt.utils.randomPrivateKey()}function cc(r,t){let e=ht.digest(t instanceof Uint8Array?t:t.subarray());if(It(e))return e.then(({digest:n})=>Dt.sign(n,r).toDERRawBytes()).catch(n=>{throw new B(String(n),"ERR_INVALID_INPUT")});try{return Dt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new B(String(n),"ERR_INVALID_INPUT")}}function lc(r,t,e){let n=ht.digest(e instanceof Uint8Array?e:e.subarray());if(It(n))return n.then(({digest:s})=>Dt.verify(t,s,r)).catch(s=>{throw new B(String(s),"ERR_INVALID_INPUT")});try{return Dt.verify(t,n.digest,r)}catch(s){throw new B(String(s),"ERR_INVALID_INPUT")}}function uc(r){return Dt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function fc(r){try{Dt.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Vo(r){try{Dt.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function hc(r){try{return Dt.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Yr=class{_key;constructor(t){Vo(t),this._key=t}verify(t,e){return lc(this._key,e,t)}marshal(){return uc(this._key)}get bytes(){return Qt.encode({Type:tt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return It(t)?{bytes:e}=await t:e=t.bytes,e}},Gr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??hc(t),fc(this._key),Vo(this._publicKey)}sign(t){return cc(this._key,t)}get public(){return new Yr(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:tt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return It(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return j(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return cr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function uh(r){return new Gr(r)}function fh(r){return new Yr(r)}async function hh(){let r=ac();return new Gr(r)}var zr={rsa:Co,ed25519:Eo,secp256k1:Oo};function dc(r){let t=Object.keys(zr).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function dh(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return zr[r];throw dc(r)}async function pc(r,t){return dh(r).generateKeyPair(t??2048)}async function Ho(r){let t=Kt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case tt.RSA:return zr.rsa.unmarshalRsaPrivateKey(e);case tt.Ed25519:return zr.ed25519.unmarshalEd25519PrivateKey(e);case tt.Secp256k1:return zr.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw dc(t.Type??"RSA")}}async function Wr(r,t){try{let e=await sa(r,t);return await Ho(e)}catch{}if(!r.includes("BEGIN"))throw new B("Encrypted key was not a libp2p-key or a PEM file","ERR_INVALID_IMPORT_FORMAT");return _o(r,t)}var Zr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Re=new Uint32Array(80),Ko=class extends de{constructor(){super(64,20,8,!1),this.A=Zr[0]|0,this.B=Zr[1]|0,this.C=Zr[2]|0,this.D=Zr[3]|0,this.E=Zr[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)Re[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Re[c]=sn(Re[c-3]^Re[c-8]^Re[c-14]^Re[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=on(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=an(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=sn(n,5)+u+a+l+Re[c]|0;a=i,i=o,o=sn(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(){Re.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},gc=nr(()=>new Ko);var yc={sha1:gc,"sha2-256":ps,"sha2-512":Ue};function Jr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(yc).join(" / ");throw new B(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let o=yc[s],i=aa(o,r,t,{c:e,dkLen:n});return Te.encode(i).substring(1)}var bc=Symbol.for("nodejs.util.inspect.custom"),mc=Object.values(Xe).map(r=>r.decoder).reduce((r,t)=>r.or(t),Xe.identity.decoder),wc=114,Fo=36,$o=37,Xr=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Es]=!0;toString(){return this.string==null&&(this.string=bt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return fe.createV1(wc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return kt(this.multihash.bytes,t);if(typeof t=="string")return ph(t).equals(this);if(t?.multihash?.bytes!=null)return kt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[bc](){return`PeerId(${this.toString()})`}},yr=class extends Xr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},mr=class extends Xr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},br=class extends Xr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},Po=2336,Mo=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Gt.digest(P(this.url))}[bc](){return`PeerId(${this.url})`}[Es]=!0;toString(){return this.toCID().toString()}toCID(){return fe.createV1(Po,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=j(t)),t.toString()===this.toString())}};function ph(r,t){if(t=t??mc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Sr(bt.decode(`z${r}`));return r.startsWith("12D")?new mr({multihash:e}):r.startsWith("16U")?new br({multihash:e}):new yr({multihash:e})}return gh(mc.decode(r))}function gh(r){try{let t=Sr(r);if(t.code===Gt.code){if(t.digest.length===Fo)return new mr({multihash:t});if(t.digest.length===$o)return new br({multihash:t})}if(t.code===ht.code)return new yr({multihash:t})}catch{return yh(fe.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function yh(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==wc&&r.code!==Po)throw new Error("Supplied PeerID CID is invalid");if(r.code===Po){let e=j(r.multihash.digest);return new Mo(new URL(e))}let t=r.multihash;if(t.code===ht.code)return new yr({multihash:r.multihash});if(t.code===Gt.code){if(t.digest.length===Fo)return new mr({multihash:r.multihash});if(t.digest.length===$o)return new br({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function xc(r,t){return r.length===Fo?new mr({multihash:Vt(Gt.code,r),privateKey:t}):r.length===$o?new br({multihash:Vt(Gt.code,r),privateKey:t}):new yr({multihash:await ht.digest(r),publicKey:r,privateKey:t})}var ce="/",Ec=new TextEncoder().encode(ce),gs=Ec[0],Qr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=P(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]!==gs)throw new Error("Invalid key")}toString(t="utf8"){return j(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ce))}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=Ec),this._buf[0]!==gs){let t=new Uint8Array(this._buf.byteLength+1);t.fill(gs,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===gs;)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(ce).slice(1)}type(){return mh(this.baseNamespace())}name(){return bh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ce)||(t+=ce),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ce):new r(t.slice(0,-1).join(ce))}child(t){return this.toString()===ce?t:t.toString()===ce?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(),...wh(t.map(e=>e.namespaces()))])}};function mh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function bh(r){let t=r.split(":");return t[t.length-1]}function wh(r){return[].concat(...r)}var Nc=xs(_c(),1),Tc=Nc.default;var Mc=xs(Pc(),1);var $;(function(r){r.ERR_INVALID_PARAMETERS="ERR_INVALID_PARAMETERS",r.ERR_INVALID_KEY_NAME="ERR_INVALID_KEY_NAME",r.ERR_INVALID_KEY_TYPE="ERR_INVALID_KEY_TYPE",r.ERR_KEY_ALREADY_EXISTS="ERR_KEY_ALREADY_EXISTS",r.ERR_INVALID_KEY_SIZE="ERR_INVALID_KEY_SIZE",r.ERR_KEY_NOT_FOUND="ERR_KEY_NOT_FOUND",r.ERR_OLD_KEY_NAME_INVALID="ERR_OLD_KEY_NAME_INVALID",r.ERR_NEW_KEY_NAME_INVALID="ERR_NEW_KEY_NAME_INVALID",r.ERR_PASSWORD_REQUIRED="ERR_PASSWORD_REQUIRED",r.ERR_PEM_REQUIRED="ERR_PEM_REQUIRED",r.ERR_CANNOT_READ_KEY="ERR_CANNOT_READ_KEY",r.ERR_MISSING_PRIVATE_KEY="ERR_MISSING_PRIVATE_KEY",r.ERR_INVALID_OLD_PASS_TYPE="ERR_INVALID_OLD_PASS_TYPE",r.ERR_INVALID_NEW_PASS_TYPE="ERR_INVALID_NEW_PASS_TYPE",r.ERR_INVALID_PASS_LENGTH="ERR_INVALID_PASS_LENGTH"})($||($={}));var Oh="/pkcs8/",Fc="/info/",qe=new WeakMap,je={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},jo={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function le(r){return r==null||typeof r!="string"?!1:r===(0,Mc.default)(r.trim())&&r.length>0}async function z(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function qt(r){return new Qr(Oh+r)}function _e(r){return new Qr(Fc+r)}var bs=class{components;init;log;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Tc(jo,e),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<je.minKeyLength)throw new Error(`dek.keyLength must be least ${je.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<je.minSaltLength)throw new Error(`dek.saltLength must be least ${je.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<je.minIterationCount)throw new Error(`dek.iterationCount must be least ${je.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Jr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";qe.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[ti]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},jo),e=Math.ceil(je.minSaltLength/3)*3;return t.dek.salt=j(Pt(e),"base64"),t}static get options(){return jo}async createKey(t,e,n=2048){if(!le(t)||t==="self")throw await z(),new B("Invalid key name",$.ERR_INVALID_KEY_NAME);if(typeof e!="string")throw await z(),new B("Invalid key type",$.ERR_INVALID_KEY_TYPE);let s=qt(t);if(await this.components.datastore.has(s))throw await z(),new B("Key name already exists",$.ERR_KEY_ALREADY_EXISTS);switch(e.toLowerCase()){case"rsa":if(!Number.isSafeInteger(n)||n<2048)throw await z(),new B("Invalid RSA key size",$.ERR_INVALID_KEY_SIZE);break;default:break}let i;try{let a=await pc(e,n),c=await a.id(),u=qe.get(this);if(u==null)throw new B("dek missing",$.ERR_INVALID_PARAMETERS);let l=u.dek,f=await a.export(l);i={name:t,id:c};let h=this.components.datastore.batch();h.put(s,P(f)),h.put(_e(t),P(JSON.stringify(i))),await h.commit()}catch(a){throw await z(),a}return i}async listKeys(){let t={prefix:Fc},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(j(n.value)));return e}async findKeyById(t){try{let n=(await this.listKeys()).find(s=>s.id===t);if(n==null)throw new B(`Key with id '${t}' does not exist.`,$.ERR_KEY_NOT_FOUND);return n}catch(e){throw await z(),e}}async findKeyByName(t){if(!le(t))throw await z(),new B(`Invalid key name '${t}'`,$.ERR_INVALID_KEY_NAME);let e=_e(t);try{let n=await this.components.datastore.get(e);return JSON.parse(j(n))}catch(n){throw await z(),this.log.error(n),new B(`Key '${t}' does not exist.`,$.ERR_KEY_NOT_FOUND)}}async removeKey(t){if(!le(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,$.ERR_INVALID_KEY_NAME);let e=qt(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(_e(t)),await s.commit(),n}async renameKey(t,e){if(!le(t)||t==="self")throw await z(),new B(`Invalid old key name '${t}'`,$.ERR_OLD_KEY_NAME_INVALID);if(!le(e)||e==="self")throw await z(),new B(`Invalid new key name '${e}'`,$.ERR_NEW_KEY_NAME_INVALID);let n=qt(t),s=qt(e),o=_e(t),i=_e(e);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${e}' already exists`,$.ERR_KEY_ALREADY_EXISTS);try{let c=await this.components.datastore.get(n),u=await this.components.datastore.get(o),l=JSON.parse(j(u));l.name=e;let f=this.components.datastore.batch();return f.put(s,c),f.put(i,P(JSON.stringify(l))),f.delete(n),f.delete(o),await f.commit(),l}catch(c){throw await z(),c}}async exportKey(t,e){if(!le(t))throw await z(),new B(`Invalid key name '${t}'`,$.ERR_INVALID_KEY_NAME);if(e==null)throw await z(),new B("Password is required",$.ERR_PASSWORD_REQUIRED);let n=qt(t);try{let s=await this.components.datastore.get(n),o=j(s),i=qe.get(this);if(i==null)throw new B("dek missing",$.ERR_INVALID_PARAMETERS);let a=i.dek;return await(await Wr(o,a)).export(e)}catch(s){throw await z(),s}}async exportPeerId(t){let e="temporary-password",n=await this.exportKey(t,e),s=await Wr(n,e);return xc(s.public.bytes,s.bytes)}async importKey(t,e,n){if(!le(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,$.ERR_INVALID_KEY_NAME);if(e==null)throw await z(),new B("PEM encoded key is required",$.ERR_PEM_REQUIRED);let s=qt(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,$.ERR_KEY_ALREADY_EXISTS);let i;try{i=await Wr(e,n)}catch{throw await z(),new B("Cannot read the key, most likely the password is wrong",$.ERR_CANNOT_READ_KEY)}let a;try{a=await i.id();let l=qe.get(this);if(l==null)throw new B("dek missing",$.ERR_INVALID_PARAMETERS);let f=l.dek;e=await i.export(f)}catch(l){throw await z(),l}let c={name:t,id:a},u=this.components.datastore.batch();return u.put(s,P(e)),u.put(_e(t),P(JSON.stringify(c))),await u.commit(),c}async importPeer(t,e){try{if(!le(t))throw new B(`Invalid key name '${t}'`,$.ERR_INVALID_KEY_NAME);if(e==null)throw new B("PeerId is required",$.ERR_MISSING_PRIVATE_KEY);if(e.privateKey==null)throw new B("PeerId.privKey is required",$.ERR_MISSING_PRIVATE_KEY);let n=await Ho(e.privateKey),s=qt(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,$.ERR_KEY_ALREADY_EXISTS);let i=qe.get(this);if(i==null)throw new B("dek missing",$.ERR_INVALID_PARAMETERS);let a=i.dek,c=await n.export(a),u={name:t,id:e.toString()},l=this.components.datastore.batch();return l.put(s,P(c)),l.put(_e(t),P(JSON.stringify(u))),await l.commit(),u}catch(n){throw await z(),n}}async getPrivateKey(t){if(!le(t))throw await z(),new B(`Invalid key name '${t}'`,$.ERR_INVALID_KEY_NAME);try{let e=qt(t),n=await this.components.datastore.get(e);return j(n)}catch(e){throw await z(),this.log.error(e),new B(`Key '${t}' does not exist.`,$.ERR_KEY_NOT_FOUND)}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await z(),new B(`Invalid old pass type '${typeof t}'`,$.ERR_INVALID_OLD_PASS_TYPE);if(typeof e!="string")throw await z(),new B(`Invalid new pass type '${typeof e}'`,$.ERR_INVALID_NEW_PASS_TYPE);if(e.length<20)throw await z(),new B(`Invalid pass length ${e.length}`,$.ERR_INVALID_PASS_LENGTH);this.log("recreating keychain");let n=qe.get(this);if(n==null)throw new B("dek missing",$.ERR_INVALID_PARAMETERS);let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Jr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";qe.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(qt(a.name)),u=j(c),l=await Wr(u,s),f=o.toString(),h=await l.export(f),w=this.components.datastore.batch(),x={name:a.name,id:a.id};w.put(qt(a.name),P(h)),w.put(_e(a.name),P(JSON.stringify(x))),await w.commit()}this.log("keychain reconstructed")}};function Hh(r={}){return t=>new bs(t,r)}return rl(Kh);})();
|
|
6
|
+
`)}`:`${e} :`}};oa=xe;k.Constructed=oa;xe.NAME="CONSTRUCTED";var Sn=class extends pt{fromBER(t,e,n){return e}toBER(t){return Ut}};Sn.override="EndOfContentValueBlock";var ia,In=class extends ut{constructor(t={}){super(t,Sn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ia=In;k.EndOfContent=ia;In.NAME=Rr;var aa,Wt=class extends ut{constructor(t={}){super(t,pt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};aa=Wt;k.Null=aa;Wt.NAME="NULL";var Nn=class extends Qt(pt){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 Xt(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,xo.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Nn.NAME="BooleanValueBlock";var ca,Cn=class extends ut{constructor(t={}){super(t,Nn),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}`}};ca=Cn;k.Boolean=ca;Cn.NAME="BOOLEAN";var Tn=class extends Qt(Vt){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=Vt.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===Rr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==ea)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Vt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Tn.NAME="OctetStringValueBlock";var la,Jt=class r extends ut{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},Tn),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=ss(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?xe.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)}};la=Jt;k.OctetString=la;Jt.NAME=ea;var Un=class extends Qt(Vt){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=Vt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Rr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ra)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(!Xt(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=ss(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 Vt.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}}};Un.NAME="BitStringValueBlock";var ua,er=class extends ut{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Un),this.idBlock.tagClass=1,this.idBlock.tagNumber=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 xe.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)}`}}};ua=er;k.BitString=ua;er.NAME=ra;var fa;function Tf(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=wn(new Uint8Array([u%10]),o);break;default:o[i-f]=u%10}}return e[0]>0&&(o=wn(e,o)),o}function ta(r){if(r>=Tr.length)for(let t=Tr.length;t<=r;t++){let e=new Uint8Array([0]),n=Tr[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=wn(e,n)),Tr.push(n)}return Tr[r]}function Uf(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 Lr=class extends Qt(pt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=xo.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Yi(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=Uf(ta(n),e),i="-";break;default:e=Tf(e,ta(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Qi.charAt(e[c]));return a===!1&&(i+=Qi.charAt(0)),i}};fa=Lr;Lr.NAME="IntegerValueBlock";Object.defineProperty(fa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ha,X=class r extends ut{constructor(t={}){super(t,Lr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return xn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){xn();let e=BigInt(t),n=new Ur,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()}`}};ha=X;k.Integer=ha;X.NAME="INTEGER";var da,Rn=class extends X{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};da=Rn;k.Enumerated=da;Rn.NAME="ENUMERATED";var _r=class extends Qt(pt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!Xt(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=Le(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){xn();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=we(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}}};_r.NAME="sidBlock";var Ln=class extends pt{constructor({value:t=rr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new _r;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 vo(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 _r;if(s>Number.MAX_SAFE_INTEGER){xn();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}};Ln.NAME="ObjectIdentifierValueBlock";var pa,kt=class extends ut{constructor(t={}){super(t,Ln),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()}}};pa=kt;k.ObjectIdentifier=pa;kt.NAME="OBJECT IDENTIFIER";var Hr=class extends Qt(Zt){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(!Xt(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=Le(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=we(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}}};Hr.NAME="relativeSidBlock";var _n=class extends pt{constructor({value:t=rr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Hr;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 vo(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 Hr;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 ga,Hn=class extends ut{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()}}};ga=Hn;k.RelativeObjectIdentifier=ga;Hn.NAME="RelativeObjectIdentifier";var ma,nt=class extends xe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ma=nt;k.Sequence=ma;nt.NAME="SEQUENCE";var ya,Vn=class extends xe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ya=Vn;k.Set=ya;Vn.NAME="SET";var On=class extends Qt(pt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=rr}toJSON(){return{...super.toJSON(),value:this.value}}};On.NAME="StringValueBlock";var Dn=class extends On{};Dn.NAME="SimpleStringValueBlock";var yt=class extends En{constructor({...t}={}){super(t,Dn)}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}};yt.NAME="SIMPLE STRING";var Kn=class extends yt{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}};Kn.NAME="Utf8StringValueBlock";var ba,Yt=class extends Kn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ba=Yt;k.Utf8String=ba;Yt.NAME="UTF8String";var Mn=class extends yt{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))}};Mn.NAME="BmpStringValueBlock";var wa,Pn=class extends Mn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};wa=Pn;k.BmpString=wa;Pn.NAME="BMPString";var Fn=class extends yt{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=we(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}};Fn.NAME="UniversalStringValueBlock";var xa,$n=class extends Fn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};xa=$n;k.UniversalString=xa;$n.NAME="UniversalString";var va,qn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};va=qn;k.NumericString=va;qn.NAME="NumericString";var Ba,jn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ba=jn;k.PrintableString=Ba;jn.NAME="PrintableString";var Ea,zn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ea=zn;k.TeletexString=Ea;zn.NAME="TeletexString";var Aa,Gn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Aa=Gn;k.VideotexString=Aa;Gn.NAME="VideotexString";var ka,Zn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ka=Zn;k.IA5String=ka;Zn.NAME="IA5String";var Sa,Wn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Sa=Wn;k.GraphicString=Sa;Wn.NAME="GraphicString";var Ia,Vr=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ia=Vr;k.VisibleString=Ia;Vr.NAME="VisibleString";var Na,Jn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Na=Jn;k.GeneralString=Na;Jn.NAME="GeneralString";var Ca,Yn=class extends yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ca=Yn;k.CharacterString=Ca;Yn.NAME="CharacterString";var Ta,Or=class extends Vr{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]=Bt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Bt(this.month,2),e[2]=Bt(this.day,2),e[3]=Bt(this.hour,2),e[4]=Bt(this.minute,2),e[5]=Bt(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}}};Ta=Or;k.UTCTime=Ta;Or.NAME="UTCTime";var Ua,Xn=class extends Or{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("+"),w="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(w=n.substring(h+1),n=n.substring(0,h),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let x=parseInt(w.substring(0,2),10);if(isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*x,w.length===4){if(x=parseInt(w.substring(2,4),10),isNaN(x.valueOf()))throw new Error("Wrong input string for conversion");c=f*x}}}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(Bt(this.year,4)),e.push(Bt(this.month,2)),e.push(Bt(this.day,2)),e.push(Bt(this.hour,2)),e.push(Bt(this.minute,2)),e.push(Bt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Bt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ua=Xn;k.GeneralizedTime=Ua;Xn.NAME="GeneralizedTime";var Ra,Qn=class extends Yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ra=Qn;k.DATE=Ra;Qn.NAME="DATE";var La,ts=class extends Yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};La=ts;k.TimeOfDay=La;ts.NAME="TimeOfDay";var _a,es=class extends Yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};_a=es;k.DateTime=_a;es.NAME="DateTime";var Ha,rs=class extends Yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ha=rs;k.Duration=Ha;rs.NAME="Duration";var Va,ns=class extends Yt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Va=ns;k.TIME=Va;ns.NAME="TIME";function W(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function He(r){if(isNaN(r)||r<=0)throw new _("random bytes length must be a Number bigger than 0");return Je(r)}async function Oa(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 Rf(t);return{privateKey:e[0],publicKey:e[1]}}async function Da(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 Ka(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 Rf(r){if(r.privateKey==null||r.publicKey==null)throw new _("Private and public key are required");return Promise.all([wt.get().subtle.exportKey("jwk",r.privateKey),wt.get().subtle.exportKey("jwk",r.publicKey)])}function Ao(r){if(r.kty!=="RSA")throw new _("invalid key type");if(r.n==null)throw new _("invalid key modulus");return $(r.n,"base64url").length*8}var nr=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Dr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Lt.createV1(114,this._multihash)}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Pt(this.raw,t.raw)}verify(t,e){return Ka(this._key,e,t)}},Kr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Dr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Pt(this.raw,t.raw)}sign(t){return Da(this._key,t)}};var os=8192,ko=18;function Ma(r){let{result:t}=_e(r),e=t.valueBlock.value;return{n:W(Ot(e[1].toBigInt()),"base64url"),e:W(Ot(e[2].toBigInt()),"base64url"),d:W(Ot(e[3].toBigInt()),"base64url"),p:W(Ot(e[4].toBigInt()),"base64url"),q:W(Ot(e[5].toBigInt()),"base64url"),dp:W(Ot(e[6].toBigInt()),"base64url"),dq:W(Ot(e[7].toBigInt()),"base64url"),qi:W(Ot(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Lf(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new _("JWK was missing components");let e=new nt({value:[new X({value:0}),X.fromBigInt(Dt($(r.n,"base64url"))),X.fromBigInt(Dt($(r.e,"base64url"))),X.fromBigInt(Dt($(r.d,"base64url"))),X.fromBigInt(Dt($(r.p,"base64url"))),X.fromBigInt(Dt($(r.q,"base64url"))),X.fromBigInt(Dt($(r.dp,"base64url"))),X.fromBigInt(Dt($(r.dq,"base64url"))),X.fromBigInt(Dt($(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Pa(r){let{result:t}=_e(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:W(Ot(e[0].toBigInt()),"base64url"),e:W(Ot(e[1].toBigInt()),"base64url")}}function So(r){if(r.n==null||r.e==null)throw new _("JWK was missing components");let e=new nt({value:[new nt({value:[new kt({value:"1.2.840.113549.1.1.1"}),new Wt]}),new er({valueHex:new nt({value:[X.fromBigInt(Dt($(r.n,"base64url"))),X.fromBigInt(Dt($(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ot(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function Dt(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 is(r){let t=Ma(r);return $a(t)}function Fa(r){let t=Pa(r);if(Ao(t)>os)throw new De("Key size is too large");let e=be(ge.encode({Type:at.RSA,Data:r})),n=St(ko,e);return new nr(t,n)}function $a(r){if(Ao(r)>os)throw new _("Key size is too large");let t=ja(r),e=be(ge.encode({Type:at.RSA,Data:So(t.publicKey)})),n=St(ko,e);return new Kr(t.privateKey,new nr(t.publicKey,n))}async function qa(r){if(r>os)throw new _("Key size is too large");let t=await Oa(r),e=be(ge.encode({Type:at.RSA,Data:So(t.publicKey)})),n=St(ko,e);return new Kr(t.privateKey,new nr(t.publicKey,n))}function ja(r){if(r==null)throw new _("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var as=class extends Ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Jr(t);let n=se(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ge(this),this.iHash.update(t),this}digestInto(t){Ge(this),ze(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Mr=(r,t,e)=>new as(r,t).update(e).digest();Mr.create=(r,t)=>new as(r,t);function za(r){r.lowS!==void 0&&Nt("lowS",r.lowS),r.prehash!==void 0&&Nt("prehash",r.prehash)}function _f(r){let t=Br(r);_t(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Hf,hexToBytes:Vf}=rn,te={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=te;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=ke(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?ke(s.length/2|128):"";return`${ke(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=te,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}=te;if(r<ee)throw new t("integer: negative integers are not allowed");let e=ke(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=te;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 Hf(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=te,s=typeof r=="string"?Vf(r):r;Ye(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}=te,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},ee=BigInt(0),ct=BigInt(1),Zp=BigInt(2),Ga=BigInt(3),Wp=BigInt(4);function Of(r){let t=_f(r),{Fp:e}=t,n=he(t.n,t.nBitLength),s=t.toBytes||((m,d,y)=>{let B=d.toAffine();return jt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(m=>{let d=m.subarray(1),y=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:y,y:B}});function i(m){let{a:d,b:y}=t,B=e.sqr(m),g=e.mul(B,m);return e.add(e.add(g,e.mul(m,d)),y)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return xr(m,ct,t.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:y,wrapPrivateKey:B,n:g}=t;if(d&&typeof m!="bigint"){if(le(m)&&(m=$t(m)),typeof m!="string"||!d.includes(m.length))throw new Error("Invalid key");m=m.padStart(y*2,"0")}let E;try{E=typeof m=="bigint"?m:qt(Y("private key",m,y))}catch{throw new Error(`private key must be ${y} bytes, hex or bigint, not ${typeof m}`)}return B&&(E=j(E,g)),xt("private key",E,ct,g),E}function u(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let l=Ne((m,d)=>{let{px:y,py:B,pz:g}=m;if(e.eql(g,e.ONE))return{x:y,y:B};let E=m.is0();d==null&&(d=E?e.ONE:e.inv(g));let R=e.mul(y,d),U=e.mul(B,d),S=e.mul(g,d);if(E)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:R,y:U}}),f=Ne(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y}=m.toAffine();if(!e.isValid(d)||!e.isValid(y))throw new Error("bad point: x or y not FE");let B=e.sqr(y),g=i(d);if(!e.eql(B,g))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,y,B){if(this.px=d,this.py=y,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(y==null||!e.isValid(y))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:y,y:B}=d||{};if(!d||!e.isValid(y)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let g=E=>e.eql(E,e.ZERO);return g(y)&&g(B)?h.ZERO:new h(y,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let y=e.invertBatch(d.map(B=>B.pz));return d.map((B,g)=>B.toAffine(y[g])).map(h.fromAffine)}static fromHex(d){let y=h.fromAffine(o(Y("pointHex",d)));return y.assertValidity(),y}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,y){return on(h,n,d,y)}_setWindowSize(d){x.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:y,py:B,pz:g}=this,{px:E,py:R,pz:U}=d,S=e.eql(e.mul(y,U),e.mul(E,g)),I=e.eql(e.mul(B,U),e.mul(R,g));return S&&I}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:y}=t,B=e.mul(y,Ga),{px:g,py:E,pz:R}=this,U=e.ZERO,S=e.ZERO,I=e.ZERO,T=e.mul(g,g),Q=e.mul(E,E),F=e.mul(R,R),O=e.mul(g,E);return O=e.add(O,O),I=e.mul(g,R),I=e.add(I,I),U=e.mul(d,I),S=e.mul(B,F),S=e.add(U,S),U=e.sub(Q,S),S=e.add(Q,S),S=e.mul(U,S),U=e.mul(O,U),I=e.mul(B,I),F=e.mul(d,F),O=e.sub(T,F),O=e.mul(d,O),O=e.add(O,I),I=e.add(T,T),T=e.add(I,T),T=e.add(T,F),T=e.mul(T,O),S=e.add(S,T),F=e.mul(E,R),F=e.add(F,F),T=e.mul(F,O),U=e.sub(U,T),I=e.mul(F,Q),I=e.add(I,I),I=e.add(I,I),new h(U,S,I)}add(d){u(d);let{px:y,py:B,pz:g}=this,{px:E,py:R,pz:U}=d,S=e.ZERO,I=e.ZERO,T=e.ZERO,Q=t.a,F=e.mul(t.b,Ga),O=e.mul(y,E),tt=e.mul(B,R),A=e.mul(g,U),N=e.add(y,B),b=e.add(E,R);N=e.mul(N,b),b=e.add(O,tt),N=e.sub(N,b),b=e.add(y,g);let p=e.add(E,U);return b=e.mul(b,p),p=e.add(O,A),b=e.sub(b,p),p=e.add(B,g),S=e.add(R,U),p=e.mul(p,S),S=e.add(tt,A),p=e.sub(p,S),T=e.mul(Q,b),S=e.mul(F,A),T=e.add(S,T),S=e.sub(tt,T),T=e.add(tt,T),I=e.mul(S,T),tt=e.add(O,O),tt=e.add(tt,O),A=e.mul(Q,A),b=e.mul(F,b),tt=e.add(tt,A),A=e.sub(O,A),A=e.mul(Q,A),b=e.add(b,A),O=e.mul(tt,b),I=e.add(I,O),O=e.mul(p,b),S=e.mul(N,S),S=e.sub(S,O),O=e.mul(N,tt),T=e.mul(p,T),T=e.add(T,O),new h(S,I,T)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return x.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){xt("scalar",d,ee,t.n);let y=h.ZERO;if(d===ee)return y;if(d===ct)return this;let{endo:B}=t;if(!B)return x.unsafeLadder(this,d);let{k1neg:g,k1:E,k2neg:R,k2:U}=B.splitScalar(d),S=y,I=y,T=this;for(;E>ee||U>ee;)E&ct&&(S=S.add(T)),U&ct&&(I=I.add(T)),T=T.double(),E>>=ct,U>>=ct;return g&&(S=S.negate()),R&&(I=I.negate()),I=new h(e.mul(I.px,B.beta),I.py,I.pz),S.add(I)}multiply(d){let{endo:y,n:B}=t;xt("scalar",d,ct,B);let g,E;if(y){let{k1neg:R,k1:U,k2neg:S,k2:I}=y.splitScalar(d),{p:T,f:Q}=this.wNAF(U),{p:F,f:O}=this.wNAF(I);T=x.constTimeNegate(R,T),F=x.constTimeNegate(S,F),F=new h(e.mul(F.px,y.beta),F.py,F.pz),g=T.add(F),E=Q.add(O)}else{let{p:R,f:U}=this.wNAF(d);g=R,E=U}return h.normalizeZ([g,E])[0]}multiplyAndAddUnsafe(d,y,B){let g=h.BASE,E=(U,S)=>S===ee||S===ct||!U.equals(g)?U.multiplyUnsafe(S):U.multiply(S),R=E(this,y).add(E(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:y}=t;if(d===ct)return!0;if(y)return y(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:y}=t;return d===ct?this:y?y(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),$t(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let w=t.nBitLength,x=sn(h,t.endo?Math.ceil(w/2):w);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Df(r){let t=Br(r);return _t(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Za(r){let t=Df(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(A){return j(A,n)}function a(A){return nn(A,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=Of({...t,toBytes(A,N,b){let p=N.toAffine(),v=e.toBytes(p.x),C=jt;return Nt("isCompressed",b),b?C(Uint8Array.from([N.hasEvenY()?2:3]),v):C(Uint8Array.from([4]),v,e.toBytes(p.y))},fromBytes(A){let N=A.length,b=A[0],p=A.subarray(1);if(N===s&&(b===2||b===3)){let v=qt(p);if(!xr(v,ct,e.ORDER))throw new Error("Point is not on curve");let C=l(v),L;try{L=e.sqrt(C)}catch(P){let K=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+K)}let H=(L&ct)===ct;return(b&1)===1!==H&&(L=e.neg(L)),{x:v,y:L}}else if(N===o&&b===4){let v=e.fromBytes(p.subarray(0,e.BYTES)),C=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:v,y:C}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),h=A=>$t(fe(A,t.nByteLength));function w(A){let N=n>>ct;return A>N}function x(A){return w(A)?i(-A):A}let m=(A,N,b)=>qt(A.slice(N,b));class d{constructor(N,b,p){this.r=N,this.s=b,this.recovery=p,this.assertValidity()}static fromCompact(N){let b=t.nByteLength;return N=Y("compactSignature",N,b*2),new d(m(N,0,b),m(N,b,2*b))}static fromDER(N){let{r:b,s:p}=te.toSig(Y("DER",N));return new d(b,p)}assertValidity(){xt("r",this.r,ct,n),xt("s",this.s,ct,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:b,s:p,recovery:v}=this,C=U(Y("msgHash",N));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let L=v===2||v===3?b+t.n:b;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),K=i(-C*P),q=i(p*P),z=c.BASE.multiplyAndAddUnsafe(D,K,q);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Se(this.toDERHex())}toDERHex(){return te.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Se(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let y={isValidPrivateKey(A){try{return u(A),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let A=Ks(t.n);return Bi(t.randomBytes(A),t.n)},precompute(A=8,N=c.BASE){return N._setWindowSize(A),N.multiply(BigInt(3)),N}};function B(A,N=!0){return c.fromPrivateKey(A).toRawBytes(N)}function g(A){let N=le(A),b=typeof A=="string",p=(N||b)&&A.length;return N?p===s||p===o:b?p===2*s||p===2*o:A instanceof c}function E(A,N,b=!0){if(g(A))throw new Error("first arg must be private key");if(!g(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(u(A)).toRawBytes(b)}let R=t.bits2int||function(A){let N=qt(A),b=A.length*8-t.nBitLength;return b>0?N>>BigInt(b):N},U=t.bits2int_modN||function(A){return i(R(A))},S=vr(t.nBitLength);function I(A){return xt(`num < 2^${t.nBitLength}`,A,ee,S),fe(A,t.nByteLength)}function T(A,N,b=Q){if(["recovered","canonical"].some(ot=>ot in b))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:v}=t,{lowS:C,prehash:L,extraEntropy:H}=b;C==null&&(C=!0),A=Y("msgHash",A),za(b),L&&(A=Y("prehashed msgHash",p(A)));let D=U(A),P=u(N),K=[I(P),I(D)];if(H!=null&&H!==!1){let ot=H===!0?v(e.BYTES):H;K.push(Y("extraEntropy",ot))}let q=jt(...K),z=D;function st(ot){let lt=R(ot);if(!f(lt))return;let gt=a(lt),et=c.BASE.multiply(lt).toAffine(),bt=i(et.x);if(bt===ee)return;let Kt=i(gt*i(z+bt*P));if(Kt===ee)return;let ur=(et.x===bt?0:2)|Number(et.y&ct),fr=Kt;return C&&w(Kt)&&(fr=x(Kt),ur^=1),new d(bt,fr,ur)}return{seed:q,k2sig:st}}let Q={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function O(A,N,b=Q){let{seed:p,k2sig:v}=T(A,N,b),C=t;return Hs(C.hash.outputLen,C.nByteLength,C.hmac)(p,v)}c.BASE._setWindowSize(8);function tt(A,N,b,p=F){let v=A;if(N=Y("msgHash",N),b=Y("publicKey",b),"strict"in p)throw new Error("options.strict was renamed to lowS");za(p);let{lowS:C,prehash:L}=p,H,D;try{if(typeof v=="string"||le(v))try{H=d.fromDER(v)}catch(et){if(!(et instanceof te.Err))throw et;H=d.fromCompact(v)}else if(typeof v=="object"&&typeof v.r=="bigint"&&typeof v.s=="bigint"){let{r:et,s:bt}=v;H=new d(et,bt)}else throw new Error("PARSE");D=c.fromHex(b)}catch(et){if(et.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(C&&H.hasHighS())return!1;L&&(N=t.hash(N));let{r:P,s:K}=H,q=U(N),z=a(K),st=i(q*z),ot=i(P*z),lt=c.BASE.multiplyAndAddUnsafe(D,st,ot)?.toAffine();return lt?i(lt.x)===P:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:E,sign:O,verify:tt,ProjectivePoint:c,Signature:d,utils:y}}function Kf(r){return{hash:r,hmac:(t,...e)=>Mr(r,t,Is(...e)),randomBytes:Je}}function Wa(r,t){let e=n=>Za({...r,...Kf(n)});return Object.freeze({...e(t),create:e})}var Xa=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ja=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Mf=BigInt(1),Io=BigInt(2),Ya=(r,t)=>(r+t/Io)/t;function Pf(r){let t=Xa,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=Z(l,e,t)*l%t,h=Z(f,e,t)*l%t,w=Z(h,Io,t)*u%t,x=Z(w,s,t)*w%t,m=Z(x,o,t)*x%t,d=Z(m,a,t)*m%t,y=Z(d,c,t)*d%t,B=Z(y,a,t)*m%t,g=Z(B,e,t)*l%t,E=Z(g,i,t)*x%t,R=Z(E,n,t)*u%t,U=Z(R,Io,t);if(!No.eql(No.sqr(U),r))throw new Error("Cannot find square root");return U}var No=he(Xa,void 0,void 0,{sqrt:Pf}),Rt=Wa({a:BigInt(0),b:BigInt(7),Fp:No,n:Ja,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ja,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Mf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ya(o*r,t),c=Ya(-n*r,t),u=j(r-a*e-c*s,t),l=j(-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),sg=BigInt(0);var og=Rt.ProjectivePoint;function Co(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Ht(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function To(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Qa(r,t){let e=Xe.digest(t instanceof Uint8Array?t:t.subarray());if(To(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 tc(r,t,e){let n=Xe.digest(e instanceof Uint8Array?e:e.subarray());if(To(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 cs=class{type="secp256k1";raw;_key;constructor(t){this._key=nc(t),this.raw=ec(this._key)}toMultihash(){return wr.digest(ln(this))}toCID(){return Lt.createV1(114,this.toMultihash())}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Pt(this.raw,t.raw)}verify(t,e){return tc(this._key,e,t)}},ls=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=rc(t),this.publicKey=new cs(e??sc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Pt(this.raw,t.raw)}sign(t){return Qa(this.raw,t)}};function Uo(r){return new ls(r)}function ec(r){return Rt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function rc(r){try{return Rt.getPublicKey(r,!0),r}catch(t){throw new pr(String(t))}}function nc(r){try{return Rt.ProjectivePoint.fromHex(r),r}catch(t){throw new De(String(t))}}function sc(r){try{return Rt.getPublicKey(r,!0)}catch(t){throw new pr(String(t))}}function ln(r){return ge.encode({Type:at[r.type],Data:r.raw})}function oc(r){let t=Cr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return is(e);case at.Ed25519:return qs(e);case at.secp256k1:return Uo(e);default:throw new Ke}}function ic(r){return r.byteLength===64?qs(r):r.byteLength===32?Uo(r):is(r)}function sr(r){return Cr.encode({Type:at[r.type],Data:r.raw})}function ac(r,t,e,n){Jr(r);let s=pi({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(je(o),je(i),je(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=se(t),u=se(e),l=new Uint8Array(i),f=Mr.create(r,c),h=f._cloneInto().update(u);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function cc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function lc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=ac(r,t,e,n),u,l=new Uint8Array(4),f=Ae(l),h=new Uint8Array(a.outputLen);for(let w=1,x=0;x<o;w++,x+=a.outputLen){let m=i.subarray(x,x+a.outputLen);f.setInt32(0,w,!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 y=0;y<m.length;y++)m[y]^=h[y]}}return cc(a,c,i,u,h)}async function us(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=ac(r,t,e,n),l,f=new Uint8Array(4),h=Ae(f),w=new Uint8Array(c.outputLen);for(let x=1,m=0;m<o;x++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,x,!1),(l=u._cloneInto(l)).update(f).digestInto(w),d.set(w.subarray(0,d.length)),await hi(s-1,i,()=>{c._cloneInto(l).update(w).digestInto(w);for(let y=0;y<d.length;y++)d[y]^=w[y]})}return cc(c,u,a,l,w)}var Pr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),ve=new Uint32Array(80),Ro=class extends oe{constructor(){super(64,20,8,!1),this.A=Pr[0]|0,this.B=Pr[1]|0,this.C=Pr[2]|0,this.D=Pr[3]|0,this.E=Pr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)ve[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)ve[c]=Yr(ve[c-3]^ve[c-8]^ve[c-14]^ve[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let u,l;c<20?(u=Xr(s,o,i),l=1518500249):c<40?(u=s^o^i,l=1859775393):c<60?(u=Qr(s,o,i),l=2400959708):(u=s^o^i,l=3395469782);let f=Yr(n,5)+u+a+l+ve[c]|0;a=i,i=o,o=Yr(s,30),s=n,n=f}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){ve.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},uc=We(()=>new Ro);var fc={sha1:uc,"sha2-256":be,"sha2-512":ce};function Fr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(fc).join(" / ");throw new _(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=fc[s],i=lc(o,r,t,{c:e,dkLen:n});return Ue.encode(i).substring(1)}var re="/",hc=new TextEncoder().encode(re),fs=hc[0],$r=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=$(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]!==fs)throw new Error("Invalid key")}toString(t="utf8"){return W(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(re))}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=hc),this._buf[0]!==fs){let t=new Uint8Array(this._buf.byteLength+1);t.fill(fs,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===fs;)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(re).slice(1)}type(){return Ff(this.baseNamespace())}name(){return $f(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(re)||(t+=re),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(re):new r(t.slice(0,-1).join(re))}child(t){return this.toString()===re?t:t.toString()===re?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(),...qf(t.map(e=>e.namespaces()))])}};function Ff(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function $f(r){let t=r.split(":");return t[t.length-1]}function qf(r){return[].concat(...r)}var vc=ys(xc(),1),Bc=vc.default;var Hc=ys(Uc(),1);var ar={};ht(ar,{create:()=>ch,derivedEmptyPasswordKey:()=>ps});var ps={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function ch(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 w=a.getRandomValues(new Uint8Array(o)),x=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:x};typeof h=="string"&&(h=$(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",ps,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,g,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",ps,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,g,{name:t,length:e},!0,["encrypt"])}let y=await a.subtle.encrypt(m,d,f);return Co([w,m.iv,new Uint8Array(y)])}async function u(f,h){let w=f.subarray(0,o),x=f.subarray(o,o+n),m=f.subarray(o+n),d={name:t,iv:x};typeof h=="string"&&(h=$(h));let y;if(h.length===0)try{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},E=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(g,E,{name:t,length:e},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",ps,{name:"AES-GCM"},!0,["decrypt"])}else{let g={name:"PBKDF2",salt:w,iterations:i,hash:{name:s}},E=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(g,E,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,y,m);return new Uint8Array(B)}return{encrypt:c,decrypt:u}}async function _o(r,t){let n=await ar.create().encrypt(r,t);return Ue.encode(n)}async function Ho(r,t,e){if(r.type==="RSA")return fh(r,t,e);if(r.type==="Ed25519")return lh(r,t,e);if(r.type==="secp256k1")return uh(r,t,e);throw new Ke}async function lh(r,t,e="libp2p-key"){if(e==="libp2p-key")return _o(sr(r),t);throw new _(`export format '${e}' is not supported`)}async function uh(r,t,e="libp2p-key"){if(e==="libp2p-key")return _o(sr(r),t);throw new _("Export format is not supported")}async function fh(r,t,e="pkcs-8"){if(e==="pkcs-8")return hh(r,t);if(e==="libp2p-key")return _o(sr(r),t);throw new _("Export format is not supported")}async function hh(r,t){let e=wt.get(),s=new nt({value:[new X({value:0}),new nt({value:[new kt({value:"1.2.840.113549.1.1.1"}),new Wt]}),new Jt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=He(16),a=await us(ce,t,i,{c:1e4,dkLen:32}),c=He(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 nt({value:[new Jt({valueHex:i}),new X({value:1e4}),new X({value:32}),new nt({value:[new kt({value:"1.2.840.113549.2.11"}),new Wt]})]}),h=new nt({value:[new kt({value:"1.2.840.113549.1.5.13"}),new nt({value:[new nt({value:[new kt({value:"1.2.840.113549.1.5.12"}),f]}),new nt({value:[new kt({value:"2.16.840.1.101.3.4.1.42"}),new Jt({valueHex:c})]})]})]}),x=new nt({value:[h,new Jt({valueHex:l})]}).toBER(),m=new Uint8Array(x,0,x.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...W(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function Vo(r,t){try{let e=await dh(r,t);return oc(e)}catch{}if(!r.includes("BEGIN"))throw new _("Encrypted key was not a libp2p-key or a PEM file");return ph(r,t)}async function dh(r,t){let e=Ue.decode(r);return ar.create().decrypt(e,t)}async function ph(r,t){let e=wt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=$(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=_e(o),{iv:a,salt:c,iterations:u,keySize:l,cipherText:f}=gh(i),h=await us(ce,t,c,{c:u,dkLen:l}),w=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),x=qr(await e.subtle.decrypt({name:"AES-CBC",iv:a},w,f)),{result:m}=_e(x);n=_c(m)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=$(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=_e(o);n=_c(i)}else throw new _("Could not parse private key from PEM data");let s=ic(n);if(s.type!=="RSA")throw new _("Could not parse RSA private key from PEM data");return s}function gh(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new _("Only pkcs5PBES2 encrypted private keys are supported");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new _("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=qr(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 _("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 _("Only AES-CBC encryption schemes are supported")}}}}let f=qr(u.valueBlock.value[1].getValue());return{cipherText:qr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function _c(r){return qr(r.valueBlock.value[2].getValue())}function qr(r){return new Uint8Array(r,0,r.byteLength)}var mh="/pkcs8/",Do="/info/",jr=new WeakMap,Ve={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Oo={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function cr(r){return r==null||typeof r!="string"?!1:r===(0,Hc.default)(r.trim())&&r.length>0}async function ft(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Oe(r){return new $r(mh+r)}function lr(r){return new $r(Do+r)}async function yh(r){let t=sr(r),e=await Xe.digest(t);return it.encode(e.bytes).substring(1)}var gs=class{components;init;log;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Bc(Oo,e),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<Ve.minKeyLength)throw new Error(`dek.keyLength must be least ${Ve.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Ve.minSaltLength)throw new Error(`dek.saltLength must be least ${Ve.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Ve.minIterationCount)throw new Error(`dek.iterationCount must be least ${Ve.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Fr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";jr.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[Zo]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},Oo),e=Math.ceil(Ve.minSaltLength/3)*3;return t.dek.salt=W(He(e),"base64"),t}static get options(){return Oo}async findKeyByName(t){if(!cr(t))throw await ft(),new _(`Invalid key name '${t}'`);let e=lr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(W(n))}catch(n){throw await ft(),this.log.error(n),new Zr(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:Do};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(W(n.value));if(s.id===t)return s}throw new _(`Key with id '${t}' does not exist.`)}catch(e){throw await ft(),e}}async importKey(t,e){if(!cr(t)||t==="self")throw await ft(),new _(`Invalid key name '${t}'`);if(e==null)throw await ft(),new _("Key is required");let n=Oe(t);if(await this.components.datastore.has(n))throw await ft(),new _(`Key '${t}' already exists`);let o,i;try{o=await yh(e);let u=jr.get(this);if(u==null)throw new _("dek missing");let l=u.dek;i=await Ho(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(u){throw await ft(),u}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,$(i)),c.put(lr(t),$(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!cr(t))throw await ft(),new _(`Invalid key name '${t}'`);let e=Oe(t);try{let n=await this.components.datastore.get(e),s=W(n),o=jr.get(this);if(o==null)throw new _("dek missing");let i=o.dek;return await Vo(s,i)}catch(n){throw await ft(),n}}async removeKey(t){if(!cr(t)||t==="self")throw await ft(),new _(`Invalid key name '${t}'`);let e=Oe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(lr(t)),await s.commit(),n}async listKeys(){let t={prefix:Do},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(W(n.value)));return e}async renameKey(t,e){if(!cr(t)||t==="self")throw await ft(),new _(`Invalid old key name '${t}'`);if(!cr(e)||e==="self")throw await ft(),new _(`Invalid new key name '${e}'`);let n=Oe(t),s=Oe(e),o=lr(t),i=lr(e);if(await this.components.datastore.has(s))throw await ft(),new _(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),u=await this.components.datastore.get(o),l=JSON.parse(W(u));l.name=e;let f=this.components.datastore.batch();return f.put(s,c),f.put(i,$(JSON.stringify(l))),f.delete(n),f.delete(o),await f.commit(),l}catch(c){throw await ft(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await ft(),new _(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await ft(),new _(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await ft(),new _(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=jr.get(this);if(n==null)throw new _("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Fr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";jr.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Oe(a.name)),u=W(c),l=await Vo(u,s),f=o.toString(),h=await Ho(l,f,l.type==="RSA"?"pkcs-8":"libp2p-key"),w=this.components.datastore.batch(),x={name:a.name,id:a.id};w.put(Oe(a.name),$(h)),w.put(lr(a.name),$(JSON.stringify(x))),await w.commit()}this.log("keychain reconstructed")}};function bh(r={}){return t=>new gs(t,r)}return Wc(wh);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|