@libp2p/keychain 4.0.16 → 4.1.0
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/keychain.d.ts +3 -0
- package/dist/src/keychain.d.ts.map +1 -1
- package/dist/src/keychain.js +5 -1
- package/dist/src/keychain.js.map +1 -1
- package/package.json +6 -6
- package/src/keychain.ts +7 -1
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 Wr=Object.defineProperty;var Yc=Object.getOwnPropertyDescriptor;var Gc=Object.getOwnPropertyNames;var zc=Object.getPrototypeOf,Wc=Object.prototype.hasOwnProperty;var _e=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ct=(r,t)=>{for(var e in t)Wr(r,e,{get:t[e],enumerable:!0})},Yi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Gc(t))!Wc.call(r,s)&&s!==e&&Wr(r,s,{get:()=>t[s],enumerable:!(n=Yc(t,s))||n.enumerable});return r};var bs=(r,t,e)=>(e=r!=null?jc(zc(r)):{},Yi(t||!r||!r.__esModule?Wr(e,"default",{value:r,enumerable:!0}):e,r)),Zc=r=>Yi(Wr({},"__esModule",{value:!0}),r);var sa=_e(cr=>{"use strict";var Bf="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Bf}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 i=0;i<n.length;i++)if(n[i]!==s[i])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 o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},mi="string",Af=/^[0-9a-f]+$/i,Sf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,kf=/^[a-zA-Z0-9-_]+$/,Bn=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=Qt.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},It=class{static toString(t,e=!1){let n=Qt.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},An=class r{static isHex(t){return typeof t===mi&&Af.test(t)}static isBase64(t){return typeof t===mi&&Sf.test(t)}static isBase64Url(t){return typeof t===mi&&kf.test(t)}static ToString(t,e="utf8"){let n=Qt.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 It.toString(n,!0);case"utf16":case"utf16be":return It.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 It.fromString(t,!0);case"utf16":case"utf16be":return It.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Qt.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 Bn.fromString(t);case"utf16":case"utf16be":return It.fromString(t);case"utf16le":case"usc2":return It.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 Bn.toString(t);case"utf16":case"utf16be":return It.toString(t);case"utf16le":case"usc2":return It.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=Qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Qt.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.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 i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return It.toString(t,e)}static FromUtf16String(t,e=!1){return It.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,"")||""}};An.DEFAULT_UTF8_ENCODING="utf8";function If(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function Rf(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function _f(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}cr.BufferSourceConverter=Qt;cr.Convert=An;cr.assign=If;cr.combine=Rf;cr.isEqual=_f});var mc=_e((ny,yc)=>{"use strict";yc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Bc=_e((Ec,vc)=>{"use strict";var ps=mc(),{hasOwnProperty:wc}=Object.prototype,{propertyIsEnumerable:gh}=Object,yr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),yh=Ec,bc={concatArrays:!1,ignoreUndefined:!1},gs=r=>{let t=[];for(let e in r)wc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)gh.call(r,n)&&t.push(n)}return t};function mr(r){return Array.isArray(r)?mh(r):ps(r)?bh(r):r}function mh(r){let t=r.slice(0,0);return gs(r).forEach(e=>{yr(t,e,mr(r[e]))}),t}function bh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return gs(r).forEach(e=>{yr(t,e,mr(r[e]))}),t}var xc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?yr(r,s,Vi(r[s],t[s],n)):yr(r,s,mr(t[s])))}),r),wh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(i=>{let o=[];for(let a=0;a<i.length;a++)wc.call(i,a)&&(o.push(String(a)),i===r?yr(n,s++,i[a]):yr(n,s++,mr(i[a])));n=xc(n,i,gs(i).filter(a=>!o.includes(a)),e)}),n};function Vi(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?wh(r,t,e):!ps(t)||!ps(r)?mr(t):xc(r,t,gs(t),e)}vc.exports=function(...r){let t=Vi(mr(bc),this!==yh&&this||{},bc),e={_:{}};for(let n of r)if(n!==void 0){if(!ps(n))throw new TypeError("`"+n+"` is not an Option Object");e=Vi(e,{_:n},t)}return e._}});var Ic=_e((iy,kc)=>{"use strict";function xh(r){return r>=55296&&r<=56319}function Eh(r){return r>=56320&&r<=57343}kc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,i=0,o,a,c=0;c<s;c+=1){if(o=e.charCodeAt(c),a=e[c],xh(o)&&Eh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),i+=t(a),i===n)return e.slice(0,c+1);if(i>n)return e.slice(0,c-a.length+1)}return e}});var _c=_e((oy,Rc)=>{"use strict";function vh(r){return r>=55296&&r<=56319}function Bh(r){return r>=56320&&r<=57343}Rc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,i=null,o=0;o<e;o++)s=t.charCodeAt(o),Bh(s)?i!=null&&vh(i)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),i=s;return n}});var Tc=_e((ay,Nc)=>{"use strict";var Ah=Ic(),Sh=_c();Nc.exports=Ah.bind(null,Sh)});var Uc=_e((cy,Lc)=>{"use strict";var kh=Tc(),Ih=/[\/\?<>\\:\*\|"]/g,Rh=/[\x00-\x1f\x80-\x9f]/g,_h=/^\.+$/,Nh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Th=/[\. ]+$/;function Cc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Ih,t).replace(Rh,t).replace(_h,t).replace(Nh,t).replace(Th,t);return kh(e,255)}Lc.exports=function(r,t){var e=t&&t.replacement||"",n=Cc(r,e);return e===""?n:Cc(n,"")}});var Uh={};ct(Uh,{keychain:()=>Lh});var mt={get(r=globalThis){let t=r.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var Gi=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 gi={};ct(gi,{Ed25519PrivateKey:()=>He,Ed25519PublicKey:()=>Rr,generateKeyPair:()=>vf,generateKeyPairFromSeed:()=>Qo,unmarshalEd25519PrivateKey:()=>xf,unmarshalEd25519PublicKey:()=>Ef});var Bs={};ct(Bs,{base58btc:()=>bt,base58flickr:()=>rl});var Ph=new Uint8Array(0);function zi(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 jt(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 Wi(r){return new TextEncoder().encode(r)}function Zi(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 i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,g=0,m=0,A=p.length;m!==A&&p[m]===0;)m++,h++;for(var b=(A-m)*l+1>>>0,T=new Uint8Array(b);m!==A;){for(var x=p[m],S=0,_=b-1;(x!==0||S<g)&&_!==-1;_--,S++)x+=256*T[_]>>>0,T[_]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");g=S,m++}for(var N=b-g;N!==b&&T[N]===0;)N++;for(var Y=c.repeat(h);N<b;++N)Y+=r.charAt(T[N]);return Y}function d(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var g=0,m=0;p[h]===c;)g++,h++;for(var A=(p.length-h)*f+1>>>0,b=new Uint8Array(A);p[h];){var T=e[p.charCodeAt(h)];if(T===255)return;for(var x=0,S=A-1;(T!==0||x<m)&&S!==-1;S--,x++)T+=a*b[S]>>>0,b[S]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=x,h++}if(p[h]!==" "){for(var _=A-m;_!==A&&b[_]===0;)_++;for(var N=new Uint8Array(g+(A-_)),Y=g;_!==A;)N[Y++]=b[_++];return N}}}function w(p){var h=d(p);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:w}}var Xc=Jc,Qc=Xc,Xi=Qc;var ws=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")}},xs=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 Qi(this,t)}},Es=class{decoders;constructor(t){this.decoders=t}or(t){return Qi(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 Qi(r,t){return new Es({...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 ws(t,e,n),this.decoder=new xs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function $e({name:r,prefix:t,encode:e,decode:n}){return new vs(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Xi(e,r);return $e({prefix:t,name:r,encode:n,decode:i=>jt(s(i))})}function tl(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,f=0;for(let l=0;l<i;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function el(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function Q({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return el(s,n,e)},decode(s){return tl(s,n,e,r)}})}var bt=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),rl=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ss={};ct(Ss,{identity:()=>le});var nl=ro,to=128,sl=127,il=~sl,ol=Math.pow(2,31);function ro(r,t,e){t=t||[],e=e||0;for(var n=e;r>=ol;)t[e++]=r&255|to,r/=128;for(;r&il;)t[e++]=r&255|to,r>>>=7;return t[e]=r|0,ro.bytes=e-n+1,t}var al=As,cl=128,eo=127;function As(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw As.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&eo)<<s:(o&eo)*Math.pow(2,s),s+=7}while(o>=cl);return As.bytes=i-n,e}var ll=Math.pow(2,7),ul=Math.pow(2,14),fl=Math.pow(2,21),hl=Math.pow(2,28),dl=Math.pow(2,35),pl=Math.pow(2,42),gl=Math.pow(2,49),yl=Math.pow(2,56),ml=Math.pow(2,63),bl=function(r){return r<ll?1:r<ul?2:r<fl?3:r<hl?4:r<dl?5:r<pl?6:r<gl?7:r<yl?8:r<ml?9:10},wl={encode:nl,decode:al,encodingLength:bl},xl=wl,wr=xl;function xr(r,t=0){return[wr.decode(r,t),wr.decode.bytes]}function qe(r,t,e=0){return wr.encode(r,t,e),t}function je(r){return wr.encodingLength(r)}function Dt(r,t){let e=t.byteLength,n=je(r),s=n+je(e),i=new Uint8Array(s+e);return qe(r,i,0),qe(e,i,n),i.set(t,s),new Ye(r,e,t,i)}function Er(r){let t=jt(r),[e,n]=xr(t),[s,i]=xr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Ye(e,s,o,t)}function no(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&zi(r.bytes,e.bytes)}}var Ye=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var so=0,El="identity",io=jt;function vl(r){return Dt(so,io(r))}var le={code:so,name:El,encode:io,digest:vl};var Rs={};ct(Rs,{sha256:()=>ht,sha512:()=>Bl});function Is({name:r,code:t,encode:e}){return new ks(r,t,e)}var ks=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?Dt(this.code,e):e.then(n=>Dt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ao(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ht=Is({name:"sha2-256",code:18,encode:ao("SHA-256")}),Bl=Is({name:"sha2-512",code:19,encode:ao("SHA-512")});function St(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Vt(r=0){return new Uint8Array(r)}function _s(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=Vt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Ns={};ct(Ns,{base10:()=>Al});var Al=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var Ts={};ct(Ts,{base16:()=>Sl,base16upper:()=>kl});var Sl=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),kl=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Cs={};ct(Cs,{base2:()=>Il});var Il=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ls={};ct(Ls,{base256emoji:()=>Cl});var co=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}"),Rl=co.reduce((r,t,e)=>(r[e]=t,r),[]),_l=co.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Nl(r){return r.reduce((t,e)=>(t+=Rl[e],t),"")}function Tl(r){let t=[];for(let e of r){let n=_l[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Cl=$e({prefix:"\u{1F680}",name:"base256emoji",encode:Nl,decode:Tl});var Us={};ct(Us,{base32:()=>ze,base32hex:()=>Vl,base32hexpad:()=>Hl,base32hexpadupper:()=>Pl,base32hexupper:()=>Ol,base32pad:()=>Ul,base32padupper:()=>Dl,base32upper:()=>Ll,base32z:()=>Kl});var ze=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ll=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ul=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Dl=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Vl=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ol=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Hl=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Pl=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Kl=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ds={};ct(Ds,{base36:()=>Ml,base36upper:()=>Fl});var Ml=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Fl=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Vs={};ct(Vs,{base64:()=>Ne,base64pad:()=>$l,base64url:()=>ql,base64urlpad:()=>jl});var Ne=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),$l=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),ql=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),jl=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Os={};ct(Os,{base8:()=>Yl});var Yl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Hs={};ct(Hs,{identity:()=>Gl});var Gl=$e({prefix:"\0",name:"identity",encode:r=>Zi(r),decode:r=>Wi(r)});var dd=new TextEncoder,pd=new TextDecoder;function lo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Jl(e,Ps(r),t??bt.encoder);default:return Xl(e,Ps(r),t??ze.encoder)}}var uo=new WeakMap;function Ps(r){let t=uo.get(r);if(t==null){let e=new Map;return uo.set(r,e),e}return t}var Te=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!==vr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ql)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=Dt(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&&no(t.multihash,n.multihash)}toString(t){return lo(this,t)}toJSON(){return{"/":lo(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:i,bytes:o}=e;return new r(n,s,i,o??fo(n,s,i.bytes))}else if(e[tu]===!0){let{version:n,multihash:s,code:i}=e,o=Er(s);return r.create(n,i,o)}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!==vr)throw new Error(`Version 0 CID must use dag-pb (code: ${vr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=fo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,vr,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=jt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new Ye(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,d]=xr(t.subarray(e));return e+=d,u},s=n(),i=vr;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),f=e+c,l=f-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Zl(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ps(i).set(n,t),i}};function Zl(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 ze.prefix:{let e=t??ze;return[ze.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 Jl(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 i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function Xl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var vr=112,Ql=18;function fo(r,t,e){let n=je(r),s=n+je(t),i=new Uint8Array(s+e.byteLength);return qe(r,i,0),qe(t,i,n),i.set(e,s),i}var tu=Symbol.for("@ipld/js-cid/CID");var We={...Hs,...Cs,...Os,...Ns,...Ts,...Us,...Ds,...Bs,...Vs,...Ls},Nd={...Rs,...Ss};function po(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ho=po("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ks=po("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Vt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),eu={utf8:ho,"utf-8":ho,hex:We.base16,latin1:Ks,ascii:Ks,binary:Ks,...We},Jr=eu;function F(r,t="utf8"){let e=Jr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function kt(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function ru(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Je(r,...t){if(!ru(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 Xr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Ze(r.outputLen),Ze(r.blockLen)}function Xe(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 go(r,t){Je(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Qr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Ce=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),_t=(r,t)=>r<<32-t|r>>>t,tn=(r,t)=>r<<t|r>>>32-t>>>0,qd=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var nu=async()=>{};async function yo(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let i=Date.now()-n;i>=0&&i<t||(await nu(),n+=i)}}function Ms(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ue(r){return typeof r=="string"&&(r=Ms(r)),Je(r),r}function en(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Je(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var Qe=class{clone(){return this._cloneInto()}},su={}.toString;function mo(r,t){if(t!==void 0&&su.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function tr(r){let t=n=>r().update(ue(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function er(r=32){if(Qr&&typeof Qr.getRandomValues=="function")return Qr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function iu(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,f=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+f,a,n)}var rn=(r,t,e)=>r&t^~r&e,nn=(r,t,e)=>r&t^r&e^t&e,fe=class extends Qe{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=Ce(this.buffer)}update(t){Xe(this);let{view:e,buffer:n,blockLen:s}=this;t=ue(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Ce(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Xe(this),go(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;iu(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Ce(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],i)}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:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var sn=BigInt(4294967295),Fs=BigInt(32);function bo(r,t=!1){return t?{h:Number(r&sn),l:Number(r>>Fs&sn)}:{h:Number(r>>Fs&sn)|0,l:Number(r&sn)|0}}function ou(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=bo(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var au=(r,t)=>BigInt(r>>>0)<<Fs|BigInt(t>>>0),cu=(r,t,e)=>r>>>e,lu=(r,t,e)=>r<<32-e|t>>>e,uu=(r,t,e)=>r>>>e|t<<32-e,fu=(r,t,e)=>r<<32-e|t>>>e,hu=(r,t,e)=>r<<64-e|t>>>e-32,du=(r,t,e)=>r>>>e-32|t<<64-e,pu=(r,t)=>t,gu=(r,t)=>r,yu=(r,t,e)=>r<<e|t>>>32-e,mu=(r,t,e)=>t<<e|r>>>32-e,bu=(r,t,e)=>t<<e-32|r>>>64-e,wu=(r,t,e)=>r<<e-32|t>>>64-e;function xu(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Eu=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),vu=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Bu=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Au=(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),ku=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var Iu={fromBig:bo,split:ou,toBig:au,shrSH:cu,shrSL:lu,rotrSH:uu,rotrSL:fu,rotrBH:hu,rotrBL:du,rotr32H:pu,rotr32L:gu,rotlSH:yu,rotlSL:mu,rotlBH:bu,rotlBL:wu,add:xu,add3L:Eu,add3H:vu,add4L:Bu,add4H:Au,add5H:ku,add5L:Su},U=Iu;var[Ru,_u]=U.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))),he=new Uint32Array(80),de=new Uint32Array(80),$s=class extends fe{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:i,Cl:o,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:d,Gh:w,Gl:p,Hh:h,Hl:g}=this;return[t,e,n,s,i,o,a,c,f,l,u,d,w,p,h,g]}set(t,e,n,s,i,o,a,c,f,l,u,d,w,p,h,g){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=d|0,this.Gh=w|0,this.Gl=p|0,this.Hh=h|0,this.Hl=g|0}process(t,e){for(let b=0;b<16;b++,e+=4)he[b]=t.getUint32(e),de[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=he[b-15]|0,x=de[b-15]|0,S=U.rotrSH(T,x,1)^U.rotrSH(T,x,8)^U.shrSH(T,x,7),_=U.rotrSL(T,x,1)^U.rotrSL(T,x,8)^U.shrSL(T,x,7),N=he[b-2]|0,Y=de[b-2]|0,$=U.rotrSH(N,Y,19)^U.rotrBH(N,Y,61)^U.shrSH(N,Y,6),D=U.rotrSL(N,Y,19)^U.rotrBL(N,Y,61)^U.shrSL(N,Y,6),nt=U.add4L(_,D,de[b-7],de[b-16]),et=U.add4H(nt,S,$,he[b-7],he[b-16]);he[b]=et|0,de[b]=nt|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:d,Fh:w,Fl:p,Gh:h,Gl:g,Hh:m,Hl:A}=this;for(let b=0;b<80;b++){let T=U.rotrSH(u,d,14)^U.rotrSH(u,d,18)^U.rotrBH(u,d,41),x=U.rotrSL(u,d,14)^U.rotrSL(u,d,18)^U.rotrBL(u,d,41),S=u&w^~u&h,_=d&p^~d&g,N=U.add5L(A,x,_,_u[b],de[b]),Y=U.add5H(N,m,T,S,Ru[b],he[b]),$=N|0,D=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),nt=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),et=n&i^n&a^i&a,At=s&o^s&c^o&c;m=h|0,A=g|0,h=w|0,g=p|0,w=u|0,p=d|0,{h:u,l:d}=U.add(f|0,l|0,Y|0,$|0),f=a|0,l=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let E=U.add3L($,nt,At);n=U.add3H(E,Y,D,et),s=E|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=U.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=U.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:d}=U.add(this.Eh|0,this.El|0,u|0,d|0),{h:w,l:p}=U.add(this.Fh|0,this.Fl|0,w|0,p|0),{h,l:g}=U.add(this.Gh|0,this.Gl|0,h|0,g|0),{h:m,l:A}=U.add(this.Hh|0,this.Hl|0,m|0,A|0),this.set(n,s,i,o,a,c,f,l,u,d,w,p,h,g,m,A)}roundClean(){he.fill(0),de.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 pe=tr(()=>new $s);var an={};ct(an,{abytes:()=>rr,bitGet:()=>Vu,bitLen:()=>Du,bitMask:()=>Br,bitSet:()=>Ou,bytesToHex:()=>Gt,bytesToNumberBE:()=>zt,bytesToNumberLE:()=>ye,concatBytes:()=>Wt,createHmacDrbg:()=>Ys,ensureBytes:()=>tt,equalBytes:()=>Lu,hexToBytes:()=>Le,hexToNumber:()=>js,isBytes:()=>ge,numberToBytesBE:()=>me,numberToBytesLE:()=>Ue,numberToHexUnpadded:()=>vo,numberToVarBytesBE:()=>Cu,utf8ToBytes:()=>Uu,validateObject:()=>Ot});var Eo=BigInt(0),on=BigInt(1),Nu=BigInt(2);function ge(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function rr(r){if(!ge(r))throw new Error("Uint8Array expected")}var Tu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Gt(r){rr(r);let t="";for(let e=0;e<r.length;e++)t+=Tu[r[e]];return t}function vo(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function js(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Yt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function wo(r){if(r>=Yt._0&&r<=Yt._9)return r-Yt._0;if(r>=Yt._A&&r<=Yt._F)return r-(Yt._A-10);if(r>=Yt._a&&r<=Yt._f)return r-(Yt._a-10)}function Le(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,i=0;s<e;s++,i+=2){let o=wo(r.charCodeAt(i)),a=wo(r.charCodeAt(i+1));if(o===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[s]=o*16+a}return n}function zt(r){return js(Gt(r))}function ye(r){return rr(r),js(Gt(Uint8Array.from(r).reverse()))}function me(r,t){return Le(r.toString(16).padStart(t*2,"0"))}function Ue(r,t){return me(r,t).reverse()}function Cu(r){return Le(vo(r))}function tt(r,t,e){let n;if(typeof t=="string")try{n=Le(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(ge(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 Wt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];rr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function Lu(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 Uu(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Du(r){let t;for(t=0;r>Eo;r>>=on,t+=1);return t}function Vu(r,t){return r>>BigInt(t)&on}function Ou(r,t,e){return r|(e?on:Eo)<<BigInt(t)}var Br=r=>(Nu<<BigInt(r-1))-on,qs=r=>new Uint8Array(r),xo=r=>Uint8Array.from(r);function Ys(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=qs(r),s=qs(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=qs())=>{s=a(xo([0]),u),n=a(),u.length!==0&&(s=a(xo([1]),u),n=a())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let w=n.slice();d.push(w),u+=n.length}return Wt(...d)};return(u,d)=>{o(),c(u);let w;for(;!(w=d(f()));)c();return o(),w}}var Hu={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"||ge(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 Ot(r,t,e={}){let n=(s,i,o)=>{let a=Hu[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${i}`)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var at=BigInt(0),Z=BigInt(1),De=BigInt(2),Pu=BigInt(3),Gs=BigInt(4),Bo=BigInt(5),Ao=BigInt(8),Ku=BigInt(9),Mu=BigInt(16);function G(r,t){let e=r%t;return e>=at?e:t+e}function Fu(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Z)return at;let n=Z;for(;t>at;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function cn(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=G(r,t),n=t,s=at,i=Z,o=Z,a=at;for(;e!==at;){let f=n/e,l=n%e,u=s-o*f,d=i-a*f;n=e,e=l,s=o,i=a,o=u,a=d}if(n!==Z)throw new Error("invert: does not exist");return G(s,t)}function $u(r){let t=(r-Z)/De,e,n,s;for(e=r-Z,n=0;e%De===at;e/=De,n++);for(s=De;s<r&&Fu(s,t,r)!==r-Z;s++);if(n===1){let o=(r+Z)/Gs;return function(c,f){let l=c.pow(f,o);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let i=(e+Z)/De;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(d);w<f&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let p=a.pow(l,Z<<BigInt(f-w-1));l=a.sqr(p),u=a.mul(u,p),d=a.mul(d,l),f=w}return u}}function qu(r){if(r%Gs===Pu){let t=(r+Z)/Gs;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%Ao===Bo){let t=(r-Bo)/Ao;return function(n,s){let i=n.mul(s,De),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,De),o),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Mu,$u(r)}var So=(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 zs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=ju.reduce((n,s)=>(n[s]="function",n),t);return Ot(r,e)}function Yu(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>at;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function Gu(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function Ws(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ln(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Ws(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=qu(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Br(s),ZERO:at,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 at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>Yu(a,c,f),div:(c,f)=>G(c*cn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>cn(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>Gu(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Ue(c,i):me(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return e?ye(c):zt(c)}});return Object.freeze(a)}function ko(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function Io(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 Zs(r){let t=Io(r);return t+Math.ceil(t/2)}function Ro(r,t,e=!1){let n=r.length,s=Io(t),i=Zs(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?zt(r):ye(r),a=G(o,t-Z)+Z;return e?Ue(a,s):me(a,s)}var Wu=BigInt(0),Js=BigInt(1);function un(r,t){let e=(s,i)=>{let o=i.negate();return s?o:i},n=s=>{let i=Math.ceil(t/s)+1,o=2**(s-1);return{windows:i,windowSize:o}};return{constTimeNegate:e,unsafeLadder(s,i){let o=r.ZERO,a=s;for(;i>Wu;)i&Js&&(o=o.add(a)),a=a.double(),i>>=Js;return o},precomputeWindow(s,i){let{windows:o,windowSize:a}=n(i),c=[],f=s,l=f;for(let u=0;u<o;u++){l=f,c.push(l);for(let d=1;d<a;d++)l=l.add(f),c.push(l);f=l.double()}return c},wNAF(s,i,o){let{windows:a,windowSize:c}=n(s),f=r.ZERO,l=r.BASE,u=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let p=0;p<a;p++){let h=p*c,g=Number(o&u);o>>=w,g>c&&(g-=d,o+=Js);let m=h,A=h+Math.abs(g)-1,b=p%2!==0,T=g<0;g===0?l=l.add(e(b,i[m])):f=f.add(e(T,i[A]))}return{p:f,f:l}},wNAFCached(s,i,o,a){let c=s._WINDOW_SIZE||1,f=i.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&i.set(s,a(f))),this.wNAF(c,f,o)}}}function Ar(r){return zs(r.Fp),Ot(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ws(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),vt=BigInt(1),fn=BigInt(2),Zu=BigInt(8),Ju={zip215:!0};function Xu(r){let t=Ar(r);return Ot(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function hn(r){let t=Xu(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,f=fn<<BigInt(a*8)-vt,l=e.create,u=t.uvRatio||((v,y)=>{try{return{isValid:!0,value:e.sqrt(v*e.inv(y))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(v=>v),w=t.domain||((v,y,I)=>{if(y.length||I)throw new Error("Contexts/pre-hash are not supported");return v}),p=v=>typeof v=="bigint"&&Nt<v,h=(v,y)=>p(v)&&p(y)&&v<y,g=v=>v===Nt||h(v,f);function m(v,y){if(h(v,y))return v;throw new Error(`Expected valid scalar < ${y}, got ${typeof v} ${v}`)}function A(v){return v===Nt?v:m(v,n)}let b=new Map;function T(v){if(!(v instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(y,I,C,L){if(this.ex=y,this.ey=I,this.ez=C,this.et=L,!g(y))throw new Error("x required");if(!g(I))throw new Error("y required");if(!g(C))throw new Error("z required");if(!g(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof x)throw new Error("extended point not allowed");let{x:I,y:C}=y||{};if(!g(I)||!g(C))throw new Error("invalid affine point");return new x(I,C,vt,l(I*C))}static normalizeZ(y){let I=e.invertBatch(y.map(C=>C.ez));return y.map((C,L)=>C.toAffine(I[L])).map(x.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:I}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:O,et:H}=this,j=l(C*C),K=l(L*L),q=l(O*O),st=l(q*q),X=l(j*y),ut=l(q*l(X+K)),ft=l(st+l(I*l(j*K)));if(ut!==ft)throw new Error("bad point: equation left != right (1)");let ot=l(C*L),pt=l(O*H);if(ot!==pt)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:I,ey:C,ez:L}=this,{ex:O,ey:H,ez:j}=y,K=l(I*j),q=l(O*L),st=l(C*j),X=l(H*L);return K===q&&st===X}is0(){return this.equals(x.ZERO)}negate(){return new x(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:y}=t,{ex:I,ey:C,ez:L}=this,O=l(I*I),H=l(C*C),j=l(fn*l(L*L)),K=l(y*O),q=I+C,st=l(l(q*q)-O-H),X=K+H,ut=X-j,ft=K-H,ot=l(st*ut),pt=l(X*ft),qt=l(st*ft),Re=l(ut*X);return new x(ot,pt,Re,qt)}add(y){T(y);let{a:I,d:C}=t,{ex:L,ey:O,ez:H,et:j}=this,{ex:K,ey:q,ez:st,et:X}=y;if(I===BigInt(-1)){let Pi=l((O-L)*(q+K)),Ki=l((O+L)*(q-K)),ms=l(Ki-Pi);if(ms===Nt)return this.double();let Mi=l(H*fn*X),Fi=l(j*fn*st),$i=Fi+Mi,qi=Ki+Pi,ji=Fi-Mi,Mc=l($i*ms),Fc=l(qi*ji),$c=l($i*ji),qc=l(ms*qi);return new x(Mc,Fc,qc,$c)}let ut=l(L*K),ft=l(O*q),ot=l(j*C*X),pt=l(H*st),qt=l((L+O)*(K+q)-ut-ft),Re=pt-ot,br=pt+ot,Hi=l(ft-I*ut),Oc=l(qt*Re),Hc=l(br*Hi),Pc=l(qt*Hi),Kc=l(Re*br);return new x(Oc,Hc,Kc,Pc)}subtract(y){return this.add(y.negate())}wNAF(y){return N.wNAFCached(this,b,y,x.normalizeZ)}multiply(y){let{p:I,f:C}=this.wNAF(m(y,n));return x.normalizeZ([I,C])[0]}multiplyUnsafe(y){let I=A(y);return I===Nt?_:this.equals(_)||I===vt?this:this.equals(S)?this.wNAF(I).p:N.unsafeLadder(this,I)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return N.unsafeLadder(this,n).is0()}toAffine(y){let{ex:I,ey:C,ez:L}=this,O=this.is0();y==null&&(y=O?Zu:e.inv(L));let H=l(I*y),j=l(C*y),K=l(L*y);if(O)return{x:Nt,y:vt};if(K!==vt)throw new Error("invZ was invalid");return{x:H,y:j}}clearCofactor(){let{h:y}=t;return y===vt?this:this.multiplyUnsafe(y)}static fromHex(y,I=!1){let{d:C,a:L}=t,O=e.BYTES;y=tt("pointHex",y,O);let H=y.slice(),j=y[O-1];H[O-1]=j&-129;let K=ye(H);K===Nt||(I?m(K,f):m(K,e.ORDER));let q=l(K*K),st=l(q-vt),X=l(C*q-L),{isValid:ut,value:ft}=u(st,X);if(!ut)throw new Error("Point.fromHex: invalid y coordinate");let ot=(ft&vt)===vt,pt=(j&128)!==0;if(!I&&ft===Nt&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==ot&&(ft=l(-ft)),x.fromAffine({x:ft,y:K})}static fromPrivateKey(y){return D(y).point}toRawBytes(){let{x:y,y:I}=this.toAffine(),C=Ue(I,e.BYTES);return C[C.length-1]|=y&vt?128:0,C}toHex(){return Gt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,vt,l(t.Gx*t.Gy)),x.ZERO=new x(Nt,vt,vt,Nt);let{BASE:S,ZERO:_}=x,N=un(x,a*8);function Y(v){return G(v,n)}function $(v){return Y(ye(v))}function D(v){let y=a;v=tt("private key",v,y);let I=tt("hashed private key",i(v),2*y),C=d(I.slice(0,y)),L=I.slice(y,2*y),O=$(C),H=S.multiply(O),j=H.toRawBytes();return{head:C,prefix:L,scalar:O,point:H,pointBytes:j}}function nt(v){return D(v).pointBytes}function et(v=new Uint8Array,...y){let I=Wt(...y);return $(i(w(I,tt("context",v),!!s)))}function At(v,y,I={}){v=tt("message",v),s&&(v=s(v));let{prefix:C,scalar:L,pointBytes:O}=D(y),H=et(I.context,C,v),j=S.multiply(H).toRawBytes(),K=et(I.context,j,O,v),q=Y(H+K*L);A(q);let st=Wt(j,Ue(q,e.BYTES));return tt("result",st,a*2)}let E=Ju;function R(v,y,I,C=E){let{context:L,zip215:O}=C,H=e.BYTES;v=tt("signature",v,2*H),y=tt("message",y),s&&(y=s(y));let j=ye(v.slice(H,2*H)),K,q,st;try{K=x.fromHex(I,O),q=x.fromHex(v.slice(0,H),O),st=S.multiplyUnsafe(j)}catch{return!1}if(!O&&K.isSmallOrder())return!1;let X=et(L,q.toRawBytes(),K.toRawBytes(),y);return q.add(K.multiplyUnsafe(X)).subtract(st).clearCofactor().equals(x.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:nt,sign:At,verify:R,ExtendedPoint:x,utils:{getExtendedPublicKey:D,randomPrivateKey:()=>o(e.BYTES),precompute(v=8,y=x.BASE){return y._setWindowSize(v),y.multiply(BigInt(3)),y}}}}var Qs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),_o=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),h0=BigInt(0),Qu=BigInt(1),Xs=BigInt(2),tf=BigInt(5),No=BigInt(10),ef=BigInt(20),rf=BigInt(40),To=BigInt(80);function nf(r){let t=Qs,n=r*r%t*r%t,s=J(n,Xs,t)*n%t,i=J(s,Qu,t)*r%t,o=J(i,tf,t)*i%t,a=J(o,No,t)*o%t,c=J(a,ef,t)*a%t,f=J(c,rf,t)*c%t,l=J(f,To,t)*f%t,u=J(l,To,t)*f%t,d=J(u,No,t)*o%t;return{pow_p_5_8:J(d,Xs,t)*r%t,b2:n}}function sf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function of(r,t){let e=Qs,n=G(t*t*t,e),s=G(n*n*t,e),i=nf(r*s).pow_p_5_8,o=G(r*n*i,e),a=G(t*o*o,e),c=o,f=G(o*_o,e),l=a===r,u=a===G(-r,e),d=a===G(-r*_o,e);return l&&(o=c),(u||d)&&(o=f),So(o,e)&&(o=G(-o,e)),{isValid:l||u,value:o}}var Zt=ln(Qs,void 0,!0),ti={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:pe,randomBytes:er,adjustScalarBytes:sf,uvRatio:of},nr=hn(ti);function Co(r,t,e){if(t.length>255)throw new Error("Context is too big");return en(Ms("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var d0=hn({...ti,domain:Co}),p0=hn({...ti,domain:Co,prehash:pe});var af=(Zt.ORDER+BigInt(3))/BigInt(8),g0=Zt.pow(Xs,af),y0=Zt.sqrt(Zt.neg(Zt.ONE)),m0=(Zt.ORDER-BigInt(5))/BigInt(8),b0=BigInt(486662);var w0=ko(Zt,Zt.neg(BigInt(486664)));var x0=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),E0=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),v0=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),B0=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var A0=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var sr=32,Jt=64,dn=32;function Lo(){let r=nr.utils.randomPrivateKey(),t=nr.getPublicKey(r);return{privateKey:Oo(r,t),publicKey:t}}function Uo(r){if(r.length!==dn)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=nr.getPublicKey(t);return{privateKey:Oo(t,e),publicKey:e}}function Do(r,t){let e=r.subarray(0,dn);return nr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Vo(r,t,e){return nr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Oo(r,t){let e=new Uint8Array(Jt);for(let n=0;n<dn;n++)e[n]=r[n],e[dn+n]=t[n];return e}var ei={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function pn(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=mt.get();e*=8;async function c(u,d){let w=a.getRandomValues(new Uint8Array(i)),p=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:p};typeof d=="string"&&(d=F(d));let g;if(d.length===0){g=await a.subtle.importKey("jwk",ei,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(A,b,{name:t,length:e},!0,["encrypt"])}catch{g=await a.subtle.importKey("jwk",ei,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(A,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,g,u);return _s([w,h.iv,new Uint8Array(m)])}async function f(u,d){let w=u.subarray(0,i),p=u.subarray(i,i+n),h=u.subarray(i+n),g={name:t,iv:p};typeof d=="string"&&(d=F(d));let m;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",ei,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let A=await a.subtle.decrypt(g,m,h);return new Uint8Array(A)}return{encrypt:c,decrypt:f}}async function ir(r,t){let n=await pn().encrypt(r,t);return Ne.encode(n)}var lf=Math.pow(2,7),uf=Math.pow(2,14),ff=Math.pow(2,21),Po=Math.pow(2,28),Ko=Math.pow(2,35),Mo=Math.pow(2,42),Fo=Math.pow(2,49),wt=128,be=127;function Sr(r){if(r<lf)return 1;if(r<uf)return 2;if(r<ff)return 3;if(r<Po)return 4;if(r<Ko)return 5;if(r<Mo)return 6;if(r<Fo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function $o(r,t,e=0){switch(Sr(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 qo(r,t){let e=r[t],n=0;if(n+=e&be,e<wt||(e=r[t+1],n+=(e&be)<<7,e<wt)||(e=r[t+2],n+=(e&be)<<14,e<wt)||(e=r[t+3],n+=(e&be)<<21,e<wt)||(e=r[t+4],n+=(e&be)*Po,e<wt)||(e=r[t+5],n+=(e&be)*Ko,e<wt)||(e=r[t+6],n+=(e&be)*Mo,e<wt)||(e=r[t+7],n+=(e&be)*Fo,e<wt))return n;throw new RangeError("Could not decode varint")}var ri=new Float32Array([-0]),we=new Uint8Array(ri.buffer);function jo(r,t,e){ri[0]=r,t[e]=we[0],t[e+1]=we[1],t[e+2]=we[2],t[e+3]=we[3]}function Yo(r,t){return we[0]=r[t],we[1]=r[t+1],we[2]=r[t+2],we[3]=r[t+3],ri[0]}var ni=new Float64Array([-0]),gt=new Uint8Array(ni.buffer);function Go(r,t,e){ni[0]=r,t[e]=gt[0],t[e+1]=gt[1],t[e+2]=gt[2],t[e+3]=gt[3],t[e+4]=gt[4],t[e+5]=gt[5],t[e+6]=gt[6],t[e+7]=gt[7]}function zo(r,t){return gt[0]=r[t],gt[1]=r[t+1],gt[2]=r[t+2],gt[3]=r[t+3],gt[4]=r[t+4],gt[5]=r[t+5],gt[6]=r[t+6],gt[7]=r[t+7],ni[0]}var hf=BigInt(Number.MAX_SAFE_INTEGER),df=BigInt(Number.MIN_SAFE_INTEGER),Bt=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 Ve;if(t<hf&&t>df)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>Wo&&(s=0n,++n>Wo&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ve;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):Ve}},Ve=new Bt(0,0);Ve.toBigInt=function(){return 0n};Ve.zzEncode=Ve.zzDecode=function(){return this};Ve.length=function(){return 1};var Wo=4294967296n;function Zo(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 Jo(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(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,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function si(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,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 gn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ii=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 gn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return gn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Yo(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=zo(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 Jo(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 Bt(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=gn(this.buf,this.pos+=4),e=gn(this.buf,this.pos+=4);return new Bt(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=qo(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 oi(r){return new ii(r instanceof Uint8Array?r:r.subarray())}function yn(r,t,e){let n=oi(r);return t.decode(n,void 0,e)}function ai(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return Vt(o);s+o>t&&(n=Vt(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var Oe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ci(){}var ui=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},pf=ai();function gf(r){return globalThis.Buffer!=null?Vt(r):pf(r)}var Ir=class{len;head;tail;states;constructor(){this.len=0,this.head=new Oe(ci,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Oe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new fi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(mn,10,Bt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Bt.fromBigInt(t);return this._push(mn,e.length(),e)}uint64Number(t){return this._push($o,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=Bt.fromBigInt(t).zzEncode();return this._push(mn,e.length(),e)}sint64Number(t){let e=Bt.fromNumber(t).zzEncode();return this._push(mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(li,1,t?1:0)}fixed32(t){return this._push(kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Bt.fromBigInt(t);return this._push(kr,4,e.lo)._push(kr,4,e.hi)}fixed64Number(t){let e=Bt.fromNumber(t);return this._push(kr,4,e.lo)._push(kr,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(jo,4,t)}double(t){return this._push(Go,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(li,1,0):this.uint32(e)._push(mf,e,t)}string(t){let e=Zo(t);return e!==0?this.uint32(e)._push(si,e,t):this._push(li,1,0)}fork(){return this.states=new ui(this),this.head=this.tail=new Oe(ci,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 Oe(ci,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=gf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function li(r,t,e){t[e]=r&255}function yf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var fi=class extends Oe{next;constructor(t,e){super(yf,t,e),this.next=void 0}};function mn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function kr(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&&(Ir.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(bf,t,r),this},Ir.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(wf,t,r),this});function bf(r,t,e){t.set(r,e)}function wf(r,t,e){r.length<40?si(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function hi(){return new Ir}function bn(r,t){let e=hi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var or;(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"})(or||(or={}));function wn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function di(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return wn("enum",or.VARINT,e,n)}function xn(r,t){return wn("message",or.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(rt||(rt={}));var pi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(pi||(pi={}));(function(r){r.codec=()=>di(pi)})(rt||(rt={}));var Xt;(function(r){let t;r.codec=()=>(t==null&&(t=xn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=rt.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>bn(e,r.codec()),r.decode=e=>yn(e,r.codec())})(Xt||(Xt={}));var Ht;(function(r){let t;r.codec=()=>(t==null&&(t=xn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=rt.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>bn(e,r.codec()),r.decode=e=>yn(e,r.codec())})(Ht||(Ht={}));var Rr=class{_key;constructor(t){this._key=ar(t,sr)}verify(t,e){return Vo(this._key,e,t)}marshal(){return this._key}get bytes(){return Xt.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}},He=class{_key;_publicKey;constructor(t,e){this._key=ar(t,Jt),this._publicKey=ar(e,sr)}sign(t){return Do(this._key,t)}get public(){return new Rr(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return kt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=le.digest(this.public.bytes);return bt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return ir(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function xf(r){if(r.length>Jt){r=ar(r,Jt+sr);let n=r.subarray(0,Jt),s=r.subarray(Jt,r.length);return new He(n,s)}r=ar(r,Jt);let t=r.subarray(0,Jt),e=r.subarray(sr);return new He(t,e)}function Ef(r){return r=ar(r,sr),new Rr(r)}async function vf(){let{privateKey:r,publicKey:t}=Lo();return new He(r,t)}async function Qo(r){let{privateKey:t,publicKey:e}=Uo(r);return new He(t,e)}function ar(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 W(r,t="utf8"){let e=Jr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}async function ta(r,t){let e=Ne.decode(r);return pn().decrypt(e,t)}var ki={};ct(ki,{MAX_RSA_KEY_SIZE:()=>Kr,RsaPrivateKey:()=>hr,RsaPublicKey:()=>Pr,fromJwk:()=>Yf,generateKeyPair:()=>Gf,unmarshalRsaPrivateKey:()=>Ai,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 er(r)}var Be={};ct(Be,{exportToPem:()=>Mf,importFromPem:()=>Bi,jwkToPkcs1:()=>Of,jwkToPkix:()=>Pf,pkcs1ToJwk:()=>Vf,pkixToJwk:()=>Hf});var vn=class extends Qe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Xr(t);let n=ue(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,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return Xe(this),this.iHash.update(t),this}digestInto(t){Xe(this),Je(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,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()}},_r=(r,t,e)=>new vn(r,t).update(e).digest();_r.create=(r,t)=>new vn(r,t);function ea(r,t,e,n){Xr(r);let s=mo({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(Ze(i),Ze(o),Ze(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ue(t),f=ue(e),l=new Uint8Array(o),u=_r.create(r,c),d=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:a,DK:l,PRF:u,PRFSalt:d}}function ra(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function na(r,t,e,n){let{c:s,dkLen:i,DK:o,PRF:a,PRFSalt:c}=ea(r,t,e,n),f,l=new Uint8Array(4),u=Ce(l),d=new Uint8Array(a.outputLen);for(let w=1,p=0;p<i;w++,p+=a.outputLen){let h=o.subarray(p,p+a.outputLen);u.setInt32(0,w,!1),(f=c._cloneInto(f)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let g=1;g<s;g++){a._cloneInto(f).update(d).digestInto(d);for(let m=0;m<h.length;m++)h[m]^=d[m]}}return ra(a,c,o,f,d)}async function yi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=ea(r,t,e,n),l,u=new Uint8Array(4),d=Ce(u),w=new Uint8Array(c.outputLen);for(let p=1,h=0;h<i;p++,h+=c.outputLen){let g=a.subarray(h,h+c.outputLen);d.setInt32(0,p,!1),(l=f._cloneInto(l)).update(u).digestInto(w),g.set(w.subarray(0,g.length)),await yo(s-1,o,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<g.length;m++)g[m]^=w[m]})}return ra(c,f,a,l,w)}var P=bs(sa());function Pe(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function xe(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[i-l-1]=Math.floor(s/u),s-=f[i-l-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function Sn(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function bi(){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=Pe(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,Pe(i,8)-n}function ia(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=xe(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function oa(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Et(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var Up=Math.log(2);function kn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function wi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function ne(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 Tr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return wi(this.items)}},Nr=[new Uint8Array([1])],aa="0123456789";var ur="",Lt=new ArrayBuffer(0),xi=new Uint8Array(0),Cr="EndOfContent",la="OCTET STRING",ua="BIT STRING";function se(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?P.BufferSourceConverter.toUint8Array(i.valueHex):xi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ne(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,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",Lt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{constructor({blockLength:t=0,error:e=ur,warnings:n=[],valueBeforeDecode:s=xi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};te.NAME="baseBlock";var yt=class extends te{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'")}};yt.NAME="valueBlock";var In=class extends se(te){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?P.BufferSourceConverter.toUint8Array(t.valueHex):xi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!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",Lt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=xe(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[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=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;i[c]&128;){if(f[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let d=new Uint8Array(l);for(let w=0;w<f.length;w++)d[w]=f[w];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=i[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=f[d];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Pe(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};In.NAME="identificationBlock";var Rn=class extends te{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Pe(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=xe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Lt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];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}}};Rn.NAME="lengthBlock";var k={},dt=class extends te{constructor({name:t=ur,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new In(s),this.lenBlock=new Rn(s),this.valueBlock=i?new i(s):new yt(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 Tr;e||fa(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 i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():P.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return oa(e,n)}};dt.NAME="BaseBlock";function fa(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)fa(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var _n=class extends dt{constructor({value:t=ur,...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}'`}};_n.NAME="BaseStringBlock";var Nn=class extends se(yt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Nn.NAME="PrimitiveValueBlock";var ha,Tn=class extends dt{constructor(t={}){super(t,Nn),this.idBlock.isConstructed=!1}};ha=Tn;k.Primitive=ha;Tn.NAME="PRIMITIVE";function Tf(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 us(r,t=0,e=r.length){let n=t,s=new dt({},yt),i=new te;if(!ne(i,r,t,e))return s.error=i.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 f=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Tf(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 fr(r){if(!r.byteLength){let t=new dt({},yt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return us(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Cf(r,t){return r?1:t}var Kt=class extends yt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(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 i=e;for(;Cf(this.isIndefiniteForm,n)>0;){let o=us(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===Cr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Cr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Tr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Kt.NAME="ConstructedValueBlock";var da,Ee=class extends dt{constructor(t={}){super(t,Kt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
2
|
+
"use strict";var Libp2PKeychain=(()=>{var Yc=Object.create;var Wr=Object.defineProperty;var Gc=Object.getOwnPropertyDescriptor;var zc=Object.getOwnPropertyNames;var Wc=Object.getPrototypeOf,Zc=Object.prototype.hasOwnProperty;var _e=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ct=(r,t)=>{for(var e in t)Wr(r,e,{get:t[e],enumerable:!0})},Yi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of zc(t))!Zc.call(r,s)&&s!==e&&Wr(r,s,{get:()=>t[s],enumerable:!(n=Gc(t,s))||n.enumerable});return r};var bs=(r,t,e)=>(e=r!=null?Yc(Wc(r)):{},Yi(t||!r||!r.__esModule?Wr(e,"default",{value:r,enumerable:!0}):e,r)),Jc=r=>Yi(Wr({},"__esModule",{value:!0}),r);var ia=_e(cr=>{"use strict";var Af="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Af}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 i=0;i<n.length;i++)if(n[i]!==s[i])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 o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},mi="string",Sf=/^[0-9a-f]+$/i,kf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,If=/^[a-zA-Z0-9-_]+$/,Bn=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=Qt.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},It=class{static toString(t,e=!1){let n=Qt.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},An=class r{static isHex(t){return typeof t===mi&&Sf.test(t)}static isBase64(t){return typeof t===mi&&kf.test(t)}static isBase64Url(t){return typeof t===mi&&If.test(t)}static ToString(t,e="utf8"){let n=Qt.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 It.toString(n,!0);case"utf16":case"utf16be":return It.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 It.fromString(t,!0);case"utf16":case"utf16be":return It.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Qt.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 Bn.fromString(t);case"utf16":case"utf16be":return It.fromString(t);case"utf16le":case"usc2":return It.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 Bn.toString(t);case"utf16":case"utf16be":return It.toString(t);case"utf16le":case"usc2":return It.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=Qt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Qt.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.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 i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return It.toString(t,e)}static FromUtf16String(t,e=!1){return It.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,"")||""}};An.DEFAULT_UTF8_ENCODING="utf8";function Rf(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function _f(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function Nf(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}cr.BufferSourceConverter=Qt;cr.Convert=An;cr.assign=Rf;cr.combine=_f;cr.isEqual=Nf});var bc=_e((Ry,mc)=>{"use strict";mc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Ac=_e((vc,Bc)=>{"use strict";var ps=bc(),{hasOwnProperty:xc}=Object.prototype,{propertyIsEnumerable:yh}=Object,yr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),mh=vc,wc={concatArrays:!1,ignoreUndefined:!1},gs=r=>{let t=[];for(let e in r)xc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)yh.call(r,n)&&t.push(n)}return t};function mr(r){return Array.isArray(r)?bh(r):ps(r)?wh(r):r}function bh(r){let t=r.slice(0,0);return gs(r).forEach(e=>{yr(t,e,mr(r[e]))}),t}function wh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return gs(r).forEach(e=>{yr(t,e,mr(r[e]))}),t}var Ec=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?yr(r,s,Vi(r[s],t[s],n)):yr(r,s,mr(t[s])))}),r),xh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(i=>{let o=[];for(let a=0;a<i.length;a++)xc.call(i,a)&&(o.push(String(a)),i===r?yr(n,s++,i[a]):yr(n,s++,mr(i[a])));n=Ec(n,i,gs(i).filter(a=>!o.includes(a)),e)}),n};function Vi(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?xh(r,t,e):!ps(t)||!ps(r)?mr(t):Ec(r,t,gs(t),e)}Bc.exports=function(...r){let t=Vi(mr(wc),this!==mh&&this||{},wc),e={_:{}};for(let n of r)if(n!==void 0){if(!ps(n))throw new TypeError("`"+n+"` is not an Option Object");e=Vi(e,{_:n},t)}return e._}});var Rc=_e((Ny,Ic)=>{"use strict";function Eh(r){return r>=55296&&r<=56319}function vh(r){return r>=56320&&r<=57343}Ic.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,i=0,o,a,c=0;c<s;c+=1){if(o=e.charCodeAt(c),a=e[c],Eh(o)&&vh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),i+=t(a),i===n)return e.slice(0,c+1);if(i>n)return e.slice(0,c-a.length+1)}return e}});var Nc=_e((Ty,_c)=>{"use strict";function Bh(r){return r>=55296&&r<=56319}function Ah(r){return r>=56320&&r<=57343}_c.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,i=null,o=0;o<e;o++)s=t.charCodeAt(o),Ah(s)?i!=null&&Bh(i)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),i=s;return n}});var Cc=_e((Cy,Tc)=>{"use strict";var Sh=Rc(),kh=Nc();Tc.exports=Sh.bind(null,kh)});var Dc=_e((Ly,Uc)=>{"use strict";var Ih=Cc(),Rh=/[\/\?<>\\:\*\|"]/g,_h=/[\x00-\x1f\x80-\x9f]/g,Nh=/^\.+$/,Th=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Ch=/[\. ]+$/;function Lc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Rh,t).replace(_h,t).replace(Nh,t).replace(Th,t).replace(Ch,t);return Ih(e,255)}Uc.exports=function(r,t){var e=t&&t.replacement||"",n=Lc(r,e);return e===""?n:Lc(n,"")}});var Dh={};ct(Dh,{keychain:()=>Uh});var mt={get(r=globalThis){let t=r.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var Gi=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 zi=Symbol.for("@libp2p/service-capabilities"),Kh=Symbol.for("@libp2p/service-dependencies");var gi={};ct(gi,{Ed25519PrivateKey:()=>He,Ed25519PublicKey:()=>Rr,generateKeyPair:()=>Bf,generateKeyPairFromSeed:()=>ta,unmarshalEd25519PrivateKey:()=>Ef,unmarshalEd25519PublicKey:()=>vf});var Bs={};ct(Bs,{base58btc:()=>bt,base58flickr:()=>nl});var ud=new Uint8Array(0);function Wi(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 jt(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 Zi(r){return new TextEncoder().encode(r)}function Ji(r){return new TextDecoder().decode(r)}function Xc(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 i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,g=0,m=0,A=p.length;m!==A&&p[m]===0;)m++,h++;for(var b=(A-m)*l+1>>>0,T=new Uint8Array(b);m!==A;){for(var x=p[m],S=0,_=b-1;(x!==0||S<g)&&_!==-1;_--,S++)x+=256*T[_]>>>0,T[_]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");g=S,m++}for(var N=b-g;N!==b&&T[N]===0;)N++;for(var Y=c.repeat(h);N<b;++N)Y+=r.charAt(T[N]);return Y}function d(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var g=0,m=0;p[h]===c;)g++,h++;for(var A=(p.length-h)*f+1>>>0,b=new Uint8Array(A);p[h];){var T=e[p.charCodeAt(h)];if(T===255)return;for(var x=0,S=A-1;(T!==0||x<m)&&S!==-1;S--,x++)T+=a*b[S]>>>0,b[S]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");m=x,h++}if(p[h]!==" "){for(var _=A-m;_!==A&&b[_]===0;)_++;for(var N=new Uint8Array(g+(A-_)),Y=g;_!==A;)N[Y++]=b[_++];return N}}}function w(p){var h=d(p);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:w}}var Qc=Xc,tl=Qc,Qi=tl;var ws=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")}},xs=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 to(this,t)}},Es=class{decoders;constructor(t){this.decoders=t}or(t){return to(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 to(r,t){return new Es({...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 ws(t,e,n),this.decoder=new xs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function $e({name:r,prefix:t,encode:e,decode:n}){return new vs(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Qi(e,r);return $e({prefix:t,name:r,encode:n,decode:i=>jt(s(i))})}function el(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,f=0;for(let l=0;l<i;++l){let u=s[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[f++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function rl(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function Q({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return rl(s,n,e)},decode(s){return el(s,n,e,r)}})}var bt=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),nl=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ss={};ct(Ss,{identity:()=>le});var sl=no,eo=128,il=127,ol=~il,al=Math.pow(2,31);function no(r,t,e){t=t||[],e=e||0;for(var n=e;r>=al;)t[e++]=r&255|eo,r/=128;for(;r&ol;)t[e++]=r&255|eo,r>>>=7;return t[e]=r|0,no.bytes=e-n+1,t}var cl=As,ll=128,ro=127;function As(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw As.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&ro)<<s:(o&ro)*Math.pow(2,s),s+=7}while(o>=ll);return As.bytes=i-n,e}var ul=Math.pow(2,7),fl=Math.pow(2,14),hl=Math.pow(2,21),dl=Math.pow(2,28),pl=Math.pow(2,35),gl=Math.pow(2,42),yl=Math.pow(2,49),ml=Math.pow(2,56),bl=Math.pow(2,63),wl=function(r){return r<ul?1:r<fl?2:r<hl?3:r<dl?4:r<pl?5:r<gl?6:r<yl?7:r<ml?8:r<bl?9:10},xl={encode:sl,decode:cl,encodingLength:wl},El=xl,wr=El;function xr(r,t=0){return[wr.decode(r,t),wr.decode.bytes]}function qe(r,t,e=0){return wr.encode(r,t,e),t}function je(r){return wr.encodingLength(r)}function Dt(r,t){let e=t.byteLength,n=je(r),s=n+je(e),i=new Uint8Array(s+e);return qe(r,i,0),qe(e,i,n),i.set(t,s),new Ye(r,e,t,i)}function Er(r){let t=jt(r),[e,n]=xr(t),[s,i]=xr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Ye(e,s,o,t)}function so(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wi(r.bytes,e.bytes)}}var Ye=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var io=0,vl="identity",oo=jt;function Bl(r){return Dt(io,oo(r))}var le={code:io,name:vl,encode:oo,digest:Bl};var Rs={};ct(Rs,{sha256:()=>ht,sha512:()=>Al});function Is({name:r,code:t,encode:e}){return new ks(r,t,e)}var ks=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?Dt(this.code,e):e.then(n=>Dt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function co(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ht=Is({name:"sha2-256",code:18,encode:co("SHA-256")}),Al=Is({name:"sha2-512",code:19,encode:co("SHA-512")});function St(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Vt(r=0){return new Uint8Array(r)}function _s(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=Vt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Ns={};ct(Ns,{base10:()=>Sl});var Sl=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var Ts={};ct(Ts,{base16:()=>kl,base16upper:()=>Il});var kl=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Il=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Cs={};ct(Cs,{base2:()=>Rl});var Rl=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ls={};ct(Ls,{base256emoji:()=>Ll});var lo=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}"),_l=lo.reduce((r,t,e)=>(r[e]=t,r),[]),Nl=lo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Tl(r){return r.reduce((t,e)=>(t+=_l[e],t),"")}function Cl(r){let t=[];for(let e of r){let n=Nl[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Ll=$e({prefix:"\u{1F680}",name:"base256emoji",encode:Tl,decode:Cl});var Us={};ct(Us,{base32:()=>ze,base32hex:()=>Ol,base32hexpad:()=>Pl,base32hexpadupper:()=>Kl,base32hexupper:()=>Hl,base32pad:()=>Dl,base32padupper:()=>Vl,base32upper:()=>Ul,base32z:()=>Ml});var ze=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ul=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Dl=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Vl=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ol=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Hl=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Pl=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Kl=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ml=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ds={};ct(Ds,{base36:()=>Fl,base36upper:()=>$l});var Fl=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),$l=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Vs={};ct(Vs,{base64:()=>Ne,base64pad:()=>ql,base64url:()=>jl,base64urlpad:()=>Yl});var Ne=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ql=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),jl=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Yl=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Os={};ct(Os,{base8:()=>Gl});var Gl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Hs={};ct(Hs,{identity:()=>zl});var zl=$e({prefix:"\0",name:"identity",encode:r=>Ji(r),decode:r=>Zi(r)});var Hd=new TextEncoder,Pd=new TextDecoder;function uo(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Xl(e,Ps(r),t??bt.encoder);default:return Ql(e,Ps(r),t??ze.encoder)}}var fo=new WeakMap;function Ps(r){let t=fo.get(r);if(t==null){let e=new Map;return fo.set(r,e),e}return t}var Te=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!==vr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==tu)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=Dt(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&&so(t.multihash,n.multihash)}toString(t){return uo(this,t)}toJSON(){return{"/":uo(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:i,bytes:o}=e;return new r(n,s,i,o??ho(n,s,i.bytes))}else if(e[eu]===!0){let{version:n,multihash:s,code:i}=e,o=Er(s);return r.create(n,i,o)}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!==vr)throw new Error(`Version 0 CID must use dag-pb (code: ${vr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=ho(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,vr,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=jt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new Ye(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,d]=xr(t.subarray(e));return e+=d,u},s=n(),i=vr;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),f=e+c,l=f-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Jl(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ps(i).set(n,t),i}};function Jl(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 ze.prefix:{let e=t??ze;return[ze.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 Xl(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 i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function Ql(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var vr=112,tu=18;function ho(r,t,e){let n=je(r),s=n+je(t),i=new Uint8Array(s+e.byteLength);return qe(r,i,0),qe(t,i,n),i.set(e,s),i}var eu=Symbol.for("@ipld/js-cid/CID");var We={...Hs,...Cs,...Os,...Ns,...Ts,...Us,...Ds,...Bs,...Vs,...Ls},e0={...Rs,...Ss};function go(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var po=go("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ks=go("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Vt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),ru={utf8:po,"utf-8":po,hex:We.base16,latin1:Ks,ascii:Ks,binary:Ks,...We},Jr=ru;function F(r,t="utf8"){let e=Jr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function kt(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function nu(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Je(r,...t){if(!nu(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 Xr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Ze(r.outputLen),Ze(r.blockLen)}function Xe(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 yo(r,t){Je(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Qr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Ce=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),_t=(r,t)=>r<<32-t|r>>>t,tn=(r,t)=>r<<t|r>>>32-t>>>0,g0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var su=async()=>{};async function mo(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let i=Date.now()-n;i>=0&&i<t||(await su(),n+=i)}}function Ms(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ue(r){return typeof r=="string"&&(r=Ms(r)),Je(r),r}function en(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Je(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var Qe=class{clone(){return this._cloneInto()}},iu={}.toString;function bo(r,t){if(t!==void 0&&iu.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function tr(r){let t=n=>r().update(ue(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function er(r=32){if(Qr&&typeof Qr.getRandomValues=="function")return Qr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function ou(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,f=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+f,a,n)}var rn=(r,t,e)=>r&t^~r&e,nn=(r,t,e)=>r&t^r&e^t&e,fe=class extends Qe{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=Ce(this.buffer)}update(t){Xe(this);let{view:e,buffer:n,blockLen:s}=this;t=ue(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Ce(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Xe(this),yo(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;ou(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Ce(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,l=this.get();if(f>l.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<f;u++)a.setUint32(4*u,l[u],i)}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:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var sn=BigInt(4294967295),Fs=BigInt(32);function wo(r,t=!1){return t?{h:Number(r&sn),l:Number(r>>Fs&sn)}:{h:Number(r>>Fs&sn)|0,l:Number(r&sn)|0}}function au(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=wo(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var cu=(r,t)=>BigInt(r>>>0)<<Fs|BigInt(t>>>0),lu=(r,t,e)=>r>>>e,uu=(r,t,e)=>r<<32-e|t>>>e,fu=(r,t,e)=>r>>>e|t<<32-e,hu=(r,t,e)=>r<<32-e|t>>>e,du=(r,t,e)=>r<<64-e|t>>>e-32,pu=(r,t,e)=>r>>>e-32|t<<64-e,gu=(r,t)=>t,yu=(r,t)=>r,mu=(r,t,e)=>r<<e|t>>>32-e,bu=(r,t,e)=>t<<e|r>>>32-e,wu=(r,t,e)=>t<<e-32|r>>>64-e,xu=(r,t,e)=>r<<e-32|t>>>64-e;function Eu(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var vu=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Bu=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Au=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Su=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ku=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Iu=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var Ru={fromBig:wo,split:au,toBig:cu,shrSH:lu,shrSL:uu,rotrSH:fu,rotrSL:hu,rotrBH:du,rotrBL:pu,rotr32H:gu,rotr32L:yu,rotlSH:mu,rotlSL:bu,rotlBH:wu,rotlBL:xu,add:Eu,add3L:vu,add3H:Bu,add4L:Au,add4H:Su,add5H:Iu,add5L:ku},U=Ru;var[_u,Nu]=U.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))),he=new Uint32Array(80),de=new Uint32Array(80),$s=class extends fe{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:i,Cl:o,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:d,Gh:w,Gl:p,Hh:h,Hl:g}=this;return[t,e,n,s,i,o,a,c,f,l,u,d,w,p,h,g]}set(t,e,n,s,i,o,a,c,f,l,u,d,w,p,h,g){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=d|0,this.Gh=w|0,this.Gl=p|0,this.Hh=h|0,this.Hl=g|0}process(t,e){for(let b=0;b<16;b++,e+=4)he[b]=t.getUint32(e),de[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=he[b-15]|0,x=de[b-15]|0,S=U.rotrSH(T,x,1)^U.rotrSH(T,x,8)^U.shrSH(T,x,7),_=U.rotrSL(T,x,1)^U.rotrSL(T,x,8)^U.shrSL(T,x,7),N=he[b-2]|0,Y=de[b-2]|0,$=U.rotrSH(N,Y,19)^U.rotrBH(N,Y,61)^U.shrSH(N,Y,6),D=U.rotrSL(N,Y,19)^U.rotrBL(N,Y,61)^U.shrSL(N,Y,6),nt=U.add4L(_,D,de[b-7],de[b-16]),et=U.add4H(nt,S,$,he[b-7],he[b-16]);he[b]=et|0,de[b]=nt|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:d,Fh:w,Fl:p,Gh:h,Gl:g,Hh:m,Hl:A}=this;for(let b=0;b<80;b++){let T=U.rotrSH(u,d,14)^U.rotrSH(u,d,18)^U.rotrBH(u,d,41),x=U.rotrSL(u,d,14)^U.rotrSL(u,d,18)^U.rotrBL(u,d,41),S=u&w^~u&h,_=d&p^~d&g,N=U.add5L(A,x,_,Nu[b],de[b]),Y=U.add5H(N,m,T,S,_u[b],he[b]),$=N|0,D=U.rotrSH(n,s,28)^U.rotrBH(n,s,34)^U.rotrBH(n,s,39),nt=U.rotrSL(n,s,28)^U.rotrBL(n,s,34)^U.rotrBL(n,s,39),et=n&i^n&a^i&a,At=s&o^s&c^o&c;m=h|0,A=g|0,h=w|0,g=p|0,w=u|0,p=d|0,{h:u,l:d}=U.add(f|0,l|0,Y|0,$|0),f=a|0,l=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let E=U.add3L($,nt,At);n=U.add3H(E,Y,D,et),s=E|0}({h:n,l:s}=U.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=U.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=U.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:d}=U.add(this.Eh|0,this.El|0,u|0,d|0),{h:w,l:p}=U.add(this.Fh|0,this.Fl|0,w|0,p|0),{h,l:g}=U.add(this.Gh|0,this.Gl|0,h|0,g|0),{h:m,l:A}=U.add(this.Hh|0,this.Hl|0,m|0,A|0),this.set(n,s,i,o,a,c,f,l,u,d,w,p,h,g,m,A)}roundClean(){he.fill(0),de.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 pe=tr(()=>new $s);var an={};ct(an,{abytes:()=>rr,bitGet:()=>Ou,bitLen:()=>Vu,bitMask:()=>Br,bitSet:()=>Hu,bytesToHex:()=>Gt,bytesToNumberBE:()=>zt,bytesToNumberLE:()=>ye,concatBytes:()=>Wt,createHmacDrbg:()=>Ys,ensureBytes:()=>tt,equalBytes:()=>Uu,hexToBytes:()=>Le,hexToNumber:()=>js,isBytes:()=>ge,numberToBytesBE:()=>me,numberToBytesLE:()=>Ue,numberToHexUnpadded:()=>Bo,numberToVarBytesBE:()=>Lu,utf8ToBytes:()=>Du,validateObject:()=>Ot});var vo=BigInt(0),on=BigInt(1),Tu=BigInt(2);function ge(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function rr(r){if(!ge(r))throw new Error("Uint8Array expected")}var Cu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Gt(r){rr(r);let t="";for(let e=0;e<r.length;e++)t+=Cu[r[e]];return t}function Bo(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function js(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Yt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function xo(r){if(r>=Yt._0&&r<=Yt._9)return r-Yt._0;if(r>=Yt._A&&r<=Yt._F)return r-(Yt._A-10);if(r>=Yt._a&&r<=Yt._f)return r-(Yt._a-10)}function Le(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,i=0;s<e;s++,i+=2){let o=xo(r.charCodeAt(i)),a=xo(r.charCodeAt(i+1));if(o===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[s]=o*16+a}return n}function zt(r){return js(Gt(r))}function ye(r){return rr(r),js(Gt(Uint8Array.from(r).reverse()))}function me(r,t){return Le(r.toString(16).padStart(t*2,"0"))}function Ue(r,t){return me(r,t).reverse()}function Lu(r){return Le(Bo(r))}function tt(r,t,e){let n;if(typeof t=="string")try{n=Le(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(ge(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 Wt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];rr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function Uu(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))}function Vu(r){let t;for(t=0;r>vo;r>>=on,t+=1);return t}function Ou(r,t){return r>>BigInt(t)&on}function Hu(r,t,e){return r|(e?on:vo)<<BigInt(t)}var Br=r=>(Tu<<BigInt(r-1))-on,qs=r=>new Uint8Array(r),Eo=r=>Uint8Array.from(r);function Ys(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=qs(r),s=qs(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=qs())=>{s=a(Eo([0]),u),n=a(),u.length!==0&&(s=a(Eo([1]),u),n=a())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let w=n.slice();d.push(w),u+=n.length}return Wt(...d)};return(u,d)=>{o(),c(u);let w;for(;!(w=d(f()));)c();return o(),w}}var Pu={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"||ge(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 Ot(r,t,e={}){let n=(s,i,o)=>{let a=Pu[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${i}`)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var at=BigInt(0),Z=BigInt(1),De=BigInt(2),Ku=BigInt(3),Gs=BigInt(4),Ao=BigInt(5),So=BigInt(8),Mu=BigInt(9),Fu=BigInt(16);function G(r,t){let e=r%t;return e>=at?e:t+e}function $u(r,t,e){if(e<=at||t<at)throw new Error("Expected power/modulo > 0");if(e===Z)return at;let n=Z;for(;t>at;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >at;)n*=n,n%=e;return n}function cn(r,t){if(r===at||t<=at)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=G(r,t),n=t,s=at,i=Z,o=Z,a=at;for(;e!==at;){let f=n/e,l=n%e,u=s-o*f,d=i-a*f;n=e,e=l,s=o,i=a,o=u,a=d}if(n!==Z)throw new Error("invert: does not exist");return G(s,t)}function qu(r){let t=(r-Z)/De,e,n,s;for(e=r-Z,n=0;e%De===at;e/=De,n++);for(s=De;s<r&&$u(s,t,r)!==r-Z;s++);if(n===1){let o=(r+Z)/Gs;return function(c,f){let l=c.pow(f,o);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let i=(e+Z)/De;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,l=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let w=1;for(let h=a.sqr(d);w<f&&!a.eql(h,a.ONE);w++)h=a.sqr(h);let p=a.pow(l,Z<<BigInt(f-w-1));l=a.sqr(p),u=a.mul(u,p),d=a.mul(d,l),f=w}return u}}function ju(r){if(r%Gs===Ku){let t=(r+Z)/Gs;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%So===Ao){let t=(r-Ao)/So;return function(n,s){let i=n.mul(s,De),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,De),o),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),s))throw new Error("Cannot find square root");return f}}return r%Fu,qu(r)}var ko=(r,t)=>(G(r,t)&Z)===Z,Yu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function zs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Yu.reduce((n,s)=>(n[s]="function",n),t);return Ot(r,e)}function Gu(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>at;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function zu(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function Ws(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ln(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Ws(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=ju(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Br(s),ZERO:at,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 at<=c&&c<r},is0:c=>c===at,isOdd:c=>(c&Z)===Z,neg:c=>G(-c,r),eql:(c,f)=>c===f,sqr:c=>G(c*c,r),add:(c,f)=>G(c+f,r),sub:(c,f)=>G(c-f,r),mul:(c,f)=>G(c*f,r),pow:(c,f)=>Gu(a,c,f),div:(c,f)=>G(c*cn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>cn(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>zu(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Ue(c,i):me(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return e?ye(c):zt(c)}});return Object.freeze(a)}function Io(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function Ro(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 Zs(r){let t=Ro(r);return t+Math.ceil(t/2)}function _o(r,t,e=!1){let n=r.length,s=Ro(t),i=Zs(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?zt(r):ye(r),a=G(o,t-Z)+Z;return e?Ue(a,s):me(a,s)}var Zu=BigInt(0),Js=BigInt(1);function un(r,t){let e=(s,i)=>{let o=i.negate();return s?o:i},n=s=>{let i=Math.ceil(t/s)+1,o=2**(s-1);return{windows:i,windowSize:o}};return{constTimeNegate:e,unsafeLadder(s,i){let o=r.ZERO,a=s;for(;i>Zu;)i&Js&&(o=o.add(a)),a=a.double(),i>>=Js;return o},precomputeWindow(s,i){let{windows:o,windowSize:a}=n(i),c=[],f=s,l=f;for(let u=0;u<o;u++){l=f,c.push(l);for(let d=1;d<a;d++)l=l.add(f),c.push(l);f=l.double()}return c},wNAF(s,i,o){let{windows:a,windowSize:c}=n(s),f=r.ZERO,l=r.BASE,u=BigInt(2**s-1),d=2**s,w=BigInt(s);for(let p=0;p<a;p++){let h=p*c,g=Number(o&u);o>>=w,g>c&&(g-=d,o+=Js);let m=h,A=h+Math.abs(g)-1,b=p%2!==0,T=g<0;g===0?l=l.add(e(b,i[m])):f=f.add(e(T,i[A]))}return{p:f,f:l}},wNAFCached(s,i,o,a){let c=s._WINDOW_SIZE||1,f=i.get(s);return f||(f=this.precomputeWindow(s,c),c!==1&&i.set(s,a(f))),this.wNAF(c,f,o)}}}function Ar(r){return zs(r.Fp),Ot(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ws(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),vt=BigInt(1),fn=BigInt(2),Ju=BigInt(8),Xu={zip215:!0};function Qu(r){let t=Ar(r);return Ot(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function hn(r){let t=Qu(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,f=fn<<BigInt(a*8)-vt,l=e.create,u=t.uvRatio||((v,y)=>{try{return{isValid:!0,value:e.sqrt(v*e.inv(y))}}catch{return{isValid:!1,value:Nt}}}),d=t.adjustScalarBytes||(v=>v),w=t.domain||((v,y,I)=>{if(y.length||I)throw new Error("Contexts/pre-hash are not supported");return v}),p=v=>typeof v=="bigint"&&Nt<v,h=(v,y)=>p(v)&&p(y)&&v<y,g=v=>v===Nt||h(v,f);function m(v,y){if(h(v,y))return v;throw new Error(`Expected valid scalar < ${y}, got ${typeof v} ${v}`)}function A(v){return v===Nt?v:m(v,n)}let b=new Map;function T(v){if(!(v instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(y,I,C,L){if(this.ex=y,this.ey=I,this.ez=C,this.et=L,!g(y))throw new Error("x required");if(!g(I))throw new Error("y required");if(!g(C))throw new Error("z required");if(!g(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof x)throw new Error("extended point not allowed");let{x:I,y:C}=y||{};if(!g(I)||!g(C))throw new Error("invalid affine point");return new x(I,C,vt,l(I*C))}static normalizeZ(y){let I=e.invertBatch(y.map(C=>C.ez));return y.map((C,L)=>C.toAffine(I[L])).map(x.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,b.delete(this)}assertValidity(){let{a:y,d:I}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:C,ey:L,ez:O,et:H}=this,j=l(C*C),K=l(L*L),q=l(O*O),st=l(q*q),X=l(j*y),ut=l(q*l(X+K)),ft=l(st+l(I*l(j*K)));if(ut!==ft)throw new Error("bad point: equation left != right (1)");let ot=l(C*L),pt=l(O*H);if(ot!==pt)throw new Error("bad point: equation left != right (2)")}equals(y){T(y);let{ex:I,ey:C,ez:L}=this,{ex:O,ey:H,ez:j}=y,K=l(I*j),q=l(O*L),st=l(C*j),X=l(H*L);return K===q&&st===X}is0(){return this.equals(x.ZERO)}negate(){return new x(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:y}=t,{ex:I,ey:C,ez:L}=this,O=l(I*I),H=l(C*C),j=l(fn*l(L*L)),K=l(y*O),q=I+C,st=l(l(q*q)-O-H),X=K+H,ut=X-j,ft=K-H,ot=l(st*ut),pt=l(X*ft),qt=l(st*ft),Re=l(ut*X);return new x(ot,pt,Re,qt)}add(y){T(y);let{a:I,d:C}=t,{ex:L,ey:O,ez:H,et:j}=this,{ex:K,ey:q,ez:st,et:X}=y;if(I===BigInt(-1)){let Pi=l((O-L)*(q+K)),Ki=l((O+L)*(q-K)),ms=l(Ki-Pi);if(ms===Nt)return this.double();let Mi=l(H*fn*X),Fi=l(j*fn*st),$i=Fi+Mi,qi=Ki+Pi,ji=Fi-Mi,Fc=l($i*ms),$c=l(qi*ji),qc=l($i*ji),jc=l(ms*qi);return new x(Fc,$c,jc,qc)}let ut=l(L*K),ft=l(O*q),ot=l(j*C*X),pt=l(H*st),qt=l((L+O)*(K+q)-ut-ft),Re=pt-ot,br=pt+ot,Hi=l(ft-I*ut),Hc=l(qt*Re),Pc=l(br*Hi),Kc=l(qt*Hi),Mc=l(Re*br);return new x(Hc,Pc,Mc,Kc)}subtract(y){return this.add(y.negate())}wNAF(y){return N.wNAFCached(this,b,y,x.normalizeZ)}multiply(y){let{p:I,f:C}=this.wNAF(m(y,n));return x.normalizeZ([I,C])[0]}multiplyUnsafe(y){let I=A(y);return I===Nt?_:this.equals(_)||I===vt?this:this.equals(S)?this.wNAF(I).p:N.unsafeLadder(this,I)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return N.unsafeLadder(this,n).is0()}toAffine(y){let{ex:I,ey:C,ez:L}=this,O=this.is0();y==null&&(y=O?Ju:e.inv(L));let H=l(I*y),j=l(C*y),K=l(L*y);if(O)return{x:Nt,y:vt};if(K!==vt)throw new Error("invZ was invalid");return{x:H,y:j}}clearCofactor(){let{h:y}=t;return y===vt?this:this.multiplyUnsafe(y)}static fromHex(y,I=!1){let{d:C,a:L}=t,O=e.BYTES;y=tt("pointHex",y,O);let H=y.slice(),j=y[O-1];H[O-1]=j&-129;let K=ye(H);K===Nt||(I?m(K,f):m(K,e.ORDER));let q=l(K*K),st=l(q-vt),X=l(C*q-L),{isValid:ut,value:ft}=u(st,X);if(!ut)throw new Error("Point.fromHex: invalid y coordinate");let ot=(ft&vt)===vt,pt=(j&128)!==0;if(!I&&ft===Nt&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==ot&&(ft=l(-ft)),x.fromAffine({x:ft,y:K})}static fromPrivateKey(y){return D(y).point}toRawBytes(){let{x:y,y:I}=this.toAffine(),C=Ue(I,e.BYTES);return C[C.length-1]|=y&vt?128:0,C}toHex(){return Gt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,vt,l(t.Gx*t.Gy)),x.ZERO=new x(Nt,vt,vt,Nt);let{BASE:S,ZERO:_}=x,N=un(x,a*8);function Y(v){return G(v,n)}function $(v){return Y(ye(v))}function D(v){let y=a;v=tt("private key",v,y);let I=tt("hashed private key",i(v),2*y),C=d(I.slice(0,y)),L=I.slice(y,2*y),O=$(C),H=S.multiply(O),j=H.toRawBytes();return{head:C,prefix:L,scalar:O,point:H,pointBytes:j}}function nt(v){return D(v).pointBytes}function et(v=new Uint8Array,...y){let I=Wt(...y);return $(i(w(I,tt("context",v),!!s)))}function At(v,y,I={}){v=tt("message",v),s&&(v=s(v));let{prefix:C,scalar:L,pointBytes:O}=D(y),H=et(I.context,C,v),j=S.multiply(H).toRawBytes(),K=et(I.context,j,O,v),q=Y(H+K*L);A(q);let st=Wt(j,Ue(q,e.BYTES));return tt("result",st,a*2)}let E=Xu;function R(v,y,I,C=E){let{context:L,zip215:O}=C,H=e.BYTES;v=tt("signature",v,2*H),y=tt("message",y),s&&(y=s(y));let j=ye(v.slice(H,2*H)),K,q,st;try{K=x.fromHex(I,O),q=x.fromHex(v.slice(0,H),O),st=S.multiplyUnsafe(j)}catch{return!1}if(!O&&K.isSmallOrder())return!1;let X=et(L,q.toRawBytes(),K.toRawBytes(),y);return q.add(K.multiplyUnsafe(X)).subtract(st).clearCofactor().equals(x.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:nt,sign:At,verify:R,ExtendedPoint:x,utils:{getExtendedPublicKey:D,randomPrivateKey:()=>o(e.BYTES),precompute(v=8,y=x.BASE){return y._setWindowSize(v),y.multiply(BigInt(3)),y}}}}var Qs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),No=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),O0=BigInt(0),tf=BigInt(1),Xs=BigInt(2),ef=BigInt(5),To=BigInt(10),rf=BigInt(20),nf=BigInt(40),Co=BigInt(80);function sf(r){let t=Qs,n=r*r%t*r%t,s=J(n,Xs,t)*n%t,i=J(s,tf,t)*r%t,o=J(i,ef,t)*i%t,a=J(o,To,t)*o%t,c=J(a,rf,t)*a%t,f=J(c,nf,t)*c%t,l=J(f,Co,t)*f%t,u=J(l,Co,t)*f%t,d=J(u,To,t)*o%t;return{pow_p_5_8:J(d,Xs,t)*r%t,b2:n}}function of(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function af(r,t){let e=Qs,n=G(t*t*t,e),s=G(n*n*t,e),i=sf(r*s).pow_p_5_8,o=G(r*n*i,e),a=G(t*o*o,e),c=o,f=G(o*No,e),l=a===r,u=a===G(-r,e),d=a===G(-r*No,e);return l&&(o=c),(u||d)&&(o=f),ko(o,e)&&(o=G(-o,e)),{isValid:l||u,value:o}}var Zt=ln(Qs,void 0,!0),ti={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:pe,randomBytes:er,adjustScalarBytes:of,uvRatio:af},nr=hn(ti);function Lo(r,t,e){if(t.length>255)throw new Error("Context is too big");return en(Ms("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var H0=hn({...ti,domain:Lo}),P0=hn({...ti,domain:Lo,prehash:pe});var cf=(Zt.ORDER+BigInt(3))/BigInt(8),K0=Zt.pow(Xs,cf),M0=Zt.sqrt(Zt.neg(Zt.ONE)),F0=(Zt.ORDER-BigInt(5))/BigInt(8),$0=BigInt(486662);var q0=Io(Zt,Zt.neg(BigInt(486664)));var j0=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Y0=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),G0=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),z0=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var W0=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var sr=32,Jt=64,dn=32;function Uo(){let r=nr.utils.randomPrivateKey(),t=nr.getPublicKey(r);return{privateKey:Ho(r,t),publicKey:t}}function Do(r){if(r.length!==dn)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=nr.getPublicKey(t);return{privateKey:Ho(t,e),publicKey:e}}function Vo(r,t){let e=r.subarray(0,dn);return nr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Oo(r,t,e){return nr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Ho(r,t){let e=new Uint8Array(Jt);for(let n=0;n<dn;n++)e[n]=r[n],e[dn+n]=t[n];return e}var ei={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function pn(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=mt.get();e*=8;async function c(u,d){let w=a.getRandomValues(new Uint8Array(i)),p=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:p};typeof d=="string"&&(d=F(d));let g;if(d.length===0){g=await a.subtle.importKey("jwk",ei,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(A,b,{name:t,length:e},!0,["encrypt"])}catch{g=await a.subtle.importKey("jwk",ei,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},b=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(A,b,{name:t,length:e},!0,["encrypt"])}let m=await a.subtle.encrypt(h,g,u);return _s([w,h.iv,new Uint8Array(m)])}async function f(u,d){let w=u.subarray(0,i),p=u.subarray(i,i+n),h=u.subarray(i+n),g={name:t,iv:p};typeof d=="string"&&(d=F(d));let m;if(d.length===0)try{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}catch{m=await a.subtle.importKey("jwk",ei,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:w,iterations:o,hash:{name:s}},T=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(b,T,{name:t,length:e},!0,["decrypt"])}let A=await a.subtle.decrypt(g,m,h);return new Uint8Array(A)}return{encrypt:c,decrypt:f}}async function ir(r,t){let n=await pn().encrypt(r,t);return Ne.encode(n)}var uf=Math.pow(2,7),ff=Math.pow(2,14),hf=Math.pow(2,21),Ko=Math.pow(2,28),Mo=Math.pow(2,35),Fo=Math.pow(2,42),$o=Math.pow(2,49),wt=128,be=127;function Sr(r){if(r<uf)return 1;if(r<ff)return 2;if(r<hf)return 3;if(r<Ko)return 4;if(r<Mo)return 5;if(r<Fo)return 6;if(r<$o)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function qo(r,t,e=0){switch(Sr(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 jo(r,t){let e=r[t],n=0;if(n+=e&be,e<wt||(e=r[t+1],n+=(e&be)<<7,e<wt)||(e=r[t+2],n+=(e&be)<<14,e<wt)||(e=r[t+3],n+=(e&be)<<21,e<wt)||(e=r[t+4],n+=(e&be)*Ko,e<wt)||(e=r[t+5],n+=(e&be)*Mo,e<wt)||(e=r[t+6],n+=(e&be)*Fo,e<wt)||(e=r[t+7],n+=(e&be)*$o,e<wt))return n;throw new RangeError("Could not decode varint")}var ri=new Float32Array([-0]),we=new Uint8Array(ri.buffer);function Yo(r,t,e){ri[0]=r,t[e]=we[0],t[e+1]=we[1],t[e+2]=we[2],t[e+3]=we[3]}function Go(r,t){return we[0]=r[t],we[1]=r[t+1],we[2]=r[t+2],we[3]=r[t+3],ri[0]}var ni=new Float64Array([-0]),gt=new Uint8Array(ni.buffer);function zo(r,t,e){ni[0]=r,t[e]=gt[0],t[e+1]=gt[1],t[e+2]=gt[2],t[e+3]=gt[3],t[e+4]=gt[4],t[e+5]=gt[5],t[e+6]=gt[6],t[e+7]=gt[7]}function Wo(r,t){return gt[0]=r[t],gt[1]=r[t+1],gt[2]=r[t+2],gt[3]=r[t+3],gt[4]=r[t+4],gt[5]=r[t+5],gt[6]=r[t+6],gt[7]=r[t+7],ni[0]}var df=BigInt(Number.MAX_SAFE_INTEGER),pf=BigInt(Number.MIN_SAFE_INTEGER),Bt=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 Ve;if(t<df&&t>pf)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>Zo&&(s=0n,++n>Zo&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ve;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):Ve}},Ve=new Bt(0,0);Ve.toBigInt=function(){return 0n};Ve.zzEncode=Ve.zzDecode=function(){return this};Ve.length=function(){return 1};var Zo=4294967296n;function Jo(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 Xo(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(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,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function si(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,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 gn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ii=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 gn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return gn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Go(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=Wo(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 Xo(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 Bt(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=gn(this.buf,this.pos+=4),e=gn(this.buf,this.pos+=4);return new Bt(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=jo(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 oi(r){return new ii(r instanceof Uint8Array?r:r.subarray())}function yn(r,t,e){let n=oi(r);return t.decode(n,void 0,e)}function ai(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return Vt(o);s+o>t&&(n=Vt(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var Oe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ci(){}var ui=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},gf=ai();function yf(r){return globalThis.Buffer!=null?Vt(r):gf(r)}var Ir=class{len;head;tail;states;constructor(){this.len=0,this.head=new Oe(ci,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Oe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new fi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(mn,10,Bt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Bt.fromBigInt(t);return this._push(mn,e.length(),e)}uint64Number(t){return this._push(qo,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=Bt.fromBigInt(t).zzEncode();return this._push(mn,e.length(),e)}sint64Number(t){let e=Bt.fromNumber(t).zzEncode();return this._push(mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(li,1,t?1:0)}fixed32(t){return this._push(kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Bt.fromBigInt(t);return this._push(kr,4,e.lo)._push(kr,4,e.hi)}fixed64Number(t){let e=Bt.fromNumber(t);return this._push(kr,4,e.lo)._push(kr,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(Yo,4,t)}double(t){return this._push(zo,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(li,1,0):this.uint32(e)._push(bf,e,t)}string(t){let e=Jo(t);return e!==0?this.uint32(e)._push(si,e,t):this._push(li,1,0)}fork(){return this.states=new ui(this),this.head=this.tail=new Oe(ci,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 Oe(ci,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=yf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function li(r,t,e){t[e]=r&255}function mf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var fi=class extends Oe{next;constructor(t,e){super(mf,t,e),this.next=void 0}};function mn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function kr(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&&(Ir.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(wf,t,r),this},Ir.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(xf,t,r),this});function wf(r,t,e){t.set(r,e)}function xf(r,t,e){r.length<40?si(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function hi(){return new Ir}function bn(r,t){let e=hi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var or;(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"})(or||(or={}));function wn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function di(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return wn("enum",or.VARINT,e,n)}function xn(r,t){return wn("message",or.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(rt||(rt={}));var pi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(pi||(pi={}));(function(r){r.codec=()=>di(pi)})(rt||(rt={}));var Xt;(function(r){let t;r.codec=()=>(t==null&&(t=xn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=rt.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>bn(e,r.codec()),r.decode=e=>yn(e,r.codec())})(Xt||(Xt={}));var Ht;(function(r){let t;r.codec=()=>(t==null&&(t=xn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),rt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let o=e.uint32();switch(o>>>3){case 1:s.Type=rt.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(o&7);break}}return s})),t),r.encode=e=>bn(e,r.codec()),r.decode=e=>yn(e,r.codec())})(Ht||(Ht={}));var Rr=class{_key;constructor(t){this._key=ar(t,sr)}verify(t,e){return Oo(this._key,e,t)}marshal(){return this._key}get bytes(){return Xt.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}},He=class{_key;_publicKey;constructor(t,e){this._key=ar(t,Jt),this._publicKey=ar(e,sr)}sign(t){return Vo(this._key,t)}get public(){return new Rr(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return kt(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=le.digest(this.public.bytes);return bt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return ir(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ef(r){if(r.length>Jt){r=ar(r,Jt+sr);let n=r.subarray(0,Jt),s=r.subarray(Jt,r.length);return new He(n,s)}r=ar(r,Jt);let t=r.subarray(0,Jt),e=r.subarray(sr);return new He(t,e)}function vf(r){return r=ar(r,sr),new Rr(r)}async function Bf(){let{privateKey:r,publicKey:t}=Uo();return new He(r,t)}async function ta(r){let{privateKey:t,publicKey:e}=Do(r);return new He(t,e)}function ar(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 W(r,t="utf8"){let e=Jr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}async function ea(r,t){let e=Ne.decode(r);return pn().decrypt(e,t)}var ki={};ct(ki,{MAX_RSA_KEY_SIZE:()=>Kr,RsaPrivateKey:()=>hr,RsaPublicKey:()=>Pr,fromJwk:()=>Gf,generateKeyPair:()=>zf,unmarshalRsaPrivateKey:()=>Ai,unmarshalRsaPublicKey:()=>Yf});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 er(r)}var Be={};ct(Be,{exportToPem:()=>Ff,importFromPem:()=>Bi,jwkToPkcs1:()=>Hf,jwkToPkix:()=>Kf,pkcs1ToJwk:()=>Of,pkixToJwk:()=>Pf});var vn=class extends Qe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Xr(t);let n=ue(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,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return Xe(this),this.iHash.update(t),this}digestInto(t){Xe(this),Je(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,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()}},_r=(r,t,e)=>new vn(r,t).update(e).digest();_r.create=(r,t)=>new vn(r,t);function ra(r,t,e,n){Xr(r);let s=bo({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(Ze(i),Ze(o),Ze(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ue(t),f=ue(e),l=new Uint8Array(o),u=_r.create(r,c),d=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:a,DK:l,PRF:u,PRFSalt:d}}function na(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function sa(r,t,e,n){let{c:s,dkLen:i,DK:o,PRF:a,PRFSalt:c}=ra(r,t,e,n),f,l=new Uint8Array(4),u=Ce(l),d=new Uint8Array(a.outputLen);for(let w=1,p=0;p<i;w++,p+=a.outputLen){let h=o.subarray(p,p+a.outputLen);u.setInt32(0,w,!1),(f=c._cloneInto(f)).update(l).digestInto(d),h.set(d.subarray(0,h.length));for(let g=1;g<s;g++){a._cloneInto(f).update(d).digestInto(d);for(let m=0;m<h.length;m++)h[m]^=d[m]}}return na(a,c,o,f,d)}async function yi(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=ra(r,t,e,n),l,u=new Uint8Array(4),d=Ce(u),w=new Uint8Array(c.outputLen);for(let p=1,h=0;h<i;p++,h+=c.outputLen){let g=a.subarray(h,h+c.outputLen);d.setInt32(0,p,!1),(l=f._cloneInto(l)).update(u).digestInto(w),g.set(w.subarray(0,g.length)),await mo(s-1,o,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<g.length;m++)g[m]^=w[m]})}return na(c,f,a,l,w)}var P=bs(ia());function Pe(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function xe(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[i-l-1]=Math.floor(s/u),s-=f[i-l-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function Sn(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function bi(){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=Pe(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,Pe(i,8)-n}function oa(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=xe(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=xe(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function aa(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 Et(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var ig=Math.log(2);function kn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function wi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function ne(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 Tr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return wi(this.items)}},Nr=[new Uint8Array([1])],ca="0123456789";var ur="",Lt=new ArrayBuffer(0),xi=new Uint8Array(0),Cr="EndOfContent",ua="OCTET STRING",fa="BIT STRING";function se(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?P.BufferSourceConverter.toUint8Array(i.valueHex):xi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ne(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,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",Lt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:P.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{constructor({blockLength:t=0,error:e=ur,warnings:n=[],valueBeforeDecode:s=xi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=P.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:P.Convert.ToHex(this.valueBeforeDecodeView)}}};te.NAME="baseBlock";var yt=class extends te{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'")}};yt.NAME="valueBlock";var In=class extends se(te){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?P.BufferSourceConverter.toUint8Array(t.valueHex):xi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!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",Lt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=xe(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[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=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;i[c]&128;){if(f[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let d=new Uint8Array(l);for(let w=0;w<f.length;w++)d[w]=f[w];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=i[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=f[d];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Pe(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};In.NAME="identificationBlock";var Rn=class extends te{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Pe(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=xe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Lt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];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}}};Rn.NAME="lengthBlock";var k={},dt=class extends te{constructor({name:t=ur,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new In(s),this.lenBlock=new Rn(s),this.valueBlock=i?new i(s):new yt(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 Tr;e||ha(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 i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():P.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return aa(e,n)}};dt.NAME="BaseBlock";function ha(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)ha(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var _n=class extends dt{constructor({value:t=ur,...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}'`}};_n.NAME="BaseStringBlock";var Nn=class extends se(yt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Nn.NAME="PrimitiveValueBlock";var da,Tn=class extends dt{constructor(t={}){super(t,Nn),this.idBlock.isConstructed=!1}};da=Tn;k.Primitive=da;Tn.NAME="PRIMITIVE";function Cf(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 us(r,t=0,e=r.length){let n=t,s=new dt({},yt),i=new te;if(!ne(i,r,t,e))return s.error=i.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 f=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;f.idBlock=s.idBlock,f.lenBlock=s.lenBlock,f.warnings=s.warnings,s=f}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Cf(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 fr(r){if(!r.byteLength){let t=new dt({},yt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return us(P.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Lf(r,t){return r?1:t}var Kt=class extends yt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(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 i=e;for(;Lf(this.isIndefiniteForm,n)>0;){let o=us(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===Cr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Cr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Tr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Lt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Kt.NAME="ConstructedValueBlock";var pa,Ee=class extends dt{constructor(t={}){super(t,Kt),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} :`}};da=Ee;k.Constructed=da;Ee.NAME="CONSTRUCTED";var Cn=class extends yt{fromBER(t,e,n){return e}toBER(t){return Lt}};Cn.override="EndOfContentValueBlock";var pa,Ln=class extends dt{constructor(t={}){super(t,Cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};pa=Ln;k.EndOfContent=pa;Ln.NAME=Cr;var ga,ve=class extends dt{constructor(t={}){super(t,yt),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}`}};ga=ve;k.Null=ga;ve.NAME="NULL";var Un=class extends se(yt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return ne(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,bi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Un.NAME="BooleanValueBlock";var ya,Dn=class extends dt{constructor(t={}){super(t,Un),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ya=Dn;k.Boolean=ya;Dn.NAME="BOOLEAN";var Vn=class extends se(Kt){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=Kt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Cr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==la)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?Kt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Vn.NAME="OctetStringValueBlock";var ma,ee=class r extends dt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Vn),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 i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=us(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ee.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};ma=ee;k.OctetString=ma;ee.NAME=la;var On=class extends se(Kt){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=Kt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Cr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ua)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let i=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=us(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return Kt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Lt;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}}};On.NAME="BitStringValueBlock";var ba,lr=class extends dt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},On),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 Ee.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)}`}}};ba=lr;k.BitString=ba;lr.NAME=ua;var wa;function Lf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<o?o:c,u=0;for(let d=l;d>=0;d--,u++){switch(!0){case u<a.length:f=i[o-u]+a[c-u]+e[0];break;default:f=i[o-u]+e[0]}switch(e[0]=f/10,!0){case u>=i.length:i=Sn(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=Sn(e,i)),i}function ca(r){if(r>=Nr.length)for(let t=Nr.length;t<=r;t++){let e=new Uint8Array([0]),n=Nr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=Sn(e,n)),Nr.push(n)}return Nr[r]}function Uf(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=i[o-l]-a[c-l]-e,!0){case f<0:e=1,i[o-l]=f+10;break;default:e=0,i[o-l]=f}if(e>0)for(let u=o-c+1;u>=0;u--,l++)if(f=i[o-l]-e,f<0)e=1,i[o-l]=f+10;else{e=0,i[o-l]=f;break}return i.slice()}var Lr=class extends se(yt){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=bi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ia(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}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,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Uf(ca(n),e),o="-";break;default:e=Lf(e,ca(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=aa.charAt(e[c]));return a===!1&&(o+=aa.charAt(0)),o}};wa=Lr;Lr.NAME="IntegerValueBlock";Object.defineProperty(wa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var xa,it=class r extends dt{constructor(t={}){super(t,Lr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return kn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){kn();let e=BigInt(t),n=new Tr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);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()}`}};xa=it;k.Integer=xa;it.NAME="INTEGER";var Ea,Hn=class extends it{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Ea=Hn;k.Enumerated=Ea;Hn.NAME="ENUMERATED";var Ur=class extends se(yt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[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=Pe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){kn();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,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=P.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Ur.NAME="sidBlock";var Pn=class extends yt{constructor({value:t=ur,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Ur;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}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,Lt;e.push(s)}return wi(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.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;o.valueDec=c+a,i=!1}else{let o=new Ur;if(s>Number.MAX_SAFE_INTEGER){kn();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}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}};Pn.NAME="ObjectIdentifierValueBlock";var va,Ct=class extends dt{constructor(t={}){super(t,Pn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};va=Ct;k.ObjectIdentifier=va;Ct.NAME="OBJECT IDENTIFIER";var Dr=class extends se(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[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=Pe(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,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Dr.NAME="relativeSidBlock";var Kn=class extends yt{constructor({value:t=ur,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Dr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,Lt;n.push(i)}return wi(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 i=new Dr;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}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}};Kn.NAME="RelativeObjectIdentifierValueBlock";var Ba,Mn=class extends dt{constructor(t={}){super(t,Kn),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Ba=Mn;k.RelativeObjectIdentifier=Ba;Mn.NAME="RelativeObjectIdentifier";var Aa,lt=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Aa=lt;k.Sequence=Aa;lt.NAME="SEQUENCE";var Sa,Fn=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Sa=Fn;k.Set=Sa;Fn.NAME="SET";var $n=class extends se(yt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=ur}toJSON(){return{...super.toJSON(),value:this.value}}};$n.NAME="StringValueBlock";var qn=class extends $n{};qn.NAME="SimpleStringValueBlock";var xt=class extends _n{constructor({...t}={}){super(t,qn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};xt.NAME="SIMPLE STRING";var jn=class extends xt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};jn.NAME="Utf8StringValueBlock";var ka,re=class extends jn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ka=re;k.Utf8String=ka;re.NAME="UTF8String";var Yn=class extends xt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};Yn.NAME="BmpStringValueBlock";var Ia,Gn=class extends Yn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Ia=Gn;k.BmpString=Ia;Gn.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 i=xe(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};zn.NAME="UniversalStringValueBlock";var Ra,Wn=class extends zn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ra=Wn;k.UniversalString=Ra;Wn.NAME="UniversalString";var _a,Zn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};_a=Zn;k.NumericString=_a;Zn.NAME="NumericString";var Na,Jn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Na=Jn;k.PrintableString=Na;Jn.NAME="PrintableString";var Ta,Xn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ta=Xn;k.TeletexString=Ta;Xn.NAME="TeletexString";var Ca,Qn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ca=Qn;k.VideotexString=Ca;Qn.NAME="VideotexString";var La,ts=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};La=ts;k.IA5String=La;ts.NAME="IA5String";var Ua,es=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ua=es;k.GraphicString=Ua;es.NAME="GraphicString";var Da,Vr=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Da=Vr;k.VisibleString=Da;Vr.NAME="VisibleString";var Va,rs=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Va=rs;k.GeneralString=Va;rs.NAME="GeneralString";var Oa,ns=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Oa=ns;k.CharacterString=Oa;ns.NAME="CharacterString";var Ha,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,P.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Et(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Et(this.month,2),e[2]=Et(this.day,2),e[3]=Et(this.hour,2),e[4]=Et(this.minute,2),e[5]=Et(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}}};Ha=Or;k.UTCTime=Ha;Or.NAME="UTCTime";var Pa,ss=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="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.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 u=1,d=n.indexOf("+"),w="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(w=n.substring(d+1),n=n.substring(0,d),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(w.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*p,w.length===4){if(p=parseInt(w.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=u*p}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=o.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Et(this.year,4)),e.push(Et(this.month,2)),e.push(Et(this.day,2)),e.push(Et(this.hour,2)),e.push(Et(this.minute,2)),e.push(Et(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Et(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Pa=ss;k.GeneralizedTime=Pa;ss.NAME="GeneralizedTime";var Ka,is=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ka=is;k.DATE=Ka;is.NAME="DATE";var Ma,os=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ma=os;k.TimeOfDay=Ma;os.NAME="TimeOfDay";var Fa,as=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Fa=as;k.DateTime=Fa;as.NAME="DateTime";var $a,cs=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};$a=cs;k.Duration=$a;cs.NAME="Duration";var qa,ls=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};qa=ls;k.TIME=qa;ls.NAME="TIME";function Vf(r){let{result:t}=fr(r),e=t.valueBlock.value;return{n:W(Mt(e[1].toBigInt()),"base64url"),e:W(Mt(e[2].toBigInt()),"base64url"),d:W(Mt(e[3].toBigInt()),"base64url"),p:W(Mt(e[4].toBigInt()),"base64url"),q:W(Mt(e[5].toBigInt()),"base64url"),dp:W(Mt(e[6].toBigInt()),"base64url"),dq:W(Mt(e[7].toBigInt()),"base64url"),qi:W(Mt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Of(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 it({value:0}),it.fromBigInt(Ft(F(r.n,"base64url"))),it.fromBigInt(Ft(F(r.e,"base64url"))),it.fromBigInt(Ft(F(r.d,"base64url"))),it.fromBigInt(Ft(F(r.p,"base64url"))),it.fromBigInt(Ft(F(r.q,"base64url"))),it.fromBigInt(Ft(F(r.dp,"base64url"))),it.fromBigInt(Ft(F(r.dq,"base64url"))),it.fromBigInt(Ft(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Hf(r){let{result:t}=fr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:W(Mt(e[0].toBigInt()),"base64url"),e:W(Mt(e[1].toBigInt()),"base64url")}}function Pf(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 Ct({value:"1.2.840.113549.1.1.1"}),new ve]}),new lr({valueHex:new lt({value:[it.fromBigInt(Ft(F(r.n,"base64url"))),it.fromBigInt(Ft(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Mt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,i=0;for(;s<e;)n[s]=parseInt(t.slice(i,i+2),16),s+=1,i+=2;return n}function Ft(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 Kf=16,Ei=32,vi=1e4;async function Mf(r,t){let e=mt.get(),s=new lt({value:[new it({value:0}),new lt({value:[new Ct({value:"1.2.840.113549.1.1.1"}),new ve]}),new ee({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=Pt(Kf),a=await yi(pe,t,o,{c:vi,dkLen:Ei}),c=Pt(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,i),u=new lt({value:[new ee({valueHex:o}),new it({value:vi}),new it({value:Ei}),new lt({value:[new Ct({value:"1.2.840.113549.2.11"}),new ve]})]}),d=new lt({value:[new Ct({value:"1.2.840.113549.1.5.13"}),new lt({value:[new lt({value:[new Ct({value:"1.2.840.113549.1.5.12"}),u]}),new lt({value:[new Ct({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),p=new lt({value:[d,new ee({valueHex:l})]}).toBER(),h=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...W(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function Bi(r,t){let e=mt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=fr(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:l}=Ff(i),u=await yi(pe,t,a,{c,dkLen:f}),d=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=Hr(await e.subtle.decrypt({name:"AES-CBC",iv:o},d,l)),{result:p}=fr(w);n=ja(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=fr(s);n=ja(i)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ai(n)}function Ff(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 i=n.valueBlock.value[1],o=Hr(i.valueBlock.value[0].getValue()),a=vi,c=Ei;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.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 f=t.valueBlock.value[1].valueBlock.value[1],l=f.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 u=Hr(f.valueBlock.value[1].getValue());return{cipherText:Hr(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function ja(r){return Hr(r.valueBlock.value[2].getValue())}function Hr(r){return new Uint8Array(r,0,r.byteLength)}async function Ya(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 Wa(t);return{privateKey:e[0],publicKey:e[1]}}async function Si(r){let e=[await mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await $f(r)],n=await Wa({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ga(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 za(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 Wa(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 $f(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 fs(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 F(r.n,"base64url").length*8}var Kr=8192,Pr=class{_key;constructor(t){this._key=t}verify(t,e){return za(this._key,e,t)}marshal(){return Be.jwkToPkix(this._key)}get bytes(){return Xt.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}},hr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Pt(16)}sign(t){return Ga(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Pr(this._publicKey)}marshal(){return Be.jwkToPkcs1(this._key)}get bytes(){return Ht.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return W(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Be.exportToPem(this,t);if(e==="libp2p-key")return ir(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ai(r){let t=Be.pkcs1ToJwk(r);if(fs(t)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Si(t);return new hr(e.privateKey,e.publicKey)}function jf(r){let t=Be.pkixToJwk(r);if(fs(t)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Pr(t)}async function Yf(r){if(fs(r)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Si(r);return new hr(t.privateKey,t.publicKey)}async function Gf(r){if(r>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ya(r);return new hr(t.privateKey,t.publicKey)}var Ti={};ct(Ti,{Secp256k1PrivateKey:()=>Fr,Secp256k1PublicKey:()=>Mr,generateKeyPair:()=>oh,unmarshalSecp256k1PrivateKey:()=>sh,unmarshalSecp256k1PublicKey:()=>ih});var zf=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]),Ae=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Se=new Uint32Array(64),Ii=class extends fe{constructor(){super(64,32,8,!1),this.A=Ae[0]|0,this.B=Ae[1]|0,this.C=Ae[2]|0,this.D=Ae[3]|0,this.E=Ae[4]|0,this.F=Ae[5]|0,this.G=Ae[6]|0,this.H=Ae[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)Se[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=Se[u-15],w=Se[u-2],p=_t(d,7)^_t(d,18)^d>>>3,h=_t(w,17)^_t(w,19)^w>>>10;Se[u]=h+Se[u-7]+p+Se[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let d=_t(a,6)^_t(a,11)^_t(a,25),w=l+d+rn(a,c,f)+zf[u]+Se[u]|0,h=(_t(n,2)^_t(n,13)^_t(n,22))+nn(n,s,i)|0;l=f,f=c,c=a,a=o+w|0,o=i,i=s,s=n,n=w+h|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,i,o,a,c,f,l)}roundClean(){Se.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var hs=tr(()=>new Ii);function Wf(r){let t=Ar(r);Ot(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:Zf,hexToBytes:Jf}=an,Ke={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Ke;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Zf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Ke,e=typeof r=="string"?Jf(r):r;rr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:i}=Ke._parseInt(e.subarray(2)),{d:o,l:a}=Ke._parseInt(i);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let t=f=>Number.parseInt(f[0],16)&8?"00"+f:f,e=f=>{let l=f.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),i=n.length/2,o=s.length/2,a=e(i),c=e(o);return`30${e(o+i+4)}02${c}${s}02${a}${n}`}},ie=BigInt(0),Rt=BigInt(1),og=BigInt(2),Za=BigInt(3),ag=BigInt(4);function Xf(r){let t=Wf(r),{Fp:e}=t,n=t.toBytes||((p,h,g)=>{let m=h.toAffine();return Wt(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(p=>{let h=p.subarray(1),g=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:g,y:m}});function i(p){let{a:h,b:g}=t,m=e.sqr(p),A=e.mul(m,p);return e.add(e.add(A,e.mul(p,h)),g)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function o(p){return typeof p=="bigint"&&ie<p&&p<t.n}function a(p){if(!o(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:g,wrapPrivateKey:m,n:A}=t;if(h&&typeof p!="bigint"){if(ge(p)&&(p=Gt(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(g*2,"0")}let b;try{b=typeof p=="bigint"?p:zt(tt("private key",p,g))}catch{throw new Error(`private key must be ${g} bytes, hex or bigint, not ${typeof p}`)}return m&&(b=G(b,A)),a(b),b}let f=new Map;function l(p){if(!(p instanceof u))throw new Error("ProjectivePoint expected")}class u{constructor(h,g,m){if(this.px=h,this.py=g,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(g==null||!e.isValid(g))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:g,y:m}=h||{};if(!h||!e.isValid(g)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let A=b=>e.eql(b,e.ZERO);return A(g)&&A(m)?u.ZERO:new u(g,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let g=e.invertBatch(h.map(m=>m.pz));return h.map((m,A)=>m.toAffine(g[A])).map(u.fromAffine)}static fromHex(h){let g=u.fromAffine(s(tt("pointHex",h)));return g.assertValidity(),g}static fromPrivateKey(h){return u.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,f.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:g}=this.toAffine();if(!e.isValid(h)||!e.isValid(g))throw new Error("bad point: x or y not FE");let m=e.sqr(g),A=i(h);if(!e.eql(m,A))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:g,py:m,pz:A}=this,{px:b,py:T,pz:x}=h,S=e.eql(e.mul(g,x),e.mul(b,A)),_=e.eql(e.mul(m,x),e.mul(T,A));return S&&_}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:g}=t,m=e.mul(g,Za),{px:A,py:b,pz:T}=this,x=e.ZERO,S=e.ZERO,_=e.ZERO,N=e.mul(A,A),Y=e.mul(b,b),$=e.mul(T,T),D=e.mul(A,b);return D=e.add(D,D),_=e.mul(A,T),_=e.add(_,_),x=e.mul(h,_),S=e.mul(m,$),S=e.add(x,S),x=e.sub(Y,S),S=e.add(Y,S),S=e.mul(x,S),x=e.mul(D,x),_=e.mul(m,_),$=e.mul(h,$),D=e.sub(N,$),D=e.mul(h,D),D=e.add(D,_),_=e.add(N,N),N=e.add(_,N),N=e.add(N,$),N=e.mul(N,D),S=e.add(S,N),$=e.mul(b,T),$=e.add($,$),N=e.mul($,D),x=e.sub(x,N),_=e.mul($,Y),_=e.add(_,_),_=e.add(_,_),new u(x,S,_)}add(h){l(h);let{px:g,py:m,pz:A}=this,{px:b,py:T,pz:x}=h,S=e.ZERO,_=e.ZERO,N=e.ZERO,Y=t.a,$=e.mul(t.b,Za),D=e.mul(g,b),nt=e.mul(m,T),et=e.mul(A,x),At=e.add(g,m),E=e.add(b,T);At=e.mul(At,E),E=e.add(D,nt),At=e.sub(At,E),E=e.add(g,A);let R=e.add(b,x);return E=e.mul(E,R),R=e.add(D,et),E=e.sub(E,R),R=e.add(m,A),S=e.add(T,x),R=e.mul(R,S),S=e.add(nt,et),R=e.sub(R,S),N=e.mul(Y,E),S=e.mul($,et),N=e.add(S,N),S=e.sub(nt,N),N=e.add(nt,N),_=e.mul(S,N),nt=e.add(D,D),nt=e.add(nt,D),et=e.mul(Y,et),E=e.mul($,E),nt=e.add(nt,et),et=e.sub(D,et),et=e.mul(Y,et),E=e.add(E,et),D=e.mul(nt,E),_=e.add(_,D),D=e.mul(R,E),S=e.mul(At,S),S=e.sub(S,D),D=e.mul(At,nt),N=e.mul(R,N),N=e.add(N,D),new u(S,_,N)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return w.wNAFCached(this,f,h,g=>{let m=e.invertBatch(g.map(A=>A.pz));return g.map((A,b)=>A.toAffine(m[b])).map(u.fromAffine)})}multiplyUnsafe(h){let g=u.ZERO;if(h===ie)return g;if(a(h),h===Rt)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:A,k1:b,k2neg:T,k2:x}=m.splitScalar(h),S=g,_=g,N=this;for(;b>ie||x>ie;)b&Rt&&(S=S.add(N)),x&Rt&&(_=_.add(N)),N=N.double(),b>>=Rt,x>>=Rt;return A&&(S=S.negate()),T&&(_=_.negate()),_=new u(e.mul(_.px,m.beta),_.py,_.pz),S.add(_)}multiply(h){a(h);let g=h,m,A,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:S,k2:_}=b.splitScalar(g),{p:N,f:Y}=this.wNAF(x),{p:$,f:D}=this.wNAF(_);N=w.constTimeNegate(T,N),$=w.constTimeNegate(S,$),$=new u(e.mul($.px,b.beta),$.py,$.pz),m=N.add($),A=Y.add(D)}else{let{p:T,f:x}=this.wNAF(g);m=T,A=x}return u.normalizeZ([m,A])[0]}multiplyAndAddUnsafe(h,g,m){let A=u.BASE,b=(x,S)=>S===ie||S===Rt||!x.equals(A)?x.multiplyUnsafe(S):x.multiply(S),T=b(this,g).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:g,py:m,pz:A}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(A));let T=e.mul(g,h),x=e.mul(m,h),S=e.mul(A,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:g}=t;if(h===Rt)return!0;if(g)return g(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:g}=t;return h===Rt?this:g?g(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(u,this,h)}toHex(h=!0){return Gt(this.toRawBytes(h))}}u.BASE=new u(t.Gx,t.Gy,e.ONE),u.ZERO=new u(e.ZERO,e.ONE,e.ZERO);let d=t.nBitLength,w=un(u,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function Qf(r){let t=Ar(r);return Ot(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ja(r){let t=Qf(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(E){return ie<E&&E<e.ORDER}function a(E){return G(E,n)}function c(E){return cn(E,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:d}=Xf({...t,toBytes(E,R,V){let v=R.toAffine(),y=e.toBytes(v.x),I=Wt;return V?I(Uint8Array.from([R.hasEvenY()?2:3]),y):I(Uint8Array.from([4]),y,e.toBytes(v.y))},fromBytes(E){let R=E.length,V=E[0],v=E.subarray(1);if(R===s&&(V===2||V===3)){let y=zt(v);if(!o(y))throw new Error("Point is not on curve");let I=u(y),C;try{C=e.sqrt(I)}catch(H){let j=H instanceof Error?": "+H.message:"";throw new Error("Point is not on curve"+j)}let L=(C&Rt)===Rt;return(V&1)===1!==L&&(C=e.neg(C)),{x:y,y:C}}else if(R===i&&V===4){let y=e.fromBytes(v.subarray(0,e.BYTES)),I=e.fromBytes(v.subarray(e.BYTES,2*e.BYTES));return{x:y,y:I}}else throw new Error(`Point of length ${R} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),w=E=>Gt(me(E,t.nByteLength));function p(E){let R=n>>Rt;return E>R}function h(E){return p(E)?a(-E):E}let g=(E,R,V)=>zt(E.slice(R,V));class m{constructor(R,V,v){this.r=R,this.s=V,this.recovery=v,this.assertValidity()}static fromCompact(R){let V=t.nByteLength;return R=tt("compactSignature",R,V*2),new m(g(R,0,V),g(R,V,2*V))}static fromDER(R){let{r:V,s:v}=Ke.toSig(tt("DER",R));return new m(V,v)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(R){return new m(this.r,this.s,R)}recoverPublicKey(R){let{r:V,s:v,recovery:y}=this,I=_(tt("msgHash",R));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?V+t.n:V;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=y&1?"03":"02",O=f.fromHex(L+w(C)),H=c(C),j=a(-I*H),K=a(v*H),q=f.BASE.multiplyAndAddUnsafe(O,j,K);if(!q)throw new Error("point at infinify");return q.assertValidity(),q}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Le(this.toDERHex())}toDERHex(){return Ke.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Le(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let A={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=Zs(t.n);return Ro(t.randomBytes(E),t.n)},precompute(E=8,R=f.BASE){return R._setWindowSize(E),R.multiply(BigInt(3)),R}};function b(E,R=!0){return f.fromPrivateKey(E).toRawBytes(R)}function T(E){let R=ge(E),V=typeof E=="string",v=(R||V)&&E.length;return R?v===s||v===i:V?v===2*s||v===2*i:E instanceof f}function x(E,R,V=!0){if(T(E))throw new Error("first arg must be private key");if(!T(R))throw new Error("second arg must be public key");return f.fromHex(R).multiply(l(E)).toRawBytes(V)}let S=t.bits2int||function(E){let R=zt(E),V=E.length*8-t.nBitLength;return V>0?R>>BigInt(V):R},_=t.bits2int_modN||function(E){return a(S(E))},N=Br(t.nBitLength);function Y(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(ie<=E&&E<N))throw new Error(`bigint expected < 2^${t.nBitLength}`);return me(E,t.nByteLength)}function $(E,R,V=D){if(["recovered","canonical"].some(X=>X in V))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:y}=t,{lowS:I,prehash:C,extraEntropy:L}=V;I==null&&(I=!0),E=tt("msgHash",E),C&&(E=tt("prehashed msgHash",v(E)));let O=_(E),H=l(R),j=[Y(H),Y(O)];if(L!=null&&L!==!1){let X=L===!0?y(e.BYTES):L;j.push(tt("extraEntropy",X))}let K=Wt(...j),q=O;function st(X){let ut=S(X);if(!d(ut))return;let ft=c(ut),ot=f.BASE.multiply(ut).toAffine(),pt=a(ot.x);if(pt===ie)return;let qt=a(ft*a(q+pt*H));if(qt===ie)return;let Re=(ot.x===pt?0:2)|Number(ot.y&Rt),br=qt;return I&&p(qt)&&(br=h(qt),Re^=1),new m(pt,br,Re)}return{seed:K,k2sig:st}}let D={lowS:t.lowS,prehash:!1},nt={lowS:t.lowS,prehash:!1};function et(E,R,V=D){let{seed:v,k2sig:y}=$(E,R,V),I=t;return Ys(I.hash.outputLen,I.nByteLength,I.hmac)(v,y)}f.BASE._setWindowSize(8);function At(E,R,V,v=nt){let y=E;if(R=tt("msgHash",R),V=tt("publicKey",V),"strict"in v)throw new Error("options.strict was renamed to lowS");let{lowS:I,prehash:C}=v,L,O;try{if(typeof y=="string"||ge(y))try{L=m.fromDER(y)}catch(ot){if(!(ot instanceof Ke.Err))throw ot;L=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:ot,s:pt}=y;L=new m(ot,pt)}else throw new Error("PARSE");O=f.fromHex(V)}catch(ot){if(ot.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(I&&L.hasHighS())return!1;C&&(R=t.hash(R));let{r:H,s:j}=L,K=_(R),q=c(j),st=a(K*q),X=a(H*q),ut=f.BASE.multiplyAndAddUnsafe(O,st,X)?.toAffine();return ut?a(ut.x)===H:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:x,sign:et,verify:At,ProjectivePoint:f,Signature:m,utils:A}}function th(r){return{hash:r,hmac:(t,...e)=>_r(r,t,en(...e)),randomBytes:er}}function Xa(r,t){let e=n=>Ja({...r,...th(n)});return Object.freeze({...e(t),create:e})}var ec=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Qa=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),eh=BigInt(1),Ri=BigInt(2),tc=(r,t)=>(r+t/Ri)/t;function rh(r){let t=ec,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=J(l,e,t)*l%t,d=J(u,e,t)*l%t,w=J(d,Ri,t)*f%t,p=J(w,s,t)*w%t,h=J(p,i,t)*p%t,g=J(h,a,t)*h%t,m=J(g,c,t)*g%t,A=J(m,a,t)*h%t,b=J(A,e,t)*l%t,T=J(b,o,t)*p%t,x=J(T,n,t)*f%t,S=J(x,Ri,t);if(!_i.eql(_i.sqr(S),r))throw new Error("Cannot find square root");return S}var _i=ln(ec,void 0,void 0,{sqrt:rh}),Ut=Xa({a:BigInt(0),b:BigInt(7),Fp:_i,n:Qa,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Qa,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-eh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=tc(i*r,t),c=tc(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*i,t),u=f>o,d=l>o;if(u&&(f=t-f),d&&(l=t-l),f>o||l>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:d,k2:l}}}},hs),yg=BigInt(0);var mg=Ut.ProjectivePoint;function rc(){return Ut.utils.randomPrivateKey()}function nc(r,t){let e=ht.digest(t instanceof Uint8Array?t:t.subarray());if(kt(e))return e.then(({digest:n})=>Ut.sign(n,r).toDERRawBytes()).catch(n=>{throw new B(String(n),"ERR_INVALID_INPUT")});try{return Ut.sign(e.digest,r).toDERRawBytes()}catch(n){throw new B(String(n),"ERR_INVALID_INPUT")}}function sc(r,t,e){let n=ht.digest(e instanceof Uint8Array?e:e.subarray());if(kt(n))return n.then(({digest:s})=>Ut.verify(t,s,r)).catch(s=>{throw new B(String(s),"ERR_INVALID_INPUT")});try{return Ut.verify(t,n.digest,r)}catch(s){throw new B(String(s),"ERR_INVALID_INPUT")}}function ic(r){return Ut.ProjectivePoint.fromHex(r).toRawBytes(!0)}function oc(r){try{Ut.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Ni(r){try{Ut.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function ac(r){try{return Ut.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Mr=class{_key;constructor(t){Ni(t),this._key=t}verify(t,e){return sc(this._key,e,t)}marshal(){return ic(this._key)}get bytes(){return Xt.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return kt(t)?{bytes:e}=await t:e=t.bytes,e}},Fr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??ac(t),oc(this._key),Ni(this._publicKey)}sign(t){return nc(this._key,t)}get public(){return new Mr(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return W(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return ir(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function sh(r){return new Fr(r)}function ih(r){return new Mr(r)}async function oh(){let r=rc();return new Fr(r)}var $r={rsa:ki,ed25519:gi,secp256k1:Ti};function cc(r){let t=Object.keys($r).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function ah(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return $r[r];throw cc(r)}async function lc(r,t){return ah(r).generateKeyPair(t??2048)}async function Ci(r){let t=Ht.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return $r.rsa.unmarshalRsaPrivateKey(e);case rt.Ed25519:return $r.ed25519.unmarshalEd25519PrivateKey(e);case rt.Secp256k1:return $r.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw cc(t.Type??"RSA")}}async function qr(r,t){try{let e=await ta(r,t);return await Ci(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 Bi(r,t)}var jr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),ke=new Uint32Array(80),Li=class extends fe{constructor(){super(64,20,8,!1),this.A=jr[0]|0,this.B=jr[1]|0,this.C=jr[2]|0,this.D=jr[3]|0,this.E=jr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:i}=this;return[t,e,n,s,i]}set(t,e,n,s,i){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0}process(t,e){for(let c=0;c<16;c++,e+=4)ke[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)ke[c]=tn(ke[c-3]^ke[c-8]^ke[c-14]^ke[c-16],1);let{A:n,B:s,C:i,D:o,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=rn(s,i,o),l=1518500249):c<40?(f=s^i^o,l=1859775393):c<60?(f=nn(s,i,o),l=2400959708):(f=s^i^o,l=3395469782);let u=tn(n,5)+f+a+l+ke[c]|0;a=o,o=i,i=tn(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,this.set(n,s,i,o,a)}roundClean(){ke.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},uc=tr(()=>new Li);var fc={sha1:uc,"sha2-256":hs,"sha2-512":pe};function Yr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(fc).join(" / ");throw new B(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let i=fc[s],o=na(i,r,t,{c:e,dkLen:n});return Ne.encode(o).substring(1)}var ch=Symbol.for("nodejs.util.inspect.custom"),hc=Object.values(We).map(r=>r.decoder).reduce((r,t)=>r.or(t),We.identity.decoder),dc=114,Ui=36,Di=37,Gr=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()})`}[Gi]=!0;toString(){return this.string==null&&(this.string=bt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Te.createV1(dc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return St(this.multihash.bytes,t);if(typeof t=="string")return lh(t).equals(this);if(t?.multihash?.bytes!=null)return St(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[ch](){return`PeerId(${this.toString()})`}},dr=class extends Gr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},pr=class extends Gr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},gr=class extends Gr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function lh(r,t){if(t=t??hc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Er(bt.decode(`z${r}`));return r.startsWith("12D")?new pr({multihash:e}):r.startsWith("16U")?new gr({multihash:e}):new dr({multihash:e})}return uh(hc.decode(r))}function uh(r){try{let t=Er(r);if(t.code===le.code){if(t.digest.length===Ui)return new pr({multihash:t});if(t.digest.length===Di)return new gr({multihash:t})}if(t.code===ht.code)return new dr({multihash:t})}catch{return fh(Te.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function fh(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==dc)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===ht.code)return new dr({multihash:r.multihash});if(t.code===le.code){if(t.digest.length===Ui)return new pr({multihash:r.multihash});if(t.digest.length===Di)return new gr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function pc(r,t){return r.length===Ui?new pr({multihash:Dt(le.code,r),privateKey:t}):r.length===Di?new gr({multihash:Dt(le.code,r),privateKey:t}):new dr({multihash:await ht.digest(r),publicKey:r,privateKey:t})}var oe="/",gc=new TextEncoder().encode(oe),ds=gc[0],zr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=F(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]!==ds)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(oe))}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=gc),this._buf[0]!==ds){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ds,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ds;)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 i=e[s],o=n[s];if(i<o)return!0;if(i>o)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(oe).slice(1)}type(){return hh(this.baseNamespace())}name(){return dh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(oe)||(t+=oe),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(oe):new r(t.slice(0,-1).join(oe))}child(t){return this.toString()===oe?t:t.toString()===oe?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(),...ph(t.map(e=>e.namespaces()))])}};function hh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function dh(r){let t=r.split(":");return t[t.length-1]}function ph(r){return[].concat(...r)}var Ac=bs(Bc(),1),Sc=Ac.default;var Dc=bs(Uc(),1);var M;(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"})(M||(M={}));var Ch="/pkcs8/",Vc="/info/",Me=new WeakMap,Fe={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Oi={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function ae(r){return r==null||typeof r!="string"?!1:r===(0,Dc.default)(r.trim())&&r.length>0}async function z(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function $t(r){return new zr(Ch+r)}function Ie(r){return new zr(Vc+r)}var ys=class{components;init;log;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Sc(Oi,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<Fe.minKeyLength)throw new Error(`dek.keyLength must be least ${Fe.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Fe.minSaltLength)throw new Error(`dek.saltLength must be least ${Fe.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Fe.minIterationCount)throw new Error(`dek.iterationCount must be least ${Fe.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Yr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Me.set(this,{dek:n})}static generateOptions(){let t=Object.assign({},Oi),e=Math.ceil(Fe.minSaltLength/3)*3;return t.dek.salt=W(Pt(e),"base64"),t}static get options(){return Oi}async createKey(t,e,n=2048){if(!ae(t)||t==="self")throw await z(),new B("Invalid key name",M.ERR_INVALID_KEY_NAME);if(typeof e!="string")throw await z(),new B("Invalid key type",M.ERR_INVALID_KEY_TYPE);let s=$t(t);if(await this.components.datastore.has(s))throw await z(),new B("Key name already exists",M.ERR_KEY_ALREADY_EXISTS);switch(e.toLowerCase()){case"rsa":if(!Number.isSafeInteger(n)||n<2048)throw await z(),new B("Invalid RSA key size",M.ERR_INVALID_KEY_SIZE);break;default:break}let o;try{let a=await lc(e,n),c=await a.id(),f=Me.get(this);if(f==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let l=f.dek,u=await a.export(l);o={name:t,id:c};let d=this.components.datastore.batch();d.put(s,F(u)),d.put(Ie(t),F(JSON.stringify(o))),await d.commit()}catch(a){throw await z(),a}return o}async listKeys(){let t={prefix:Vc},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(W(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.`,M.ERR_KEY_NOT_FOUND);return n}catch(e){throw await z(),e}}async findKeyByName(t){if(!ae(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);let e=Ie(t);try{let n=await this.components.datastore.get(e);return JSON.parse(W(n))}catch(n){throw await z(),this.log.error(n),new B(`Key '${t}' does not exist.`,M.ERR_KEY_NOT_FOUND)}}async removeKey(t){if(!ae(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);let e=$t(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(Ie(t)),await s.commit(),n}async renameKey(t,e){if(!ae(t)||t==="self")throw await z(),new B(`Invalid old key name '${t}'`,M.ERR_OLD_KEY_NAME_INVALID);if(!ae(e)||e==="self")throw await z(),new B(`Invalid new key name '${e}'`,M.ERR_NEW_KEY_NAME_INVALID);let n=$t(t),s=$t(e),i=Ie(t),o=Ie(e);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${e}' already exists`,M.ERR_KEY_ALREADY_EXISTS);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(i),l=JSON.parse(W(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(o,F(JSON.stringify(l))),u.delete(n),u.delete(i),await u.commit(),l}catch(c){throw await z(),c}}async exportKey(t,e){if(!ae(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);if(e==null)throw await z(),new B("Password is required",M.ERR_PASSWORD_REQUIRED);let n=$t(t);try{let s=await this.components.datastore.get(n),i=W(s),o=Me.get(this);if(o==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let a=o.dek;return await(await qr(i,a)).export(e)}catch(s){throw await z(),s}}async exportPeerId(t){let e="temporary-password",n=await this.exportKey(t,e),s=await qr(n,e);return pc(s.public.bytes,s.bytes)}async importKey(t,e,n){if(!ae(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);if(e==null)throw await z(),new B("PEM encoded key is required",M.ERR_PEM_REQUIRED);let s=$t(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,M.ERR_KEY_ALREADY_EXISTS);let o;try{o=await qr(e,n)}catch{throw await z(),new B("Cannot read the key, most likely the password is wrong",M.ERR_CANNOT_READ_KEY)}let a;try{a=await o.id();let l=Me.get(this);if(l==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let u=l.dek;e=await o.export(u)}catch(l){throw await z(),l}let c={name:t,id:a},f=this.components.datastore.batch();return f.put(s,F(e)),f.put(Ie(t),F(JSON.stringify(c))),await f.commit(),c}async importPeer(t,e){try{if(!ae(t))throw new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);if(e==null)throw new B("PeerId is required",M.ERR_MISSING_PRIVATE_KEY);if(e.privateKey==null)throw new B("PeerId.privKey is required",M.ERR_MISSING_PRIVATE_KEY);let n=await Ci(e.privateKey),s=$t(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,M.ERR_KEY_ALREADY_EXISTS);let o=Me.get(this);if(o==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let a=o.dek,c=await n.export(a),f={name:t,id:e.toString()},l=this.components.datastore.batch();return l.put(s,F(c)),l.put(Ie(t),F(JSON.stringify(f))),await l.commit(),f}catch(n){throw await z(),n}}async getPrivateKey(t){if(!ae(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);try{let e=$t(t),n=await this.components.datastore.get(e);return W(n)}catch(e){throw await z(),this.log.error(e),new B(`Key '${t}' does not exist.`,M.ERR_KEY_NOT_FOUND)}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await z(),new B(`Invalid old pass type '${typeof t}'`,M.ERR_INVALID_OLD_PASS_TYPE);if(typeof e!="string")throw await z(),new B(`Invalid new pass type '${typeof e}'`,M.ERR_INVALID_NEW_PASS_TYPE);if(e.length<20)throw await z(),new B(`Invalid pass length ${e.length}`,M.ERR_INVALID_PASS_LENGTH);this.log("recreating keychain");let n=Me.get(this);if(n==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let s=n.dek;this.init.pass=e;let i=e!=null&&this.init.dek?.salt!=null?Yr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Me.set(this,{dek:i});let o=await this.listKeys();for(let a of o){let c=await this.components.datastore.get($t(a.name)),f=W(c),l=await qr(f,s),u=i.toString(),d=await l.export(u),w=this.components.datastore.batch(),p={name:a.name,id:a.id};w.put($t(a.name),F(d)),w.put(Ie(a.name),F(JSON.stringify(p))),await w.commit()}this.log("keychain reconstructed")}};function Lh(r={}){return t=>new ys(t,r)}return Zc(Uh);})();
|
|
6
|
+
`)}`:`${e} :`}};pa=Ee;k.Constructed=pa;Ee.NAME="CONSTRUCTED";var Cn=class extends yt{fromBER(t,e,n){return e}toBER(t){return Lt}};Cn.override="EndOfContentValueBlock";var ga,Ln=class extends dt{constructor(t={}){super(t,Cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ga=Ln;k.EndOfContent=ga;Ln.NAME=Cr;var ya,ve=class extends dt{constructor(t={}){super(t,yt),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}`}};ya=ve;k.Null=ya;ve.NAME="NULL";var Un=class extends se(yt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=P.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=P.BufferSourceConverter.toUint8Array(t);return ne(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,bi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Un.NAME="BooleanValueBlock";var ma,Dn=class extends dt{constructor(t={}){super(t,Un),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ma=Dn;k.Boolean=ma;Dn.NAME="BOOLEAN";var Vn=class extends se(Kt){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=Kt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Cr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==ua)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?Kt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Vn.NAME="OctetStringValueBlock";var ba,ee=class r extends dt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Vn),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 i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=us(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ee.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${P.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return P.BufferSourceConverter.concat(t)}};ba=ee;k.OctetString=ba;ee.NAME=ua;var On=class extends se(Kt){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=Kt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Cr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==fa)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return s}let i=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=us(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return Kt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Lt;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}}};On.NAME="BitStringValueBlock";var wa,lr=class extends dt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},On),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 Ee.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)}`}}};wa=lr;k.BitString=wa;lr.NAME=fa;var xa;function Uf(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<o?o:c,u=0;for(let d=l;d>=0;d--,u++){switch(!0){case u<a.length:f=i[o-u]+a[c-u]+e[0];break;default:f=i[o-u]+e[0]}switch(e[0]=f/10,!0){case u>=i.length:i=Sn(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=Sn(e,i)),i}function la(r){if(r>=Nr.length)for(let t=Nr.length;t<=r;t++){let e=new Uint8Array([0]),n=Nr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=Sn(e,n)),Nr.push(n)}return Nr[r]}function Df(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=i[o-l]-a[c-l]-e,!0){case f<0:e=1,i[o-l]=f+10;break;default:e=0,i[o-l]=f}if(e>0)for(let u=o-c+1;u>=0;u--,l++)if(f=i[o-l]-e,f<0)e=1,i[o-l]=f+10;else{e=0,i[o-l]=f;break}return i.slice()}var Lr=class extends se(yt){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=bi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(oa(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}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,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Df(la(n),e),o="-";break;default:e=Uf(e,la(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=ca.charAt(e[c]));return a===!1&&(o+=ca.charAt(0)),o}};xa=Lr;Lr.NAME="IntegerValueBlock";Object.defineProperty(xa.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Ea,it=class r extends dt{constructor(t={}){super(t,Lr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return kn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){kn();let e=BigInt(t),n=new Tr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(P.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${P.Convert.ToHex(a)}`)+e,l=P.BufferSourceConverter.toUint8Array(P.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);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()}`}};Ea=it;k.Integer=Ea;it.NAME="INTEGER";var va,Hn=class extends it{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};va=Hn;k.Enumerated=va;Hn.NAME="ENUMERATED";var Ur=class extends se(yt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[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=Pe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){kn();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,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=P.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Ur.NAME="sidBlock";var Pn=class extends yt{constructor({value:t=ur,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Ur;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}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,Lt;e.push(s)}return wi(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.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;o.valueDec=c+a,i=!1}else{let o=new Ur;if(s>Number.MAX_SAFE_INTEGER){kn();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}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}};Pn.NAME="ObjectIdentifierValueBlock";var Ba,Ct=class extends dt{constructor(t={}){super(t,Pn),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()}}};Ba=Ct;k.ObjectIdentifier=Ba;Ct.NAME="OBJECT IDENTIFIER";var Dr=class extends se(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=P.BufferSourceConverter.toUint8Array(t);if(!ne(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[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=Pe(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,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=xe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Lt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=P.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Dr.NAME="relativeSidBlock";var Kn=class extends yt{constructor({value:t=ur,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Dr;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,Lt;n.push(i)}return wi(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 i=new Dr;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}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}};Kn.NAME="RelativeObjectIdentifierValueBlock";var Aa,Mn=class extends dt{constructor(t={}){super(t,Kn),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()}}};Aa=Mn;k.RelativeObjectIdentifier=Aa;Mn.NAME="RelativeObjectIdentifier";var Sa,lt=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Sa=lt;k.Sequence=Sa;lt.NAME="SEQUENCE";var ka,Fn=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ka=Fn;k.Set=ka;Fn.NAME="SET";var $n=class extends se(yt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=ur}toJSON(){return{...super.toJSON(),value:this.value}}};$n.NAME="StringValueBlock";var qn=class extends $n{};qn.NAME="SimpleStringValueBlock";var xt=class extends _n{constructor({...t}={}){super(t,qn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,P.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};xt.NAME="SIMPLE STRING";var jn=class extends xt{fromBuffer(t){this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=P.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=P.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf8String(t)),this.valueBlock.value=t}};jn.NAME="Utf8StringValueBlock";var Ia,re=class extends jn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Ia=re;k.Utf8String=Ia;re.NAME="UTF8String";var Yn=class extends xt{fromBuffer(t){this.valueBlock.value=P.Convert.ToUtf16String(t),this.valueBlock.valueHexView=P.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(P.Convert.FromUtf16String(t))}};Yn.NAME="BmpStringValueBlock";var Ra,Gn=class extends Yn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Ra=Gn;k.BmpString=Ra;Gn.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 i=xe(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};zn.NAME="UniversalStringValueBlock";var _a,Wn=class extends zn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};_a=Wn;k.UniversalString=_a;Wn.NAME="UniversalString";var Na,Zn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Na=Zn;k.NumericString=Na;Zn.NAME="NumericString";var Ta,Jn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ta=Jn;k.PrintableString=Ta;Jn.NAME="PrintableString";var Ca,Xn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ca=Xn;k.TeletexString=Ca;Xn.NAME="TeletexString";var La,Qn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};La=Qn;k.VideotexString=La;Qn.NAME="VideotexString";var Ua,ts=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ua=ts;k.IA5String=Ua;ts.NAME="IA5String";var Da,es=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Da=es;k.GraphicString=Da;es.NAME="GraphicString";var Va,Vr=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Va=Vr;k.VisibleString=Va;Vr.NAME="VisibleString";var Oa,rs=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Oa=rs;k.GeneralString=Oa;rs.NAME="GeneralString";var Ha,ns=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ha=ns;k.CharacterString=Ha;ns.NAME="CharacterString";var Pa,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,P.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Et(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Et(this.month,2),e[2]=Et(this.day,2),e[3]=Et(this.hour,2),e[4]=Et(this.minute,2),e[5]=Et(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Pa=Or;k.UTCTime=Pa;Or.NAME="UTCTime";var Ka,ss=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="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.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 u=1,d=n.indexOf("+"),w="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(w=n.substring(d+1),n=n.substring(0,d),w.length!==2&&w.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(w.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*p,w.length===4){if(p=parseInt(w.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=u*p}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let u=new Number(`0${n.substring(f)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=o.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let u=1;u<l.length;u++)switch(u){case 1:this.year=parseInt(l[u],10);break;case 2:this.month=parseInt(l[u],10);break;case 3:this.day=parseInt(l[u],10);break;case 4:this.hour=parseInt(l[u],10)+a;break;case 5:this.minute=parseInt(l[u],10)+c;break;case 6:this.second=parseInt(l[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Et(this.year,4)),e.push(Et(this.month,2)),e.push(Et(this.day,2)),e.push(Et(this.hour,2)),e.push(Et(this.minute,2)),e.push(Et(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Et(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ka=ss;k.GeneralizedTime=Ka;ss.NAME="GeneralizedTime";var Ma,is=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ma=is;k.DATE=Ma;is.NAME="DATE";var Fa,os=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Fa=os;k.TimeOfDay=Fa;os.NAME="TimeOfDay";var $a,as=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};$a=as;k.DateTime=$a;as.NAME="DateTime";var qa,cs=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};qa=cs;k.Duration=qa;cs.NAME="Duration";var ja,ls=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};ja=ls;k.TIME=ja;ls.NAME="TIME";function Of(r){let{result:t}=fr(r),e=t.valueBlock.value;return{n:W(Mt(e[1].toBigInt()),"base64url"),e:W(Mt(e[2].toBigInt()),"base64url"),d:W(Mt(e[3].toBigInt()),"base64url"),p:W(Mt(e[4].toBigInt()),"base64url"),q:W(Mt(e[5].toBigInt()),"base64url"),dp:W(Mt(e[6].toBigInt()),"base64url"),dq:W(Mt(e[7].toBigInt()),"base64url"),qi:W(Mt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Hf(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 it({value:0}),it.fromBigInt(Ft(F(r.n,"base64url"))),it.fromBigInt(Ft(F(r.e,"base64url"))),it.fromBigInt(Ft(F(r.d,"base64url"))),it.fromBigInt(Ft(F(r.p,"base64url"))),it.fromBigInt(Ft(F(r.q,"base64url"))),it.fromBigInt(Ft(F(r.dp,"base64url"))),it.fromBigInt(Ft(F(r.dq,"base64url"))),it.fromBigInt(Ft(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Pf(r){let{result:t}=fr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:W(Mt(e[0].toBigInt()),"base64url"),e:W(Mt(e[1].toBigInt()),"base64url")}}function Kf(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 Ct({value:"1.2.840.113549.1.1.1"}),new ve]}),new lr({valueHex:new lt({value:[it.fromBigInt(Ft(F(r.n,"base64url"))),it.fromBigInt(Ft(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Mt(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,i=0;for(;s<e;)n[s]=parseInt(t.slice(i,i+2),16),s+=1,i+=2;return n}function Ft(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 Mf=16,Ei=32,vi=1e4;async function Ff(r,t){let e=mt.get(),s=new lt({value:[new it({value:0}),new lt({value:[new Ct({value:"1.2.840.113549.1.1.1"}),new ve]}),new ee({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=Pt(Mf),a=await yi(pe,t,o,{c:vi,dkLen:Ei}),c=Pt(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,i),u=new lt({value:[new ee({valueHex:o}),new it({value:vi}),new it({value:Ei}),new lt({value:[new Ct({value:"1.2.840.113549.2.11"}),new ve]})]}),d=new lt({value:[new Ct({value:"1.2.840.113549.1.5.13"}),new lt({value:[new lt({value:[new Ct({value:"1.2.840.113549.1.5.12"}),u]}),new lt({value:[new Ct({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),p=new lt({value:[d,new ee({valueHex:l})]}).toBER(),h=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...W(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function Bi(r,t){let e=mt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=fr(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:l}=$f(i),u=await yi(pe,t,a,{c,dkLen:f}),d=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=Hr(await e.subtle.decrypt({name:"AES-CBC",iv:o},d,l)),{result:p}=fr(w);n=Ya(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=F(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=fr(s);n=Ya(i)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ai(n)}function $f(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 i=n.valueBlock.value[1],o=Hr(i.valueBlock.value[0].getValue()),a=vi,c=Ei;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.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 f=t.valueBlock.value[1].valueBlock.value[1],l=f.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 u=Hr(f.valueBlock.value[1].getValue());return{cipherText:Hr(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function Ya(r){return Hr(r.valueBlock.value[2].getValue())}function Hr(r){return new Uint8Array(r,0,r.byteLength)}async function Ga(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 Za(t);return{privateKey:e[0],publicKey:e[1]}}async function Si(r){let e=[await mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await qf(r)],n=await Za({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function za(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 Wa(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 Za(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 qf(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 fs(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 F(r.n,"base64url").length*8}var Kr=8192,Pr=class{_key;constructor(t){this._key=t}verify(t,e){return Wa(this._key,e,t)}marshal(){return Be.jwkToPkix(this._key)}get bytes(){return Xt.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}},hr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Pt(16)}sign(t){return za(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Pr(this._publicKey)}marshal(){return Be.jwkToPkcs1(this._key)}get bytes(){return Ht.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return W(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Be.exportToPem(this,t);if(e==="libp2p-key")return ir(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ai(r){let t=Be.pkcs1ToJwk(r);if(fs(t)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Si(t);return new hr(e.privateKey,e.publicKey)}function Yf(r){let t=Be.pkixToJwk(r);if(fs(t)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Pr(t)}async function Gf(r){if(fs(r)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Si(r);return new hr(t.privateKey,t.publicKey)}async function zf(r){if(r>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ga(r);return new hr(t.privateKey,t.publicKey)}var Ti={};ct(Ti,{Secp256k1PrivateKey:()=>Fr,Secp256k1PublicKey:()=>Mr,generateKeyPair:()=>ah,unmarshalSecp256k1PrivateKey:()=>ih,unmarshalSecp256k1PublicKey:()=>oh});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]),Ae=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Se=new Uint32Array(64),Ii=class extends fe{constructor(){super(64,32,8,!1),this.A=Ae[0]|0,this.B=Ae[1]|0,this.C=Ae[2]|0,this.D=Ae[3]|0,this.E=Ae[4]|0,this.F=Ae[5]|0,this.G=Ae[6]|0,this.H=Ae[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)Se[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=Se[u-15],w=Se[u-2],p=_t(d,7)^_t(d,18)^d>>>3,h=_t(w,17)^_t(w,19)^w>>>10;Se[u]=h+Se[u-7]+p+Se[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let d=_t(a,6)^_t(a,11)^_t(a,25),w=l+d+rn(a,c,f)+Wf[u]+Se[u]|0,h=(_t(n,2)^_t(n,13)^_t(n,22))+nn(n,s,i)|0;l=f,f=c,c=a,a=o+w|0,o=i,i=s,s=n,n=w+h|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,i,o,a,c,f,l)}roundClean(){Se.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var hs=tr(()=>new Ii);function Zf(r){let t=Ar(r);Ot(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:Jf,hexToBytes:Xf}=an,Ke={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Ke;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Jf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Ke,e=typeof r=="string"?Xf(r):r;rr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:i}=Ke._parseInt(e.subarray(2)),{d:o,l:a}=Ke._parseInt(i);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let t=f=>Number.parseInt(f[0],16)&8?"00"+f:f,e=f=>{let l=f.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),s=t(e(r.r)),i=n.length/2,o=s.length/2,a=e(i),c=e(o);return`30${e(o+i+4)}02${c}${s}02${a}${n}`}},ie=BigInt(0),Rt=BigInt(1),Tg=BigInt(2),Ja=BigInt(3),Cg=BigInt(4);function Qf(r){let t=Zf(r),{Fp:e}=t,n=t.toBytes||((p,h,g)=>{let m=h.toAffine();return Wt(Uint8Array.from([4]),e.toBytes(m.x),e.toBytes(m.y))}),s=t.fromBytes||(p=>{let h=p.subarray(1),g=e.fromBytes(h.subarray(0,e.BYTES)),m=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:g,y:m}});function i(p){let{a:h,b:g}=t,m=e.sqr(p),A=e.mul(m,p);return e.add(e.add(A,e.mul(p,h)),g)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function o(p){return typeof p=="bigint"&&ie<p&&p<t.n}function a(p){if(!o(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:g,wrapPrivateKey:m,n:A}=t;if(h&&typeof p!="bigint"){if(ge(p)&&(p=Gt(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(g*2,"0")}let b;try{b=typeof p=="bigint"?p:zt(tt("private key",p,g))}catch{throw new Error(`private key must be ${g} bytes, hex or bigint, not ${typeof p}`)}return m&&(b=G(b,A)),a(b),b}let f=new Map;function l(p){if(!(p instanceof u))throw new Error("ProjectivePoint expected")}class u{constructor(h,g,m){if(this.px=h,this.py=g,this.pz=m,h==null||!e.isValid(h))throw new Error("x required");if(g==null||!e.isValid(g))throw new Error("y required");if(m==null||!e.isValid(m))throw new Error("z required")}static fromAffine(h){let{x:g,y:m}=h||{};if(!h||!e.isValid(g)||!e.isValid(m))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let A=b=>e.eql(b,e.ZERO);return A(g)&&A(m)?u.ZERO:new u(g,m,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let g=e.invertBatch(h.map(m=>m.pz));return h.map((m,A)=>m.toAffine(g[A])).map(u.fromAffine)}static fromHex(h){let g=u.fromAffine(s(tt("pointHex",h)));return g.assertValidity(),g}static fromPrivateKey(h){return u.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,f.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:g}=this.toAffine();if(!e.isValid(h)||!e.isValid(g))throw new Error("bad point: x or y not FE");let m=e.sqr(g),A=i(h);if(!e.eql(m,A))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:g,py:m,pz:A}=this,{px:b,py:T,pz:x}=h,S=e.eql(e.mul(g,x),e.mul(b,A)),_=e.eql(e.mul(m,x),e.mul(T,A));return S&&_}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:g}=t,m=e.mul(g,Ja),{px:A,py:b,pz:T}=this,x=e.ZERO,S=e.ZERO,_=e.ZERO,N=e.mul(A,A),Y=e.mul(b,b),$=e.mul(T,T),D=e.mul(A,b);return D=e.add(D,D),_=e.mul(A,T),_=e.add(_,_),x=e.mul(h,_),S=e.mul(m,$),S=e.add(x,S),x=e.sub(Y,S),S=e.add(Y,S),S=e.mul(x,S),x=e.mul(D,x),_=e.mul(m,_),$=e.mul(h,$),D=e.sub(N,$),D=e.mul(h,D),D=e.add(D,_),_=e.add(N,N),N=e.add(_,N),N=e.add(N,$),N=e.mul(N,D),S=e.add(S,N),$=e.mul(b,T),$=e.add($,$),N=e.mul($,D),x=e.sub(x,N),_=e.mul($,Y),_=e.add(_,_),_=e.add(_,_),new u(x,S,_)}add(h){l(h);let{px:g,py:m,pz:A}=this,{px:b,py:T,pz:x}=h,S=e.ZERO,_=e.ZERO,N=e.ZERO,Y=t.a,$=e.mul(t.b,Ja),D=e.mul(g,b),nt=e.mul(m,T),et=e.mul(A,x),At=e.add(g,m),E=e.add(b,T);At=e.mul(At,E),E=e.add(D,nt),At=e.sub(At,E),E=e.add(g,A);let R=e.add(b,x);return E=e.mul(E,R),R=e.add(D,et),E=e.sub(E,R),R=e.add(m,A),S=e.add(T,x),R=e.mul(R,S),S=e.add(nt,et),R=e.sub(R,S),N=e.mul(Y,E),S=e.mul($,et),N=e.add(S,N),S=e.sub(nt,N),N=e.add(nt,N),_=e.mul(S,N),nt=e.add(D,D),nt=e.add(nt,D),et=e.mul(Y,et),E=e.mul($,E),nt=e.add(nt,et),et=e.sub(D,et),et=e.mul(Y,et),E=e.add(E,et),D=e.mul(nt,E),_=e.add(_,D),D=e.mul(R,E),S=e.mul(At,S),S=e.sub(S,D),D=e.mul(At,nt),N=e.mul(R,N),N=e.add(N,D),new u(S,_,N)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return w.wNAFCached(this,f,h,g=>{let m=e.invertBatch(g.map(A=>A.pz));return g.map((A,b)=>A.toAffine(m[b])).map(u.fromAffine)})}multiplyUnsafe(h){let g=u.ZERO;if(h===ie)return g;if(a(h),h===Rt)return this;let{endo:m}=t;if(!m)return w.unsafeLadder(this,h);let{k1neg:A,k1:b,k2neg:T,k2:x}=m.splitScalar(h),S=g,_=g,N=this;for(;b>ie||x>ie;)b&Rt&&(S=S.add(N)),x&Rt&&(_=_.add(N)),N=N.double(),b>>=Rt,x>>=Rt;return A&&(S=S.negate()),T&&(_=_.negate()),_=new u(e.mul(_.px,m.beta),_.py,_.pz),S.add(_)}multiply(h){a(h);let g=h,m,A,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:S,k2:_}=b.splitScalar(g),{p:N,f:Y}=this.wNAF(x),{p:$,f:D}=this.wNAF(_);N=w.constTimeNegate(T,N),$=w.constTimeNegate(S,$),$=new u(e.mul($.px,b.beta),$.py,$.pz),m=N.add($),A=Y.add(D)}else{let{p:T,f:x}=this.wNAF(g);m=T,A=x}return u.normalizeZ([m,A])[0]}multiplyAndAddUnsafe(h,g,m){let A=u.BASE,b=(x,S)=>S===ie||S===Rt||!x.equals(A)?x.multiplyUnsafe(S):x.multiply(S),T=b(this,g).add(b(h,m));return T.is0()?void 0:T}toAffine(h){let{px:g,py:m,pz:A}=this,b=this.is0();h==null&&(h=b?e.ONE:e.inv(A));let T=e.mul(g,h),x=e.mul(m,h),S=e.mul(A,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:g}=t;if(h===Rt)return!0;if(g)return g(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:g}=t;return h===Rt?this:g?g(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(u,this,h)}toHex(h=!0){return Gt(this.toRawBytes(h))}}u.BASE=new u(t.Gx,t.Gy,e.ONE),u.ZERO=new u(e.ZERO,e.ONE,e.ZERO);let d=t.nBitLength,w=un(u,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function th(r){let t=Ar(r);return Ot(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Xa(r){let t=th(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(E){return ie<E&&E<e.ORDER}function a(E){return G(E,n)}function c(E){return cn(E,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:d}=Qf({...t,toBytes(E,R,V){let v=R.toAffine(),y=e.toBytes(v.x),I=Wt;return V?I(Uint8Array.from([R.hasEvenY()?2:3]),y):I(Uint8Array.from([4]),y,e.toBytes(v.y))},fromBytes(E){let R=E.length,V=E[0],v=E.subarray(1);if(R===s&&(V===2||V===3)){let y=zt(v);if(!o(y))throw new Error("Point is not on curve");let I=u(y),C;try{C=e.sqrt(I)}catch(H){let j=H instanceof Error?": "+H.message:"";throw new Error("Point is not on curve"+j)}let L=(C&Rt)===Rt;return(V&1)===1!==L&&(C=e.neg(C)),{x:y,y:C}}else if(R===i&&V===4){let y=e.fromBytes(v.subarray(0,e.BYTES)),I=e.fromBytes(v.subarray(e.BYTES,2*e.BYTES));return{x:y,y:I}}else throw new Error(`Point of length ${R} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),w=E=>Gt(me(E,t.nByteLength));function p(E){let R=n>>Rt;return E>R}function h(E){return p(E)?a(-E):E}let g=(E,R,V)=>zt(E.slice(R,V));class m{constructor(R,V,v){this.r=R,this.s=V,this.recovery=v,this.assertValidity()}static fromCompact(R){let V=t.nByteLength;return R=tt("compactSignature",R,V*2),new m(g(R,0,V),g(R,V,2*V))}static fromDER(R){let{r:V,s:v}=Ke.toSig(tt("DER",R));return new m(V,v)}assertValidity(){if(!d(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!d(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(R){return new m(this.r,this.s,R)}recoverPublicKey(R){let{r:V,s:v,recovery:y}=this,I=_(tt("msgHash",R));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let C=y===2||y===3?V+t.n:V;if(C>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=y&1?"03":"02",O=f.fromHex(L+w(C)),H=c(C),j=a(-I*H),K=a(v*H),q=f.BASE.multiplyAndAddUnsafe(O,j,K);if(!q)throw new Error("point at infinify");return q.assertValidity(),q}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Le(this.toDERHex())}toDERHex(){return Ke.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Le(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}let A={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=Zs(t.n);return _o(t.randomBytes(E),t.n)},precompute(E=8,R=f.BASE){return R._setWindowSize(E),R.multiply(BigInt(3)),R}};function b(E,R=!0){return f.fromPrivateKey(E).toRawBytes(R)}function T(E){let R=ge(E),V=typeof E=="string",v=(R||V)&&E.length;return R?v===s||v===i:V?v===2*s||v===2*i:E instanceof f}function x(E,R,V=!0){if(T(E))throw new Error("first arg must be private key");if(!T(R))throw new Error("second arg must be public key");return f.fromHex(R).multiply(l(E)).toRawBytes(V)}let S=t.bits2int||function(E){let R=zt(E),V=E.length*8-t.nBitLength;return V>0?R>>BigInt(V):R},_=t.bits2int_modN||function(E){return a(S(E))},N=Br(t.nBitLength);function Y(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(ie<=E&&E<N))throw new Error(`bigint expected < 2^${t.nBitLength}`);return me(E,t.nByteLength)}function $(E,R,V=D){if(["recovered","canonical"].some(X=>X in V))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:y}=t,{lowS:I,prehash:C,extraEntropy:L}=V;I==null&&(I=!0),E=tt("msgHash",E),C&&(E=tt("prehashed msgHash",v(E)));let O=_(E),H=l(R),j=[Y(H),Y(O)];if(L!=null&&L!==!1){let X=L===!0?y(e.BYTES):L;j.push(tt("extraEntropy",X))}let K=Wt(...j),q=O;function st(X){let ut=S(X);if(!d(ut))return;let ft=c(ut),ot=f.BASE.multiply(ut).toAffine(),pt=a(ot.x);if(pt===ie)return;let qt=a(ft*a(q+pt*H));if(qt===ie)return;let Re=(ot.x===pt?0:2)|Number(ot.y&Rt),br=qt;return I&&p(qt)&&(br=h(qt),Re^=1),new m(pt,br,Re)}return{seed:K,k2sig:st}}let D={lowS:t.lowS,prehash:!1},nt={lowS:t.lowS,prehash:!1};function et(E,R,V=D){let{seed:v,k2sig:y}=$(E,R,V),I=t;return Ys(I.hash.outputLen,I.nByteLength,I.hmac)(v,y)}f.BASE._setWindowSize(8);function At(E,R,V,v=nt){let y=E;if(R=tt("msgHash",R),V=tt("publicKey",V),"strict"in v)throw new Error("options.strict was renamed to lowS");let{lowS:I,prehash:C}=v,L,O;try{if(typeof y=="string"||ge(y))try{L=m.fromDER(y)}catch(ot){if(!(ot instanceof Ke.Err))throw ot;L=m.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:ot,s:pt}=y;L=new m(ot,pt)}else throw new Error("PARSE");O=f.fromHex(V)}catch(ot){if(ot.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(I&&L.hasHighS())return!1;C&&(R=t.hash(R));let{r:H,s:j}=L,K=_(R),q=c(j),st=a(K*q),X=a(H*q),ut=f.BASE.multiplyAndAddUnsafe(O,st,X)?.toAffine();return ut?a(ut.x)===H:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:x,sign:et,verify:At,ProjectivePoint:f,Signature:m,utils:A}}function eh(r){return{hash:r,hmac:(t,...e)=>_r(r,t,en(...e)),randomBytes:er}}function Qa(r,t){let e=n=>Xa({...r,...eh(n)});return Object.freeze({...e(t),create:e})}var rc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),tc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),rh=BigInt(1),Ri=BigInt(2),ec=(r,t)=>(r+t/Ri)/t;function nh(r){let t=rc,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=J(l,e,t)*l%t,d=J(u,e,t)*l%t,w=J(d,Ri,t)*f%t,p=J(w,s,t)*w%t,h=J(p,i,t)*p%t,g=J(h,a,t)*h%t,m=J(g,c,t)*g%t,A=J(m,a,t)*h%t,b=J(A,e,t)*l%t,T=J(b,o,t)*p%t,x=J(T,n,t)*f%t,S=J(x,Ri,t);if(!_i.eql(_i.sqr(S),r))throw new Error("Cannot find square root");return S}var _i=ln(rc,void 0,void 0,{sqrt:nh}),Ut=Qa({a:BigInt(0),b:BigInt(7),Fp:_i,n:tc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=tc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-rh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=ec(i*r,t),c=ec(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*i,t),u=f>o,d=l>o;if(u&&(f=t-f),d&&(l=t-l),f>o||l>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:d,k2:l}}}},hs),Mg=BigInt(0);var Fg=Ut.ProjectivePoint;function nc(){return Ut.utils.randomPrivateKey()}function sc(r,t){let e=ht.digest(t instanceof Uint8Array?t:t.subarray());if(kt(e))return e.then(({digest:n})=>Ut.sign(n,r).toDERRawBytes()).catch(n=>{throw new B(String(n),"ERR_INVALID_INPUT")});try{return Ut.sign(e.digest,r).toDERRawBytes()}catch(n){throw new B(String(n),"ERR_INVALID_INPUT")}}function ic(r,t,e){let n=ht.digest(e instanceof Uint8Array?e:e.subarray());if(kt(n))return n.then(({digest:s})=>Ut.verify(t,s,r)).catch(s=>{throw new B(String(s),"ERR_INVALID_INPUT")});try{return Ut.verify(t,n.digest,r)}catch(s){throw new B(String(s),"ERR_INVALID_INPUT")}}function oc(r){return Ut.ProjectivePoint.fromHex(r).toRawBytes(!0)}function ac(r){try{Ut.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Ni(r){try{Ut.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function cc(r){try{return Ut.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Mr=class{_key;constructor(t){Ni(t),this._key=t}verify(t,e){return ic(this._key,e,t)}marshal(){return oc(this._key)}get bytes(){return Xt.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return kt(t)?{bytes:e}=await t:e=t.bytes,e}},Fr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??cc(t),ac(this._key),Ni(this._publicKey)}sign(t){return sc(this._key,t)}get public(){return new Mr(this._publicKey)}marshal(){return this._key}get bytes(){return Ht.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return St(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return W(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return ir(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ih(r){return new Fr(r)}function oh(r){return new Mr(r)}async function ah(){let r=nc();return new Fr(r)}var $r={rsa:ki,ed25519:gi,secp256k1:Ti};function lc(r){let t=Object.keys($r).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function ch(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return $r[r];throw lc(r)}async function uc(r,t){return ch(r).generateKeyPair(t??2048)}async function Ci(r){let t=Ht.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return $r.rsa.unmarshalRsaPrivateKey(e);case rt.Ed25519:return $r.ed25519.unmarshalEd25519PrivateKey(e);case rt.Secp256k1:return $r.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw lc(t.Type??"RSA")}}async function qr(r,t){try{let e=await ea(r,t);return await Ci(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 Bi(r,t)}var jr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),ke=new Uint32Array(80),Li=class extends fe{constructor(){super(64,20,8,!1),this.A=jr[0]|0,this.B=jr[1]|0,this.C=jr[2]|0,this.D=jr[3]|0,this.E=jr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:i}=this;return[t,e,n,s,i]}set(t,e,n,s,i){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0}process(t,e){for(let c=0;c<16;c++,e+=4)ke[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)ke[c]=tn(ke[c-3]^ke[c-8]^ke[c-14]^ke[c-16],1);let{A:n,B:s,C:i,D:o,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=rn(s,i,o),l=1518500249):c<40?(f=s^i^o,l=1859775393):c<60?(f=nn(s,i,o),l=2400959708):(f=s^i^o,l=3395469782);let u=tn(n,5)+f+a+l+ke[c]|0;a=o,o=i,i=tn(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,this.set(n,s,i,o,a)}roundClean(){ke.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},fc=tr(()=>new Li);var hc={sha1:fc,"sha2-256":hs,"sha2-512":pe};function Yr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(hc).join(" / ");throw new B(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let i=hc[s],o=sa(i,r,t,{c:e,dkLen:n});return Ne.encode(o).substring(1)}var lh=Symbol.for("nodejs.util.inspect.custom"),dc=Object.values(We).map(r=>r.decoder).reduce((r,t)=>r.or(t),We.identity.decoder),pc=114,Ui=36,Di=37,Gr=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()})`}[Gi]=!0;toString(){return this.string==null&&(this.string=bt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Te.createV1(pc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return St(this.multihash.bytes,t);if(typeof t=="string")return uh(t).equals(this);if(t?.multihash?.bytes!=null)return St(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[lh](){return`PeerId(${this.toString()})`}},dr=class extends Gr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},pr=class extends Gr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},gr=class extends Gr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function uh(r,t){if(t=t??dc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Er(bt.decode(`z${r}`));return r.startsWith("12D")?new pr({multihash:e}):r.startsWith("16U")?new gr({multihash:e}):new dr({multihash:e})}return fh(dc.decode(r))}function fh(r){try{let t=Er(r);if(t.code===le.code){if(t.digest.length===Ui)return new pr({multihash:t});if(t.digest.length===Di)return new gr({multihash:t})}if(t.code===ht.code)return new dr({multihash:t})}catch{return hh(Te.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function hh(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==pc)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===ht.code)return new dr({multihash:r.multihash});if(t.code===le.code){if(t.digest.length===Ui)return new pr({multihash:r.multihash});if(t.digest.length===Di)return new gr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function gc(r,t){return r.length===Ui?new pr({multihash:Dt(le.code,r),privateKey:t}):r.length===Di?new gr({multihash:Dt(le.code,r),privateKey:t}):new dr({multihash:await ht.digest(r),publicKey:r,privateKey:t})}var oe="/",yc=new TextEncoder().encode(oe),ds=yc[0],zr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=F(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]!==ds)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(oe))}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=yc),this._buf[0]!==ds){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ds,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ds;)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 i=e[s],o=n[s];if(i<o)return!0;if(i>o)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(oe).slice(1)}type(){return dh(this.baseNamespace())}name(){return ph(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(oe)||(t+=oe),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(oe):new r(t.slice(0,-1).join(oe))}child(t){return this.toString()===oe?t:t.toString()===oe?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(),...gh(t.map(e=>e.namespaces()))])}};function dh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function ph(r){let t=r.split(":");return t[t.length-1]}function gh(r){return[].concat(...r)}var Sc=bs(Ac(),1),kc=Sc.default;var Vc=bs(Dc(),1);var M;(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"})(M||(M={}));var Lh="/pkcs8/",Oc="/info/",Me=new WeakMap,Fe={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Oi={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function ae(r){return r==null||typeof r!="string"?!1:r===(0,Vc.default)(r.trim())&&r.length>0}async function z(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function $t(r){return new zr(Lh+r)}function Ie(r){return new zr(Oc+r)}var ys=class{components;init;log;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=kc(Oi,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<Fe.minKeyLength)throw new Error(`dek.keyLength must be least ${Fe.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Fe.minSaltLength)throw new Error(`dek.saltLength must be least ${Fe.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Fe.minIterationCount)throw new Error(`dek.iterationCount must be least ${Fe.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?Yr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Me.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[zi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},Oi),e=Math.ceil(Fe.minSaltLength/3)*3;return t.dek.salt=W(Pt(e),"base64"),t}static get options(){return Oi}async createKey(t,e,n=2048){if(!ae(t)||t==="self")throw await z(),new B("Invalid key name",M.ERR_INVALID_KEY_NAME);if(typeof e!="string")throw await z(),new B("Invalid key type",M.ERR_INVALID_KEY_TYPE);let s=$t(t);if(await this.components.datastore.has(s))throw await z(),new B("Key name already exists",M.ERR_KEY_ALREADY_EXISTS);switch(e.toLowerCase()){case"rsa":if(!Number.isSafeInteger(n)||n<2048)throw await z(),new B("Invalid RSA key size",M.ERR_INVALID_KEY_SIZE);break;default:break}let o;try{let a=await uc(e,n),c=await a.id(),f=Me.get(this);if(f==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let l=f.dek,u=await a.export(l);o={name:t,id:c};let d=this.components.datastore.batch();d.put(s,F(u)),d.put(Ie(t),F(JSON.stringify(o))),await d.commit()}catch(a){throw await z(),a}return o}async listKeys(){let t={prefix:Oc},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(W(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.`,M.ERR_KEY_NOT_FOUND);return n}catch(e){throw await z(),e}}async findKeyByName(t){if(!ae(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);let e=Ie(t);try{let n=await this.components.datastore.get(e);return JSON.parse(W(n))}catch(n){throw await z(),this.log.error(n),new B(`Key '${t}' does not exist.`,M.ERR_KEY_NOT_FOUND)}}async removeKey(t){if(!ae(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);let e=$t(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(Ie(t)),await s.commit(),n}async renameKey(t,e){if(!ae(t)||t==="self")throw await z(),new B(`Invalid old key name '${t}'`,M.ERR_OLD_KEY_NAME_INVALID);if(!ae(e)||e==="self")throw await z(),new B(`Invalid new key name '${e}'`,M.ERR_NEW_KEY_NAME_INVALID);let n=$t(t),s=$t(e),i=Ie(t),o=Ie(e);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${e}' already exists`,M.ERR_KEY_ALREADY_EXISTS);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(i),l=JSON.parse(W(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(o,F(JSON.stringify(l))),u.delete(n),u.delete(i),await u.commit(),l}catch(c){throw await z(),c}}async exportKey(t,e){if(!ae(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);if(e==null)throw await z(),new B("Password is required",M.ERR_PASSWORD_REQUIRED);let n=$t(t);try{let s=await this.components.datastore.get(n),i=W(s),o=Me.get(this);if(o==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let a=o.dek;return await(await qr(i,a)).export(e)}catch(s){throw await z(),s}}async exportPeerId(t){let e="temporary-password",n=await this.exportKey(t,e),s=await qr(n,e);return gc(s.public.bytes,s.bytes)}async importKey(t,e,n){if(!ae(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);if(e==null)throw await z(),new B("PEM encoded key is required",M.ERR_PEM_REQUIRED);let s=$t(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,M.ERR_KEY_ALREADY_EXISTS);let o;try{o=await qr(e,n)}catch{throw await z(),new B("Cannot read the key, most likely the password is wrong",M.ERR_CANNOT_READ_KEY)}let a;try{a=await o.id();let l=Me.get(this);if(l==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let u=l.dek;e=await o.export(u)}catch(l){throw await z(),l}let c={name:t,id:a},f=this.components.datastore.batch();return f.put(s,F(e)),f.put(Ie(t),F(JSON.stringify(c))),await f.commit(),c}async importPeer(t,e){try{if(!ae(t))throw new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);if(e==null)throw new B("PeerId is required",M.ERR_MISSING_PRIVATE_KEY);if(e.privateKey==null)throw new B("PeerId.privKey is required",M.ERR_MISSING_PRIVATE_KEY);let n=await Ci(e.privateKey),s=$t(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,M.ERR_KEY_ALREADY_EXISTS);let o=Me.get(this);if(o==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let a=o.dek,c=await n.export(a),f={name:t,id:e.toString()},l=this.components.datastore.batch();return l.put(s,F(c)),l.put(Ie(t),F(JSON.stringify(f))),await l.commit(),f}catch(n){throw await z(),n}}async getPrivateKey(t){if(!ae(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);try{let e=$t(t),n=await this.components.datastore.get(e);return W(n)}catch(e){throw await z(),this.log.error(e),new B(`Key '${t}' does not exist.`,M.ERR_KEY_NOT_FOUND)}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await z(),new B(`Invalid old pass type '${typeof t}'`,M.ERR_INVALID_OLD_PASS_TYPE);if(typeof e!="string")throw await z(),new B(`Invalid new pass type '${typeof e}'`,M.ERR_INVALID_NEW_PASS_TYPE);if(e.length<20)throw await z(),new B(`Invalid pass length ${e.length}`,M.ERR_INVALID_PASS_LENGTH);this.log("recreating keychain");let n=Me.get(this);if(n==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let s=n.dek;this.init.pass=e;let i=e!=null&&this.init.dek?.salt!=null?Yr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Me.set(this,{dek:i});let o=await this.listKeys();for(let a of o){let c=await this.components.datastore.get($t(a.name)),f=W(c),l=await qr(f,s),u=i.toString(),d=await l.export(u),w=this.components.datastore.batch(),p={name:a.name,id:a.id};w.put($t(a.name),F(d)),w.put(Ie(a.name),F(JSON.stringify(p))),await w.commit()}this.log("keychain reconstructed")}};function Uh(r={}){return t=>new ys(t,r)}return Jc(Dh);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|
package/dist/src/keychain.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { serviceCapabilities } from '@libp2p/interface';
|
|
1
2
|
import type { KeychainComponents, KeychainInit, Keychain, KeyInfo } from './index.js';
|
|
2
3
|
import type { KeyType, PeerId } from '@libp2p/interface';
|
|
3
4
|
declare const defaultOptions: {
|
|
@@ -24,6 +25,8 @@ export declare class DefaultKeychain implements Keychain {
|
|
|
24
25
|
* Creates a new instance of a key chain
|
|
25
26
|
*/
|
|
26
27
|
constructor(components: KeychainComponents, init: KeychainInit);
|
|
28
|
+
readonly [Symbol.toStringTag] = "@libp2p/keychain";
|
|
29
|
+
readonly [serviceCapabilities]: string[];
|
|
27
30
|
/**
|
|
28
31
|
* Generates the options for a keychain. A random salt is produced.
|
|
29
32
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"keychain.d.ts","sourceRoot":"","sources":["../../src/keychain.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"keychain.d.ts","sourceRoot":"","sources":["../../src/keychain.ts"],"names":[],"mappings":"AAIA,OAAO,EAAa,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAQlE,OAAO,KAAK,EAAE,kBAAkB,EAAE,YAAY,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AACrF,OAAO,KAAK,EAAU,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAahE,QAAA,MAAM,cAAc;;;;;;;CAQnB,CAAA;AAwCD;;;;;;;GAOG;AACH,qBAAa,eAAgB,YAAW,QAAQ;IAC9C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAc;IACnC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAQ;IAE5B;;OAEG;gBACU,UAAU,EAAE,kBAAkB,EAAE,IAAI,EAAE,YAAY;IA+B/D,QAAQ,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,sBAAqB;IAElD,QAAQ,CAAC,CAAC,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAEvC;IAED;;;;OAIG;IACH,MAAM,CAAC,eAAe,IAAK,YAAY;IAOvC;;;;;OAKG;IACH,MAAM,KAAK,OAAO,IAAK,OAAO,cAAc,CAE3C;IAED;;;;;;OAMG;IACG,SAAS,CAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,SAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IA0D5E;;;;OAIG;IACG,QAAQ,IAAK,OAAO,CAAC,OAAO,EAAE,CAAC;IAarC;;OAEG;IACG,WAAW,CAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAgBhD;;;;;OAKG;IACG,aAAa,CAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAiBpD;;;;;OAKG;IACG,SAAS,CAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAchD;;;;;;OAMG;IACG,SAAS,CAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAuCpE;;OAEG;IACG,SAAS,CAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IA+BjE;;OAEG;IACG,YAAY,CAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAQlD;;;;;;;OAOG;IACG,SAAS,CAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAoD/E;;OAEG;IACG,UAAU,CAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IA4C/D;;OAEG;IACG,aAAa,CAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAiBnD;;OAEG;IACG,kBAAkB,CAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAmD3E"}
|
package/dist/src/keychain.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/* eslint max-nested-callbacks: ["error", 5] */
|
|
2
2
|
import { pbkdf2, randomBytes } from '@libp2p/crypto';
|
|
3
3
|
import { generateKeyPair, importKey, unmarshalPrivateKey } from '@libp2p/crypto/keys';
|
|
4
|
-
import { CodeError } from '@libp2p/interface';
|
|
4
|
+
import { CodeError, serviceCapabilities } from '@libp2p/interface';
|
|
5
5
|
import { peerIdFromKeys } from '@libp2p/peer-id';
|
|
6
6
|
import { Key } from 'interface-datastore/key';
|
|
7
7
|
import mergeOptions from 'merge-options';
|
|
@@ -97,6 +97,10 @@ export class DefaultKeychain {
|
|
|
97
97
|
: '';
|
|
98
98
|
privates.set(this, { dek });
|
|
99
99
|
}
|
|
100
|
+
[Symbol.toStringTag] = '@libp2p/keychain';
|
|
101
|
+
[serviceCapabilities] = [
|
|
102
|
+
'@libp2p/keychain'
|
|
103
|
+
];
|
|
100
104
|
/**
|
|
101
105
|
* Generates the options for a keychain. A random salt is produced.
|
|
102
106
|
*
|
package/dist/src/keychain.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"keychain.js","sourceRoot":"","sources":["../../src/keychain.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"keychain.js","sourceRoot":"","sources":["../../src/keychain.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/keychain",
|
|
3
|
-
"version": "4.0
|
|
3
|
+
"version": "4.1.0",
|
|
4
4
|
"description": "Key management and cryptographically protected messages",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/keychain#readme",
|
|
@@ -59,9 +59,9 @@
|
|
|
59
59
|
"test:electron-main": "aegir test -t electron-main"
|
|
60
60
|
},
|
|
61
61
|
"dependencies": {
|
|
62
|
-
"@libp2p/crypto": "^4.1.
|
|
63
|
-
"@libp2p/interface": "^1.
|
|
64
|
-
"@libp2p/peer-id": "^4.1.
|
|
62
|
+
"@libp2p/crypto": "^4.1.4",
|
|
63
|
+
"@libp2p/interface": "^1.5.0",
|
|
64
|
+
"@libp2p/peer-id": "^4.1.4",
|
|
65
65
|
"interface-datastore": "^8.2.11",
|
|
66
66
|
"merge-options": "^3.0.4",
|
|
67
67
|
"multiformats": "^13.1.0",
|
|
@@ -69,8 +69,8 @@
|
|
|
69
69
|
"uint8arrays": "^5.1.0"
|
|
70
70
|
},
|
|
71
71
|
"devDependencies": {
|
|
72
|
-
"@libp2p/logger": "^4.0.
|
|
73
|
-
"@libp2p/peer-id-factory": "^4.1.
|
|
72
|
+
"@libp2p/logger": "^4.0.15",
|
|
73
|
+
"@libp2p/peer-id-factory": "^4.1.4",
|
|
74
74
|
"aegir": "^43.0.1",
|
|
75
75
|
"datastore-core": "^9.2.9"
|
|
76
76
|
},
|
package/src/keychain.ts
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
import { pbkdf2, randomBytes } from '@libp2p/crypto'
|
|
4
4
|
import { generateKeyPair, importKey, unmarshalPrivateKey } from '@libp2p/crypto/keys'
|
|
5
|
-
import { CodeError } from '@libp2p/interface'
|
|
5
|
+
import { CodeError, serviceCapabilities } from '@libp2p/interface'
|
|
6
6
|
import { peerIdFromKeys } from '@libp2p/peer-id'
|
|
7
7
|
import { Key } from 'interface-datastore/key'
|
|
8
8
|
import mergeOptions from 'merge-options'
|
|
@@ -119,6 +119,12 @@ export class DefaultKeychain implements Keychain {
|
|
|
119
119
|
privates.set(this, { dek })
|
|
120
120
|
}
|
|
121
121
|
|
|
122
|
+
readonly [Symbol.toStringTag] = '@libp2p/keychain'
|
|
123
|
+
|
|
124
|
+
readonly [serviceCapabilities]: string[] = [
|
|
125
|
+
'@libp2p/keychain'
|
|
126
|
+
]
|
|
127
|
+
|
|
122
128
|
/**
|
|
123
129
|
* Generates the options for a keychain. A random salt is produced.
|
|
124
130
|
*
|