@libp2p/keychain 4.0.7-f4dda4a3c → 4.0.8
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/typedoc-urls.json +14 -0
- package/package.json +11 -11
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 Dc=Object.create;var Yr=Object.defineProperty;var Vc=Object.getOwnPropertyDescriptor;var Oc=Object.getOwnPropertyNames;var Hc=Object.getPrototypeOf,Kc=Object.prototype.hasOwnProperty;var Ie=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ct=(r,t)=>{for(var e in t)Yr(r,e,{get:t[e],enumerable:!0})},Mi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Oc(t))!Kc.call(r,s)&&s!==e&&Yr(r,s,{get:()=>t[s],enumerable:!(n=Vc(t,s))||n.enumerable});return r};var fs=(r,t,e)=>(e=r!=null?Dc(Hc(r)):{},Mi(t||!r||!r.__esModule?Yr(e,"default",{value:r,enumerable:!0}):e,r)),Pc=r=>Mi(Yr({},"__esModule",{value:!0}),r);var zo=Ie(ir=>{"use strict";var ff="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===ff}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}},fi="string",hf=/^[0-9a-f]+$/i,df=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,pf=/^[a-zA-Z0-9-_]+$/,yn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=Qt.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},St=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}},mn=class r{static isHex(t){return typeof t===fi&&hf.test(t)}static isBase64(t){return typeof t===fi&&df.test(t)}static isBase64Url(t){return typeof t===fi&&pf.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 St.toString(n,!0);case"utf16":case"utf16be":return St.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 St.fromString(t,!0);case"utf16":case"utf16be":return St.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 yn.fromString(t);case"utf16":case"utf16be":return St.fromString(t);case"utf16le":case"usc2":return St.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return yn.toString(t);case"utf16":case"utf16be":return St.toString(t);case"utf16le":case"usc2":return St.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 St.toString(t,e)}static FromUtf16String(t,e=!1){return St.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,"")||""}};mn.DEFAULT_UTF8_ENCODING="utf8";function gf(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 yf(...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 mf(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}ir.BufferSourceConverter=Qt;ir.Convert=mn;ir.assign=gf;ir.combine=yf;ir.isEqual=mf});var ac=Ie((qg,oc)=>{"use strict";oc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var dc=Ie((fc,hc)=>{"use strict";var as=ac(),{hasOwnProperty:lc}=Object.prototype,{propertyIsEnumerable:ah}=Object,dr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),ch=fc,cc={concatArrays:!1,ignoreUndefined:!1},cs=r=>{let t=[];for(let e in r)lc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)ah.call(r,n)&&t.push(n)}return t};function pr(r){return Array.isArray(r)?lh(r):as(r)?uh(r):r}function lh(r){let t=r.slice(0,0);return cs(r).forEach(e=>{dr(t,e,pr(r[e]))}),t}function uh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return cs(r).forEach(e=>{dr(t,e,pr(r[e]))}),t}var uc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?dr(r,s,Ti(r[s],t[s],n)):dr(r,s,pr(t[s])))}),r),fh=(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++)lc.call(i,a)&&(o.push(String(a)),i===r?dr(n,s++,i[a]):dr(n,s++,pr(i[a])));n=uc(n,i,cs(i).filter(a=>!o.includes(a)),e)}),n};function Ti(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?fh(r,t,e):!as(t)||!as(r)?pr(t):uc(r,t,cs(t),e)}hc.exports=function(...r){let t=Ti(pr(cc),this!==ch&&this||{},cc),e={_:{}};for(let n of r)if(n!==void 0){if(!as(n))throw new TypeError("`"+n+"` is not an Option Object");e=Ti(e,{_:n},t)}return e._}});var mc=Ie((Yg,yc)=>{"use strict";function hh(r){return r>=55296&&r<=56319}function dh(r){return r>=56320&&r<=57343}yc.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],hh(o)&&dh(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 wc=Ie((Gg,bc)=>{"use strict";function ph(r){return r>=55296&&r<=56319}function gh(r){return r>=56320&&r<=57343}bc.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),gh(s)?i!=null&&ph(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 Ec=Ie((zg,xc)=>{"use strict";var yh=mc(),mh=wc();xc.exports=yh.bind(null,mh)});var Ac=Ie((Wg,Bc)=>{"use strict";var bh=Ec(),wh=/[\/\?<>\\:\*\|"]/g,xh=/[\x00-\x1f\x80-\x9f]/g,Eh=/^\.+$/,vh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Bh=/[\. ]+$/;function vc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(wh,t).replace(xh,t).replace(Eh,t).replace(vh,t).replace(Bh,t);return bh(e,255)}Bc.exports=function(r,t){var e=t&&t.replacement||"",n=vc(r,e);return e===""?n:vc(n,"")}});var Sh={};ct(Sh,{keychain:()=>kh});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 Fi=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 li={};ct(li,{Ed25519PrivateKey:()=>Oe,Ed25519PublicKey:()=>kr,generateKeyPair:()=>uf,generateKeyPairFromSeed:()=>$o,unmarshalEd25519PrivateKey:()=>cf,unmarshalEd25519PublicKey:()=>lf});var ys={};ct(ys,{base58btc:()=>bt,base58flickr:()=>Yc});var Th=new Uint8Array(0);function $i(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 qt(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 qi(r){return new TextEncoder().encode(r)}function ji(r){return new TextDecoder().decode(r)}function Mc(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],k=0,_=b-1;(x!==0||k<g)&&_!==-1;_--,k++)x+=256*T[_]>>>0,T[_]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");g=k,m++}for(var N=b-g;N!==b&&T[N]===0;)N++;for(var j=c.repeat(h);N<b;++N)j+=r.charAt(T[N]);return j}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,k=A-1;(T!==0||x<m)&&k!==-1;k--,x++)T+=a*b[k]>>>0,b[k]=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-_)),j=g;_!==A;)N[j++]=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 Fc=Mc,$c=Fc,Gi=$c;var hs=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")}},ds=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 zi(this,t)}},ps=class{decoders;constructor(t){this.decoders=t}or(t){return zi(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 zi(r,t){return new ps({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var gs=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 hs(t,e,n),this.decoder=new ds(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Fe({name:r,prefix:t,encode:e,decode:n}){return new gs(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Gi(e,r);return Fe({prefix:t,name:r,encode:n,decode:i=>qt(s(i))})}function qc(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 jc(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 Fe({prefix:t,name:r,encode(s){return jc(s,n,e)},decode(s){return qc(s,n,e,r)}})}var bt=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Yc=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var bs={};ct(bs,{identity:()=>le});var Gc=Ji,Wi=128,zc=127,Wc=~zc,Zc=Math.pow(2,31);function Ji(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Zc;)t[e++]=r&255|Wi,r/=128;for(;r&Wc;)t[e++]=r&255|Wi,r>>>=7;return t[e]=r|0,Ji.bytes=e-n+1,t}var Jc=ms,Xc=128,Zi=127;function ms(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw ms.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Zi)<<s:(o&Zi)*Math.pow(2,s),s+=7}while(o>=Xc);return ms.bytes=i-n,e}var Qc=Math.pow(2,7),tl=Math.pow(2,14),el=Math.pow(2,21),rl=Math.pow(2,28),nl=Math.pow(2,35),sl=Math.pow(2,42),il=Math.pow(2,49),ol=Math.pow(2,56),al=Math.pow(2,63),cl=function(r){return r<Qc?1:r<tl?2:r<el?3:r<rl?4:r<nl?5:r<sl?6:r<il?7:r<ol?8:r<al?9:10},ll={encode:Gc,decode:Jc,encodingLength:cl},ul=ll,yr=ul;function mr(r,t=0){return[yr.decode(r,t),yr.decode.bytes]}function $e(r,t,e=0){return yr.encode(r,t,e),t}function qe(r){return yr.encodingLength(r)}function Dt(r,t){let e=t.byteLength,n=qe(r),s=n+qe(e),i=new Uint8Array(s+e);return $e(r,i,0),$e(e,i,n),i.set(t,s),new je(r,e,t,i)}function br(r){let t=qt(r),[e,n]=mr(t),[s,i]=mr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new je(e,s,o,t)}function Xi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&$i(r.bytes,e.bytes)}}var je=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Qi=0,fl="identity",to=qt;function hl(r){return Dt(Qi,to(r))}var le={code:Qi,name:fl,encode:to,digest:hl};var Es={};ct(Es,{sha256:()=>ht,sha512:()=>dl});function xs({name:r,code:t,encode:e}){return new ws(r,t,e)}var ws=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 ro(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ht=xs({name:"sha2-256",code:18,encode:ro("SHA-256")}),dl=xs({name:"sha2-512",code:19,encode:ro("SHA-512")});function At(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 Re(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function jt(r=0){return globalThis.Buffer?.allocUnsafe!=null?Re(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function vs(r,t){if(globalThis.Buffer!=null)return Re(globalThis.Buffer.concat(r,t));t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=jt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return Re(e)}var Bs={};ct(Bs,{base10:()=>pl});var pl=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var As={};ct(As,{base16:()=>gl,base16upper:()=>yl});var gl=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),yl=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ks={};ct(ks,{base2:()=>ml});var ml=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ss={};ct(Ss,{base256emoji:()=>vl});var no=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}"),bl=no.reduce((r,t,e)=>(r[e]=t,r),[]),wl=no.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function xl(r){return r.reduce((t,e)=>(t+=bl[e],t),"")}function El(r){let t=[];for(let e of r){let n=wl[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var vl=Fe({prefix:"\u{1F680}",name:"base256emoji",encode:xl,decode:El});var Is={};ct(Is,{base32:()=>Ge,base32hex:()=>Sl,base32hexpad:()=>Rl,base32hexpadupper:()=>_l,base32hexupper:()=>Il,base32pad:()=>Al,base32padupper:()=>kl,base32upper:()=>Bl,base32z:()=>Nl});var Ge=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Bl=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Al=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),kl=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Sl=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Il=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Rl=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),_l=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Nl=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Rs={};ct(Rs,{base36:()=>Tl,base36upper:()=>Cl});var Tl=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Cl=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var _s={};ct(_s,{base64:()=>_e,base64pad:()=>Ll,base64url:()=>Ul,base64urlpad:()=>Dl});var _e=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ll=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ul=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Dl=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ns={};ct(Ns,{base8:()=>Vl});var Vl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ts={};ct(Ts,{identity:()=>Ol});var Ol=Fe({prefix:"\0",name:"identity",encode:r=>ji(r),decode:r=>qi(r)});var id=new TextEncoder,od=new TextDecoder;function so(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ml(e,Cs(r),t??bt.encoder);default:return Fl(e,Cs(r),t??Ge.encoder)}}var io=new WeakMap;function Cs(r){let t=io.get(r);if(t==null){let e=new Map;return io.set(r,e),e}return t}var Ne=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!==wr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==$l)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&&Xi(t.multihash,n.multihash)}toString(t){return so(this,t)}toJSON(){return{"/":so(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??oo(n,s,i.bytes))}else if(e[ql]===!0){let{version:n,multihash:s,code:i}=e,o=br(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!==wr)throw new Error(`Version 0 CID must use dag-pb (code: ${wr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=oo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,wr,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=qt(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 je(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]=mr(t.subarray(e));return e+=d,u},s=n(),i=wr;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]=Pl(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 Cs(i).set(n,t),i}};function Pl(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 Ge.prefix:{let e=t??Ge;return[Ge.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 Ml(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 Fl(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 wr=112,$l=18;function oo(r,t,e){let n=qe(r),s=n+qe(t),i=new Uint8Array(s+e.byteLength);return $e(r,i,0),$e(t,i,n),i.set(e,s),i}var ql=Symbol.for("@ipld/js-cid/CID");var ze={...Ts,...ks,...Ns,...Bs,...As,...Is,...Rs,...ys,..._s,...Ss},vd={...Es,...bs};function co(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ao=co("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ls=co("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=jt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),jl={utf8:ao,"utf-8":ao,hex:ze.base16,latin1:Ls,ascii:Ls,binary:Ls,...ze},zr=jl;function F(r,t="utf8"){let e=zr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Re(globalThis.Buffer.from(r,"utf-8")):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 We(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function Yl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Us(r,...t){if(!Yl(r))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(r.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${r.length}`)}function Wr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");We(r.outputLen),We(r.blockLen)}function Ze(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function lo(r,t){Us(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Zr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function uo(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Te=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Rt=(r,t)=>r<<32-t|r>>>t,Gl=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Gl)throw new Error("Non little-endian hardware is not supported");var zl=async()=>{};async function fo(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 zl(),n+=i)}}function Ds(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ue(r){if(typeof r=="string"&&(r=Ds(r)),!uo(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function Jr(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];if(!uo(s))throw new Error("Uint8Array expected");t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var Je=class{clone(){return this._cloneInto()}},Wl={}.toString;function ho(r,t){if(t!==void 0&&Wl.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Xe(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 Qe(r=32){if(Zr&&typeof Zr.getRandomValues=="function")return Zr.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Zl(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 fe=class extends Je{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=Te(this.buffer)}update(t){Ze(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=Te(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){Ze(this),lo(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;Zl(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Te(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 Xr=BigInt(4294967295),Vs=BigInt(32);function po(r,t=!1){return t?{h:Number(r&Xr),l:Number(r>>Vs&Xr)}:{h:Number(r>>Vs&Xr)|0,l:Number(r&Xr)|0}}function Jl(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}=po(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var Xl=(r,t)=>BigInt(r>>>0)<<Vs|BigInt(t>>>0),Ql=(r,t,e)=>r>>>e,tu=(r,t,e)=>r<<32-e|t>>>e,eu=(r,t,e)=>r>>>e|t<<32-e,ru=(r,t,e)=>r<<32-e|t>>>e,nu=(r,t,e)=>r<<64-e|t>>>e-32,su=(r,t,e)=>r>>>e-32|t<<64-e,iu=(r,t)=>t,ou=(r,t)=>r,au=(r,t,e)=>r<<e|t>>>32-e,cu=(r,t,e)=>t<<e|r>>>32-e,lu=(r,t,e)=>t<<e-32|r>>>64-e,uu=(r,t,e)=>r<<e-32|t>>>64-e;function fu(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var hu=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),du=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,pu=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),gu=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,yu=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),mu=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var bu={fromBig:po,split:Jl,toBig:Xl,shrSH:Ql,shrSL:tu,rotrSH:eu,rotrSL:ru,rotrBH:nu,rotrBL:su,rotr32H:iu,rotr32L:ou,rotlSH:au,rotlSL:cu,rotlBH:lu,rotlBL:uu,add:fu,add3L:hu,add3H:du,add4L:pu,add4H:gu,add5H:mu,add5L:yu},U=bu;var[wu,xu]=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),Os=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,k=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,j=de[b-2]|0,$=U.rotrSH(N,j,19)^U.rotrBH(N,j,61)^U.shrSH(N,j,6),D=U.rotrSL(N,j,19)^U.rotrBL(N,j,61)^U.shrSL(N,j,6),nt=U.add4L(_,D,de[b-7],de[b-16]),et=U.add4H(nt,k,$,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),k=u&w^~u&h,_=d&p^~d&g,N=U.add5L(A,x,_,xu[b],de[b]),j=U.add5H(N,m,T,k,wu[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,Bt=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,j|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,Bt);n=U.add3H(E,j,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=Xe(()=>new Os);var tn={};ct(tn,{bitGet:()=>Iu,bitLen:()=>Su,bitMask:()=>xr,bitSet:()=>Ru,bytesToHex:()=>Gt,bytesToNumberBE:()=>zt,bytesToNumberLE:()=>ge,concatBytes:()=>Wt,createHmacDrbg:()=>Ps,ensureBytes:()=>tt,equalBytes:()=>Au,hexToBytes:()=>Ce,hexToNumber:()=>Ks,isBytes:()=>_t,numberToBytesBE:()=>ye,numberToBytesLE:()=>Le,numberToHexUnpadded:()=>bo,numberToVarBytesBE:()=>Bu,utf8ToBytes:()=>ku,validateObject:()=>Vt});var mo=BigInt(0),Qr=BigInt(1),Eu=BigInt(2);function _t(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var vu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Gt(r){if(!_t(r))throw new Error("Uint8Array expected");let t="";for(let e=0;e<r.length;e++)t+=vu[r[e]];return t}function bo(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Ks(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 go(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 Ce(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=go(r.charCodeAt(i)),a=go(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 Ks(Gt(r))}function ge(r){if(!_t(r))throw new Error("Uint8Array expected");return Ks(Gt(Uint8Array.from(r).reverse()))}function ye(r,t){return Ce(r.toString(16).padStart(t*2,"0"))}function Le(r,t){return ye(r,t).reverse()}function Bu(r){return Ce(bo(r))}function tt(r,t,e){let n;if(typeof t=="string")try{n=Ce(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(_t(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 s=0;s<r.length;s++){let i=r[s];if(!_t(i))throw new Error("Uint8Array expected");t+=i.length}let e=new Uint8Array(t),n=0;for(let s=0;s<r.length;s++){let i=r[s];e.set(i,n),n+=i.length}return e}function Au(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 ku(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Su(r){let t;for(t=0;r>mo;r>>=Qr,t+=1);return t}function Iu(r,t){return r>>BigInt(t)&Qr}var Ru=(r,t,e)=>r|(e?Qr:mo)<<BigInt(t),xr=r=>(Eu<<BigInt(r-1))-Qr,Hs=r=>new Uint8Array(r),yo=r=>Uint8Array.from(r);function Ps(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=Hs(r),s=Hs(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=Hs())=>{s=a(yo([0]),u),n=a(),u.length!==0&&(s=a(yo([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 _u={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||_t(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Vt(r,t,e={}){let n=(s,i,o)=>{let a=_u[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),Ue=BigInt(2),Nu=BigInt(3),Ms=BigInt(4),wo=BigInt(5),xo=BigInt(8),Tu=BigInt(9),Cu=BigInt(16);function G(r,t){let e=r%t;return e>=at?e:t+e}function Lu(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 en(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 Uu(r){let t=(r-Z)/Ue,e,n,s;for(e=r-Z,n=0;e%Ue===at;e/=Ue,n++);for(s=Ue;s<r&&Lu(s,t,r)!==r-Z;s++);if(n===1){let o=(r+Z)/Ms;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)/Ue;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 Du(r){if(r%Ms===Nu){let t=(r+Z)/Ms;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%xo===wo){let t=(r-wo)/xo;return function(n,s){let i=n.mul(s,Ue),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Ue),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%Cu,Uu(r)}var Eo=(r,t)=>(G(r,t)&Z)===Z,Vu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Fs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Vu.reduce((n,s)=>(n[s]="function",n),t);return Vt(r,e)}function Ou(r,t,e){if(e<at)throw new Error("Expected power > 0");if(e===at)return r.ONE;if(e===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 Hu(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 $s(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function rn(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=$s(r,t);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=Du(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:xr(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)=>Ou(a,c,f),div:(c,f)=>G(c*en(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>en(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>Hu(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Le(c,i):ye(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return e?ge(c):zt(c)}});return Object.freeze(a)}function vo(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 Bo(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 qs(r){let t=Bo(r);return t+Math.ceil(t/2)}function Ao(r,t,e=!1){let n=r.length,s=Bo(t),i=qs(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?zt(r):ge(r),a=G(o,t-Z)+Z;return e?Le(a,s):ye(a,s)}var Pu=BigInt(0),js=BigInt(1);function nn(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>Pu;)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 Er(r){return Fs(r.Fp),Vt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...$s(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Nt=BigInt(0),vt=BigInt(1),sn=BigInt(2),Mu=BigInt(8),Fu={zip215:!0};function $u(r){let t=Er(r);return Vt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function on(r){let t=$u(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,f=sn<<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,Y=l(C*C),P=l(L*L),q=l(O*O),st=l(q*q),X=l(Y*y),ut=l(q*l(X+P)),ft=l(st+l(I*l(Y*P)));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:Y}=y,P=l(I*Y),q=l(O*L),st=l(C*Y),X=l(H*L);return P===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),Y=l(sn*l(L*L)),P=l(y*O),q=I+C,st=l(l(q*q)-O-H),X=P+H,ut=X-Y,ft=P-H,ot=l(st*ut),pt=l(X*ft),$t=l(st*ft),Se=l(ut*X);return new x(ot,pt,Se,$t)}add(y){T(y);let{a:I,d:C}=t,{ex:L,ey:O,ez:H,et:Y}=this,{ex:P,ey:q,ez:st,et:X}=y;if(I===BigInt(-1)){let Ui=l((O-L)*(q+P)),Di=l((O+L)*(q-P)),us=l(Di-Ui);if(us===Nt)return this.double();let Vi=l(H*sn*X),Oi=l(Y*sn*st),Hi=Oi+Vi,Ki=Di+Ui,Pi=Oi-Vi,Tc=l(Hi*us),Cc=l(Ki*Pi),Lc=l(Hi*Pi),Uc=l(us*Ki);return new x(Tc,Cc,Uc,Lc)}let ut=l(L*P),ft=l(O*q),ot=l(Y*C*X),pt=l(H*st),$t=l((L+O)*(P+q)-ut-ft),Se=pt-ot,gr=pt+ot,Li=l(ft-I*ut),Ic=l($t*Se),Rc=l(gr*Li),_c=l($t*Li),Nc=l(Se*gr);return new x(Ic,Rc,Nc,_c)}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(k)?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?Mu:e.inv(L));let H=l(I*y),Y=l(C*y),P=l(L*y);if(O)return{x:Nt,y:vt};if(P!==vt)throw new Error("invZ was invalid");return{x:H,y:Y}}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(),Y=y[O-1];H[O-1]=Y&-129;let P=ge(H);P===Nt||(I?m(P,f):m(P,e.ORDER));let q=l(P*P),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=(Y&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:P})}static fromPrivateKey(y){return D(y).point}toRawBytes(){let{x:y,y:I}=this.toAffine(),C=Le(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:k,ZERO:_}=x,N=nn(x,a*8);function j(v){return G(v,n)}function $(v){return j(ge(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=k.multiply(O),Y=H.toRawBytes();return{head:C,prefix:L,scalar:O,point:H,pointBytes:Y}}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 Bt(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),Y=k.multiply(H).toRawBytes(),P=et(I.context,Y,O,v),q=j(H+P*L);A(q);let st=Wt(Y,Le(q,e.BYTES));return tt("result",st,a*2)}let E=Fu;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 Y=ge(v.slice(H,2*H)),P,q,st;try{P=x.fromHex(I,O),q=x.fromHex(v.slice(0,H),O),st=k.multiplyUnsafe(Y)}catch{return!1}if(!O&&P.isSmallOrder())return!1;let X=et(L,q.toRawBytes(),P.toRawBytes(),y);return q.add(P.multiplyUnsafe(X)).subtract(st).clearCofactor().equals(x.ZERO)}return k._setWindowSize(8),{CURVE:t,getPublicKey:nt,sign:Bt,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 Gs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ko=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),n0=BigInt(0),qu=BigInt(1),Ys=BigInt(2),ju=BigInt(5),So=BigInt(10),Yu=BigInt(20),Gu=BigInt(40),Io=BigInt(80);function zu(r){let t=Gs,n=r*r%t*r%t,s=J(n,Ys,t)*n%t,i=J(s,qu,t)*r%t,o=J(i,ju,t)*i%t,a=J(o,So,t)*o%t,c=J(a,Yu,t)*a%t,f=J(c,Gu,t)*c%t,l=J(f,Io,t)*f%t,u=J(l,Io,t)*f%t,d=J(u,So,t)*o%t;return{pow_p_5_8:J(d,Ys,t)*r%t,b2:n}}function Wu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Zu(r,t){let e=Gs,n=G(t*t*t,e),s=G(n*n*t,e),i=zu(r*s).pow_p_5_8,o=G(r*n*i,e),a=G(t*o*o,e),c=o,f=G(o*ko,e),l=a===r,u=a===G(-r,e),d=a===G(-r*ko,e);return l&&(o=c),(u||d)&&(o=f),Eo(o,e)&&(o=G(-o,e)),{isValid:l||u,value:o}}var Zt=rn(Gs,void 0,!0),zs={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:pe,randomBytes:Qe,adjustScalarBytes:Wu,uvRatio:Zu},tr=on(zs);function Ro(r,t,e){if(t.length>255)throw new Error("Context is too big");return Jr(Ds("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var s0=on({...zs,domain:Ro}),i0=on({...zs,domain:Ro,prehash:pe});var Ju=(Zt.ORDER+BigInt(3))/BigInt(8),o0=Zt.pow(Ys,Ju),a0=Zt.sqrt(Zt.neg(Zt.ONE)),c0=(Zt.ORDER-BigInt(5))/BigInt(8),l0=BigInt(486662);var u0=vo(Zt,Zt.neg(BigInt(486664)));var f0=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),h0=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),d0=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),p0=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var g0=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var er=32,Jt=64,an=32;function _o(){let r=tr.utils.randomPrivateKey(),t=tr.getPublicKey(r);return{privateKey:Lo(r,t),publicKey:t}}function No(r){if(r.length!==an)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=tr.getPublicKey(t);return{privateKey:Lo(t,e),publicKey:e}}function To(r,t){let e=r.subarray(0,an);return tr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Co(r,t,e){return tr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Lo(r,t){let e=new Uint8Array(Jt);for(let n=0;n<an;n++)e[n]=r[n],e[an+n]=t[n];return e}var Ws={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function cn(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",Ws,{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",Ws,{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 vs([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",Ws,{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 rr(r,t){let n=await cn().encrypt(r,t);return _e.encode(n)}var Zs=new Float32Array([-0]),me=new Uint8Array(Zs.buffer);function Do(r,t,e){Zs[0]=r,t[e]=me[0],t[e+1]=me[1],t[e+2]=me[2],t[e+3]=me[3]}function Vo(r,t){return me[0]=r[t],me[1]=r[t+1],me[2]=r[t+2],me[3]=r[t+3],Zs[0]}var Js=new Float64Array([-0]),gt=new Uint8Array(Js.buffer);function Oo(r,t,e){Js[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 Ho(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],Js[0]}var Qu=BigInt(Number.MAX_SAFE_INTEGER),tf=BigInt(Number.MIN_SAFE_INTEGER),xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return De;if(t<Qu&&t>tf)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>Ko&&(s=0n,++n>Ko&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return De;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):De}},De=new xt(0,0);De.toBigInt=function(){return 0n};De.zzEncode=De.zzDecode=function(){return this};De.length=function(){return 1};var Ko=4294967296n;function Po(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 Mo(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 Xs(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 ln(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Qs=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Tt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Tt(this,4);return ln(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return ln(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Vo(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=Ho(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 Mo(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 xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw 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=ln(this.buf,this.pos+=4),e=ln(this.buf,this.pos+=4);return new xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){return this.readLongVarint().toNumber(!0)}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function ti(r){return new Qs(r instanceof Uint8Array?r:r.subarray())}function un(r,t){let e=ti(r);return t.decode(e)}function ei(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return jt(o);s+o>t&&(n=jt(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var Ve=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ri(){}var si=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},ef=ei();function rf(r){return globalThis.Buffer!=null?jt(r):ef(r)}var Ar=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ve(ri,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ve(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ii((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(vr,10,xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=xt.fromBigInt(t);return this._push(vr,e.length(),e)}uint64Number(t){let e=xt.fromNumber(t);return this._push(vr,e.length(),e)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=xt.fromBigInt(t).zzEncode();return this._push(vr,e.length(),e)}sint64Number(t){let e=xt.fromNumber(t).zzEncode();return this._push(vr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(ni,1,t?1:0)}fixed32(t){return this._push(Br,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=xt.fromBigInt(t);return this._push(Br,4,e.lo)._push(Br,4,e.hi)}fixed64Number(t){let e=xt.fromNumber(t);return this._push(Br,4,e.lo)._push(Br,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(Do,4,t)}double(t){return this._push(Oo,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(ni,1,0):this.uint32(e)._push(sf,e,t)}string(t){let e=Po(t);return e!==0?this.uint32(e)._push(Xs,e,t):this._push(ni,1,0)}fork(){return this.states=new si(this),this.head=this.tail=new Ve(ri,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 Ve(ri,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=rf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function ni(r,t,e){t[e]=r&255}function nf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ii=class extends Ve{next;constructor(t,e){super(nf,t,e),this.next=void 0}};function vr(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 Br(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 sf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Ar.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(of,t,r),this},Ar.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(af,t,r),this});function of(r,t,e){t.set(r,e)}function af(r,t,e){r.length<40?Xs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function oi(){return new Ar}function fn(r,t){let e=oi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var nr;(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"})(nr||(nr={}));function hn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ai(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 hn("enum",nr.VARINT,e,n)}function dn(r,t){return hn("message",nr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(rt||(rt={}));var ci;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(ci||(ci={}));(function(r){r.codec=()=>ai(ci)})(rt||(rt={}));var Xt;(function(r){let t;r.codec=()=>(t==null&&(t=dn((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=>fn(e,r.codec()),r.decode=e=>un(e,r.codec())})(Xt||(Xt={}));var Ot;(function(r){let t;r.codec=()=>(t==null&&(t=dn((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=>fn(e,r.codec()),r.decode=e=>un(e,r.codec())})(Ot||(Ot={}));var kr=class{_key;constructor(t){this._key=sr(t,er)}verify(t,e){return Co(this._key,e,t)}marshal(){return this._key}get bytes(){return Xt.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return At(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}},Oe=class{_key;_publicKey;constructor(t,e){this._key=sr(t,Jt),this._publicKey=sr(e,er)}sign(t){return To(this._key,t)}get public(){return new kr(this._publicKey)}marshal(){return this._key}get bytes(){return Ot.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return At(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 rr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function cf(r){if(r.length>Jt){r=sr(r,Jt+er);let n=r.subarray(0,Jt),s=r.subarray(Jt,r.length);return new Oe(n,s)}r=sr(r,Jt);let t=r.subarray(0,Jt),e=r.subarray(er);return new Oe(t,e)}function lf(r){return r=sr(r,er),new kr(r)}async function uf(){let{privateKey:r,publicKey:t}=_o();return new Oe(r,t)}async function $o(r){let{privateKey:t,publicKey:e}=No(r);return new Oe(t,e)}function sr(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=zr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):e.encoder.encode(r).substring(1)}async function qo(r,t){let e=_e.decode(r);return cn().decrypt(e,t)}var xi={};ct(xi,{MAX_RSA_KEY_SIZE:()=>Or,RsaPrivateKey:()=>lr,RsaPublicKey:()=>Vr,fromJwk:()=>Uf,generateKeyPair:()=>Df,unmarshalRsaPrivateKey:()=>bi,unmarshalRsaPublicKey:()=>Lf});function Ht(r){if(isNaN(r)||r<=0)throw new B("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Qe(r)}var Ee={};ct(Ee,{exportToPem:()=>_f,importFromPem:()=>mi,jwkToPkcs1:()=>kf,jwkToPkix:()=>If,pkcs1ToJwk:()=>Af,pkixToJwk:()=>Sf});var gn=class extends Je{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Wr(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 Ze(this),this.iHash.update(t),this}digestInto(t){Ze(this),Us(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()}},Sr=(r,t,e)=>new gn(r,t).update(e).digest();Sr.create=(r,t)=>new gn(r,t);function jo(r,t,e,n){Wr(r);let s=ho({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(We(i),We(o),We(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ue(t),f=ue(e),l=new Uint8Array(o),u=Sr.create(r,c),d=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:a,DK:l,PRF:u,PRFSalt:d}}function Yo(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Go(r,t,e,n){let{c:s,dkLen:i,DK:o,PRF:a,PRFSalt:c}=jo(r,t,e,n),f,l=new Uint8Array(4),u=Te(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 Yo(a,c,o,f,d)}async function ui(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=jo(r,t,e,n),l,u=new Uint8Array(4),d=Te(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 fo(s-1,o,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<g.length;m++)g[m]^=w[m]})}return Yo(c,f,a,l,w)}var K=fs(zo());function He(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function be(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 bn(...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 hi(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=He(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,He(i,8)-n}function Wo(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=be(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=be(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 Zo(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 Ep=Math.log(2);function wn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function di(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 Rr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return di(this.items)}},Ir=[new Uint8Array([1])],Jo="0123456789";var ar="",Lt=new ArrayBuffer(0),pi=new Uint8Array(0),_r="EndOfContent",Qo="OCTET STRING",ta="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?K.BufferSourceConverter.toUint8Array(i.valueHex):pi}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:K.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{constructor({blockLength:t=0,error:e=ar,warnings:n=[],valueBeforeDecode:s=pi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=K.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:K.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 xn=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?K.BufferSourceConverter.toUint8Array(t.valueHex):pi,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=be(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=K.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=He(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}}};xn.NAME="identificationBlock";var En=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=K.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=He(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=be(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}}};En.NAME="lengthBlock";var S={},dt=class extends te{constructor({name:t=ar,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new xn(s),this.lenBlock=new En(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 Rr;e||ea(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():K.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${K.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 Zo(e,n)}};dt.NAME="BaseBlock";function ea(r){if(r instanceof S.Constructed)for(let t of r.valueBlock.value)ea(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var vn=class extends dt{constructor({value:t=ar,...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}'`}};vn.NAME="BaseStringBlock";var Bn=class extends se(yt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Bn.NAME="PrimitiveValueBlock";var ra,An=class extends dt{constructor(t={}){super(t,Bn),this.idBlock.isConstructed=!1}};ra=An;S.Primitive=ra;An.NAME="PRIMITIVE";function wf(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 ns(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=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let f=s.idBlock.isConstructed?new S.Constructed:new S.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?S.Constructed:S.Primitive}return s=wf(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 cr(r){if(!r.byteLength){let t=new dt({},yt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ns(K.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function xf(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=K.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(;xf(this.isIndefiniteForm,n)>0;){let o=ns(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===_r)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===_r?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Rr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?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 na,we=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 qc=Object.create;var zr=Object.defineProperty;var jc=Object.getOwnPropertyDescriptor;var Yc=Object.getOwnPropertyNames;var Gc=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)zr(r,e,{get:t[e],enumerable:!0})},qi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Yc(t))!zc.call(r,s)&&s!==e&&zr(r,s,{get:()=>t[s],enumerable:!(n=jc(t,s))||n.enumerable});return r};var ps=(r,t,e)=>(e=r!=null?qc(Gc(r)):{},qi(t||!r||!r.__esModule?zr(e,"default",{value:r,enumerable:!0}):e,r)),Wc=r=>qi(zr({},"__esModule",{value:!0}),r);var na=_e(ar=>{"use strict";var Bf="[object ArrayBuffer]",te=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}},pi="string",Af=/^[0-9a-f]+$/i,kf=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Sf=/^[a-zA-Z0-9-_]+$/,wn=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=te.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},It=class{static toString(t,e=!1){let n=te.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}},xn=class r{static isHex(t){return typeof t===pi&&Af.test(t)}static isBase64(t){return typeof t===pi&&kf.test(t)}static isBase64Url(t){return typeof t===pi&&Sf.test(t)}static ToString(t,e="utf8"){let n=te.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return 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=te.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return wn.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 wn.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=te.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=te.toUint8Array(t),n="",s=e.length;for(let 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,"")||""}};xn.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}ar.BufferSourceConverter=te;ar.Convert=xn;ar.assign=If;ar.combine=Rf;ar.isEqual=_f});var yc=_e((oy,gc)=>{"use strict";gc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var vc=_e((xc,Ec)=>{"use strict";var us=yc(),{hasOwnProperty:bc}=Object.prototype,{propertyIsEnumerable:wh}=Object,gr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),xh=xc,mc={concatArrays:!1,ignoreUndefined:!1},fs=r=>{let t=[];for(let e in r)bc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)wh.call(r,n)&&t.push(n)}return t};function yr(r){return Array.isArray(r)?Eh(r):us(r)?vh(r):r}function Eh(r){let t=r.slice(0,0);return fs(r).forEach(e=>{gr(t,e,yr(r[e]))}),t}function vh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return fs(r).forEach(e=>{gr(t,e,yr(r[e]))}),t}var wc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?gr(r,s,Ui(r[s],t[s],n)):gr(r,s,yr(t[s])))}),r),Bh=(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++)bc.call(i,a)&&(o.push(String(a)),i===r?gr(n,s++,i[a]):gr(n,s++,yr(i[a])));n=wc(n,i,fs(i).filter(a=>!o.includes(a)),e)}),n};function Ui(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Bh(r,t,e):!us(t)||!us(r)?yr(t):wc(r,t,fs(t),e)}Ec.exports=function(...r){let t=Ui(yr(mc),this!==xh&&this||{},mc),e={_:{}};for(let n of r)if(n!==void 0){if(!us(n))throw new TypeError("`"+n+"` is not an Option Object");e=Ui(e,{_:n},t)}return e._}});var Sc=_e((cy,kc)=>{"use strict";function Ah(r){return r>=55296&&r<=56319}function kh(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],Ah(o)&&kh(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 Rc=_e((ly,Ic)=>{"use strict";function Sh(r){return r>=55296&&r<=56319}function Ih(r){return r>=56320&&r<=57343}Ic.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),Ih(s)?i!=null&&Sh(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 Nc=_e((uy,_c)=>{"use strict";var Rh=Sc(),_h=Rc();_c.exports=Rh.bind(null,_h)});var Lc=_e((fy,Cc)=>{"use strict";var Nh=Nc(),Th=/[\/\?<>\\:\*\|"]/g,Ch=/[\x00-\x1f\x80-\x9f]/g,Lh=/^\.+$/,Uh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Dh=/[\. ]+$/;function Tc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Th,t).replace(Ch,t).replace(Lh,t).replace(Uh,t).replace(Dh,t);return Nh(e,255)}Cc.exports=function(r,t){var e=t&&t.replacement||"",n=Tc(r,e);return e===""?n:Tc(n,"")}});var Hh={};ct(Hh,{keychain:()=>Oh});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 ji=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 hi={};ct(hi,{Ed25519PrivateKey:()=>Ke,Ed25519PublicKey:()=>Ir,generateKeyPair:()=>vf,generateKeyPairFromSeed:()=>Xo,unmarshalEd25519PrivateKey:()=>xf,unmarshalEd25519PublicKey:()=>Ef});var ws={};ct(ws,{base58btc:()=>bt,base58flickr:()=>el});var $h=new Uint8Array(0);function Yi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Yt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Gi(r){return new TextEncoder().encode(r)}function zi(r){return new TextDecoder().decode(r)}function Zc(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],k=0,_=b-1;(x!==0||k<g)&&_!==-1;_--,k++)x+=256*T[_]>>>0,T[_]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");g=k,m++}for(var N=b-g;N!==b&&T[N]===0;)N++;for(var j=c.repeat(h);N<b;++N)j+=r.charAt(T[N]);return j}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,k=A-1;(T!==0||x<m)&&k!==-1;k--,x++)T+=a*b[k]>>>0,b[k]=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-_)),j=g;_!==A;)N[j++]=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 Jc=Zc,Xc=Jc,Zi=Xc;var gs=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")}},ys=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 Ji(this,t)}},ms=class{decoders;constructor(t){this.decoders=t}or(t){return Ji(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 Ji(r,t){return new ms({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var bs=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 gs(t,e,n),this.decoder=new ys(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function qe({name:r,prefix:t,encode:e,decode:n}){return new bs(r,t,e,n)}function le({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Zi(e,r);return qe({prefix:t,name:r,encode:n,decode:i=>Yt(s(i))})}function Qc(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 tl(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 qe({prefix:t,name:r,encode(s){return tl(s,n,e)},decode(s){return Qc(s,n,e,r)}})}var bt=le({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),el=le({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Es={};ct(Es,{identity:()=>ue});var rl=to,Xi=128,nl=127,sl=~nl,il=Math.pow(2,31);function to(r,t,e){t=t||[],e=e||0;for(var n=e;r>=il;)t[e++]=r&255|Xi,r/=128;for(;r&sl;)t[e++]=r&255|Xi,r>>>=7;return t[e]=r|0,to.bytes=e-n+1,t}var ol=xs,al=128,Qi=127;function xs(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw xs.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&Qi)<<s:(o&Qi)*Math.pow(2,s),s+=7}while(o>=al);return xs.bytes=i-n,e}var cl=Math.pow(2,7),ll=Math.pow(2,14),ul=Math.pow(2,21),fl=Math.pow(2,28),hl=Math.pow(2,35),dl=Math.pow(2,42),pl=Math.pow(2,49),gl=Math.pow(2,56),yl=Math.pow(2,63),ml=function(r){return r<cl?1:r<ll?2:r<ul?3:r<fl?4:r<hl?5:r<dl?6:r<pl?7:r<gl?8:r<yl?9:10},bl={encode:rl,decode:ol,encodingLength:ml},wl=bl,br=wl;function wr(r,t=0){return[br.decode(r,t),br.decode.bytes]}function je(r,t,e=0){return br.encode(r,t,e),t}function Ye(r){return br.encodingLength(r)}function Vt(r,t){let e=t.byteLength,n=Ye(r),s=n+Ye(e),i=new Uint8Array(s+e);return je(r,i,0),je(e,i,n),i.set(t,s),new Ge(r,e,t,i)}function xr(r){let t=Yt(r),[e,n]=wr(t),[s,i]=wr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new Ge(e,s,o,t)}function eo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Yi(r.bytes,e.bytes)}}var Ge=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var ro=0,xl="identity",no=Yt;function El(r){return Vt(ro,no(r))}var ue={code:ro,name:xl,encode:no,digest:El};var As={};ct(As,{sha256:()=>ht,sha512:()=>vl});function Bs({name:r,code:t,encode:e}){return new vs(r,t,e)}var vs=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Vt(this.code,e):e.then(n=>Vt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function io(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ht=Bs({name:"sha2-256",code:18,encode:io("SHA-256")}),vl=Bs({name:"sha2-512",code:19,encode:io("SHA-512")});function kt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Ne(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function Ot(r=0){return globalThis.Buffer?.allocUnsafe!=null?Ne(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}function ks(r,t){if(globalThis.Buffer!=null)return Ne(globalThis.Buffer.concat(r,t));t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=Ot(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return Ne(e)}var Ss={};ct(Ss,{base10:()=>Bl});var Bl=le({prefix:"9",name:"base10",alphabet:"0123456789"});var Is={};ct(Is,{base16:()=>Al,base16upper:()=>kl});var Al=Q({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),kl=Q({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Rs={};ct(Rs,{base2:()=>Sl});var Sl=Q({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var _s={};ct(_s,{base256emoji:()=>Tl});var oo=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}"),Il=oo.reduce((r,t,e)=>(r[e]=t,r),[]),Rl=oo.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function _l(r){return r.reduce((t,e)=>(t+=Il[e],t),"")}function Nl(r){let t=[];for(let e of r){let n=Rl[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Tl=qe({prefix:"\u{1F680}",name:"base256emoji",encode:_l,decode:Nl});var Ns={};ct(Ns,{base32:()=>We,base32hex:()=>Dl,base32hexpad:()=>Ol,base32hexpadupper:()=>Hl,base32hexupper:()=>Vl,base32pad:()=>Ll,base32padupper:()=>Ul,base32upper:()=>Cl,base32z:()=>Kl});var We=Q({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Cl=Q({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ll=Q({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Ul=Q({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Dl=Q({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Vl=Q({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Ol=Q({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Hl=Q({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Kl=Q({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ts={};ct(Ts,{base36:()=>Pl,base36upper:()=>Ml});var Pl=le({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ml=le({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Cs={};ct(Cs,{base64:()=>Te,base64pad:()=>Fl,base64url:()=>$l,base64urlpad:()=>ql});var Te=Q({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Fl=Q({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),$l=Q({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ql=Q({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ls={};ct(Ls,{base8:()=>jl});var jl=Q({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Us={};ct(Us,{identity:()=>Yl});var Yl=qe({prefix:"\0",name:"identity",encode:r=>zi(r),decode:r=>Gi(r)});var md=new TextEncoder,bd=new TextDecoder;function ao(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Zl(e,Ds(r),t??bt.encoder);default:return Jl(e,Ds(r),t??We.encoder)}}var co=new WeakMap;function Ds(r){let t=co.get(r);if(t==null){let e=new Map;return co.set(r,e),e}return t}var Ce=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!==Er)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Xl)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Vt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&eo(t.multihash,n.multihash)}toString(t){return ao(this,t)}toJSON(){return{"/":ao(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??lo(n,s,i.bytes))}else if(e[Ql]===!0){let{version:n,multihash:s,code:i}=e,o=xr(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!==Er)throw new Error(`Version 0 CID must use dag-pb (code: ${Er}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=lo(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Er,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=Yt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new Ge(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]=wr(t.subarray(e));return e+=d,u},s=n(),i=Er;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]=Wl(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 Ds(i).set(n,t),i}};function Wl(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 We.prefix:{let e=t??We;return[We.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 Zl(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 Jl(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 Er=112,Xl=18;function lo(r,t,e){let n=Ye(r),s=n+Ye(t),i=new Uint8Array(s+e.byteLength);return je(r,i,0),je(t,i,n),i.set(e,s),i}var Ql=Symbol.for("@ipld/js-cid/CID");var Ze={...Us,...Rs,...Ls,...Ss,...Is,...Ns,...Ts,...ws,...Cs,..._s},Ud={...As,...Es};function fo(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var uo=fo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Vs=fo("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Ot(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),tu={utf8:uo,"utf-8":uo,hex:Ze.base16,latin1:Vs,ascii:Vs,binary:Vs,...Ze},Zr=tu;function F(r,t="utf8"){let e=Zr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Ne(globalThis.Buffer.from(r,"utf-8")):e.decoder.decode(`${e.prefix}${r}`)}function St(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Je(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function eu(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Os(r,...t){if(!eu(r))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(r.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${r.length}`)}function Jr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Je(r.outputLen),Je(r.blockLen)}function 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 ho(r,t){Os(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Xr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function po(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Le=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),_t=(r,t)=>r<<32-t|r>>>t,ru=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!ru)throw new Error("Non little-endian hardware is not supported");var nu=async()=>{};async function go(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 Hs(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function fe(r){if(typeof r=="string"&&(r=Hs(r)),!po(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function Qr(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];if(!po(s))throw new Error("Uint8Array expected");t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var Qe=class{clone(){return this._cloneInto()}},su={}.toString;function yo(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(fe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function er(r=32){if(Xr&&typeof Xr.getRandomValues=="function")return Xr.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 he=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=Le(this.buffer)}update(t){Xe(this);let{view:e,buffer:n,blockLen:s}=this;t=fe(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=Le(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),ho(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=Le(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 tn=BigInt(4294967295),Ks=BigInt(32);function mo(r,t=!1){return t?{h:Number(r&tn),l:Number(r>>Ks&tn)}:{h:Number(r>>Ks&tn)|0,l:Number(r&tn)|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}=mo(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var au=(r,t)=>BigInt(r>>>0)<<Ks|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,ku=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Su=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var Iu={fromBig:mo,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:Su,add5L:ku},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))),de=new Uint32Array(80),pe=new Uint32Array(80),Ps=class extends he{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)de[b]=t.getUint32(e),pe[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let T=de[b-15]|0,x=pe[b-15]|0,k=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=de[b-2]|0,j=pe[b-2]|0,$=U.rotrSH(N,j,19)^U.rotrBH(N,j,61)^U.shrSH(N,j,6),D=U.rotrSL(N,j,19)^U.rotrBL(N,j,61)^U.shrSL(N,j,6),nt=U.add4L(_,D,pe[b-7],pe[b-16]),et=U.add4H(nt,k,$,de[b-7],de[b-16]);de[b]=et|0,pe[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),k=u&w^~u&h,_=d&p^~d&g,N=U.add5L(A,x,_,_u[b],pe[b]),j=U.add5H(N,m,T,k,Ru[b],de[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,j|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,j,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(){de.fill(0),pe.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 ge=tr(()=>new Ps);var rn={};ct(rn,{bitGet:()=>Vu,bitLen:()=>Du,bitMask:()=>vr,bitSet:()=>Ou,bytesToHex:()=>zt,bytesToNumberBE:()=>Wt,bytesToNumberLE:()=>ye,concatBytes:()=>Zt,createHmacDrbg:()=>$s,ensureBytes:()=>tt,equalBytes:()=>Lu,hexToBytes:()=>Ue,hexToNumber:()=>Fs,isBytes:()=>Nt,numberToBytesBE:()=>me,numberToBytesLE:()=>De,numberToHexUnpadded:()=>Eo,numberToVarBytesBE:()=>Cu,utf8ToBytes:()=>Uu,validateObject:()=>Ht});var xo=BigInt(0),en=BigInt(1),Nu=BigInt(2);function Nt(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var Tu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function zt(r){if(!Nt(r))throw new Error("Uint8Array expected");let t="";for(let e=0;e<r.length;e++)t+=Tu[r[e]];return t}function Eo(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Fs(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Gt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function bo(r){if(r>=Gt._0&&r<=Gt._9)return r-Gt._0;if(r>=Gt._A&&r<=Gt._F)return r-(Gt._A-10);if(r>=Gt._a&&r<=Gt._f)return r-(Gt._a-10)}function Ue(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=bo(r.charCodeAt(i)),a=bo(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 Wt(r){return Fs(zt(r))}function ye(r){if(!Nt(r))throw new Error("Uint8Array expected");return Fs(zt(Uint8Array.from(r).reverse()))}function me(r,t){return Ue(r.toString(16).padStart(t*2,"0"))}function De(r,t){return me(r,t).reverse()}function Cu(r){return Ue(Eo(r))}function tt(r,t,e){let n;if(typeof t=="string")try{n=Ue(t)}catch(i){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${i}`)}else if(Nt(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 Zt(...r){let t=0;for(let s=0;s<r.length;s++){let i=r[s];if(!Nt(i))throw new Error("Uint8Array expected");t+=i.length}let e=new Uint8Array(t),n=0;for(let s=0;s<r.length;s++){let i=r[s];e.set(i,n),n+=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>xo;r>>=en,t+=1);return t}function Vu(r,t){return r>>BigInt(t)&en}var Ou=(r,t,e)=>r|(e?en:xo)<<BigInt(t),vr=r=>(Nu<<BigInt(r-1))-en,Ms=r=>new Uint8Array(r),wo=r=>Uint8Array.from(r);function $s(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Ms(r),s=Ms(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=Ms())=>{s=a(wo([0]),u),n=a(),u.length!==0&&(s=a(wo([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 Zt(...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"||Nt(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ht(r,t,e={}){let n=(s,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),Ve=BigInt(2),Ku=BigInt(3),qs=BigInt(4),vo=BigInt(5),Bo=BigInt(8),Pu=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 nn(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)/Ve,e,n,s;for(e=r-Z,n=0;e%Ve===at;e/=Ve,n++);for(s=Ve;s<r&&Fu(s,t,r)!==r-Z;s++);if(n===1){let o=(r+Z)/qs;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)/Ve;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%qs===Ku){let t=(r+Z)/qs;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%Bo===vo){let t=(r-vo)/Bo;return function(n,s){let i=n.mul(s,Ve),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,Ve),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 Ao=(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 js(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=ju.reduce((n,s)=>(n[s]="function",n),t);return Ht(r,e)}function 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 Ys(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function sn(r,t,e=!1,n={}){if(r<=at)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Ys(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:vr(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*nn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>nn(c,r),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>Gu(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?De(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):Wt(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 So(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 Gs(r){let t=So(r);return t+Math.ceil(t/2)}function Io(r,t,e=!1){let n=r.length,s=So(t),i=Gs(t);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=e?Wt(r):ye(r),a=G(o,t-Z)+Z;return e?De(a,s):me(a,s)}var Wu=BigInt(0),zs=BigInt(1);function on(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&zs&&(o=o.add(a)),a=a.double(),i>>=zs;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+=zs);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 Br(r){return js(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ys(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Tt=BigInt(0),vt=BigInt(1),an=BigInt(2),Zu=BigInt(8),Ju={zip215:!0};function Xu(r){let t=Br(r);return Ht(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function cn(r){let t=Xu(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,f=an<<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:Tt}}}),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"&&Tt<v,h=(v,y)=>p(v)&&p(y)&&v<y,g=v=>v===Tt||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===Tt?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,Y=l(C*C),P=l(L*L),q=l(O*O),st=l(q*q),X=l(Y*y),ut=l(q*l(X+P)),ft=l(st+l(I*l(Y*P)));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:Y}=y,P=l(I*Y),q=l(O*L),st=l(C*Y),X=l(H*L);return P===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),Y=l(an*l(L*L)),P=l(y*O),q=I+C,st=l(l(q*q)-O-H),X=P+H,ut=X-Y,ft=P-H,ot=l(st*ut),pt=l(X*ft),jt=l(st*ft),Re=l(ut*X);return new x(ot,pt,Re,jt)}add(y){T(y);let{a:I,d:C}=t,{ex:L,ey:O,ez:H,et:Y}=this,{ex:P,ey:q,ez:st,et:X}=y;if(I===BigInt(-1)){let Oi=l((O-L)*(q+P)),Hi=l((O+L)*(q-P)),ds=l(Hi-Oi);if(ds===Tt)return this.double();let Ki=l(H*an*X),Pi=l(Y*an*st),Mi=Pi+Ki,Fi=Hi+Oi,$i=Pi-Ki,Pc=l(Mi*ds),Mc=l(Fi*$i),Fc=l(Mi*$i),$c=l(ds*Fi);return new x(Pc,Mc,$c,Fc)}let ut=l(L*P),ft=l(O*q),ot=l(Y*C*X),pt=l(H*st),jt=l((L+O)*(P+q)-ut-ft),Re=pt-ot,mr=pt+ot,Vi=l(ft-I*ut),Vc=l(jt*Re),Oc=l(mr*Vi),Hc=l(jt*Vi),Kc=l(Re*mr);return new x(Vc,Oc,Kc,Hc)}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===Tt?_:this.equals(_)||I===vt?this:this.equals(k)?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),Y=l(C*y),P=l(L*y);if(O)return{x:Tt,y:vt};if(P!==vt)throw new Error("invZ was invalid");return{x:H,y:Y}}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(),Y=y[O-1];H[O-1]=Y&-129;let P=ye(H);P===Tt||(I?m(P,f):m(P,e.ORDER));let q=l(P*P),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=(Y&128)!==0;if(!I&&ft===Tt&&pt)throw new Error("Point.fromHex: x=0 and x_0=1");return pt!==ot&&(ft=l(-ft)),x.fromAffine({x:ft,y:P})}static fromPrivateKey(y){return D(y).point}toRawBytes(){let{x:y,y:I}=this.toAffine(),C=De(I,e.BYTES);return C[C.length-1]|=y&vt?128:0,C}toHex(){return zt(this.toRawBytes())}}x.BASE=new x(t.Gx,t.Gy,vt,l(t.Gx*t.Gy)),x.ZERO=new x(Tt,vt,vt,Tt);let{BASE:k,ZERO:_}=x,N=on(x,a*8);function j(v){return G(v,n)}function $(v){return j(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=k.multiply(O),Y=H.toRawBytes();return{head:C,prefix:L,scalar:O,point:H,pointBytes:Y}}function nt(v){return D(v).pointBytes}function et(v=new Uint8Array,...y){let I=Zt(...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),Y=k.multiply(H).toRawBytes(),P=et(I.context,Y,O,v),q=j(H+P*L);A(q);let st=Zt(Y,De(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 Y=ye(v.slice(H,2*H)),P,q,st;try{P=x.fromHex(I,O),q=x.fromHex(v.slice(0,H),O),st=k.multiplyUnsafe(Y)}catch{return!1}if(!O&&P.isSmallOrder())return!1;let X=et(L,q.toRawBytes(),P.toRawBytes(),y);return q.add(P.multiplyUnsafe(X)).subtract(st).clearCofactor().equals(x.ZERO)}return k._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 Zs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ro=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),g0=BigInt(0),Qu=BigInt(1),Ws=BigInt(2),tf=BigInt(5),_o=BigInt(10),ef=BigInt(20),rf=BigInt(40),No=BigInt(80);function nf(r){let t=Zs,n=r*r%t*r%t,s=J(n,Ws,t)*n%t,i=J(s,Qu,t)*r%t,o=J(i,tf,t)*i%t,a=J(o,_o,t)*o%t,c=J(a,ef,t)*a%t,f=J(c,rf,t)*c%t,l=J(f,No,t)*f%t,u=J(l,No,t)*f%t,d=J(u,_o,t)*o%t;return{pow_p_5_8:J(d,Ws,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=Zs,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*Ro,e),l=a===r,u=a===G(-r,e),d=a===G(-r*Ro,e);return l&&(o=c),(u||d)&&(o=f),Ao(o,e)&&(o=G(-o,e)),{isValid:l||u,value:o}}var Jt=sn(Zs,void 0,!0),Js={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Jt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ge,randomBytes:er,adjustScalarBytes:sf,uvRatio:of},rr=cn(Js);function To(r,t,e){if(t.length>255)throw new Error("Context is too big");return Qr(Hs("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var y0=cn({...Js,domain:To}),m0=cn({...Js,domain:To,prehash:ge});var af=(Jt.ORDER+BigInt(3))/BigInt(8),b0=Jt.pow(Ws,af),w0=Jt.sqrt(Jt.neg(Jt.ONE)),x0=(Jt.ORDER-BigInt(5))/BigInt(8),E0=BigInt(486662);var v0=ko(Jt,Jt.neg(BigInt(486664)));var B0=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),A0=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),k0=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),S0=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var I0=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var nr=32,Xt=64,ln=32;function Co(){let r=rr.utils.randomPrivateKey(),t=rr.getPublicKey(r);return{privateKey:Vo(r,t),publicKey:t}}function Lo(r){if(r.length!==ln)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=rr.getPublicKey(t);return{privateKey:Vo(t,e),publicKey:e}}function Uo(r,t){let e=r.subarray(0,ln);return rr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Do(r,t,e){return rr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Vo(r,t){let e=new Uint8Array(Xt);for(let n=0;n<ln;n++)e[n]=r[n],e[ln+n]=t[n];return e}var Xs={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function un(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",Xs,{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",Xs,{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 ks([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",Xs,{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 sr(r,t){let n=await un().encrypt(r,t);return Te.encode(n)}var lf=Math.pow(2,7),uf=Math.pow(2,14),ff=Math.pow(2,21),Ho=Math.pow(2,28),Ko=Math.pow(2,35),Po=Math.pow(2,42),Mo=Math.pow(2,49),wt=128,be=127;function Ar(r){if(r<lf)return 1;if(r<uf)return 2;if(r<ff)return 3;if(r<Ho)return 4;if(r<Ko)return 5;if(r<Po)return 6;if(r<Mo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Fo(r,t,e=0){switch(Ar(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 $o(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)*Ho,e<wt)||(e=r[t+5],n+=(e&be)*Ko,e<wt)||(e=r[t+6],n+=(e&be)*Po,e<wt)||(e=r[t+7],n+=(e&be)*Mo,e<wt))return n;throw new RangeError("Could not decode varint")}var Qs=new Float32Array([-0]),we=new Uint8Array(Qs.buffer);function qo(r,t,e){Qs[0]=r,t[e]=we[0],t[e+1]=we[1],t[e+2]=we[2],t[e+3]=we[3]}function jo(r,t){return we[0]=r[t],we[1]=r[t+1],we[2]=r[t+2],we[3]=r[t+3],Qs[0]}var ti=new Float64Array([-0]),gt=new Uint8Array(ti.buffer);function Yo(r,t,e){ti[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 Go(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],ti[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 Oe;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>zo&&(s=0n,++n>zo&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Oe;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):Oe}},Oe=new Bt(0,0);Oe.toBigInt=function(){return 0n};Oe.zzEncode=Oe.zzDecode=function(){return this};Oe.length=function(){return 1};var zo=4294967296n;function Wo(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 Zo(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 ei(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 Ct(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function fn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ri=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Ct(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Ct(this,4);return fn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ct(this,4);return fn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ct(this,4);let t=jo(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ct(this,4);let t=Go(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Ct(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Zo(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ct(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ct(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new 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 Ct(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Ct(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Ct(this,8);let t=fn(this.buf,this.pos+=4),e=fn(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=$o(this.buf,this.pos);return this.pos+=Ar(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 ni(r){return new ri(r instanceof Uint8Array?r:r.subarray())}function hn(r,t,e){let n=ni(r);return t.decode(n,void 0,e)}function si(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return Ot(o);s+o>t&&(n=Ot(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var He=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ii(){}var ai=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},pf=si();function gf(r){return globalThis.Buffer!=null?Ot(r):pf(r)}var Sr=class{len;head;tail;states;constructor(){this.len=0,this.head=new He(ii,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new He(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ci((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(dn,10,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(dn,e.length(),e)}uint64Number(t){return this._push(Fo,Ar(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(dn,e.length(),e)}sint64Number(t){let e=Bt.fromNumber(t).zzEncode();return this._push(dn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(oi,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(qo,4,t)}double(t){return this._push(Yo,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(oi,1,0):this.uint32(e)._push(mf,e,t)}string(t){let e=Wo(t);return e!==0?this.uint32(e)._push(ei,e,t):this._push(oi,1,0)}fork(){return this.states=new ai(this),this.head=this.tail=new He(ii,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 He(ii,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 oi(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 ci=class extends He{next;constructor(t,e){super(yf,t,e),this.next=void 0}};function dn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function 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&&(Sr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(bf,t,r),this},Sr.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?ei(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(F(r),e)}function li(){return new Sr}function pn(r,t){let e=li();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ir;(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"})(ir||(ir={}));function gn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ui(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 gn("enum",ir.VARINT,e,n)}function yn(r,t){return gn("message",ir.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(rt||(rt={}));var fi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(fi||(fi={}));(function(r){r.codec=()=>ui(fi)})(rt||(rt={}));var Qt;(function(r){let t;r.codec=()=>(t==null&&(t=yn((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=>pn(e,r.codec()),r.decode=e=>hn(e,r.codec())})(Qt||(Qt={}));var Kt;(function(r){let t;r.codec=()=>(t==null&&(t=yn((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=>pn(e,r.codec()),r.decode=e=>hn(e,r.codec())})(Kt||(Kt={}));var Ir=class{_key;constructor(t){this._key=or(t,nr)}verify(t,e){return Do(this._key,e,t)}marshal(){return this._key}get bytes(){return Qt.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return St(t)?t.then(({bytes:e})=>e):t.bytes}},Ke=class{_key;_publicKey;constructor(t,e){this._key=or(t,Xt),this._publicKey=or(e,nr)}sign(t){return Uo(this._key,t)}get public(){return new Ir(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:rt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return St(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=ue.digest(this.public.bytes);return bt.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return sr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function xf(r){if(r.length>Xt){r=or(r,Xt+nr);let n=r.subarray(0,Xt),s=r.subarray(Xt,r.length);return new Ke(n,s)}r=or(r,Xt);let t=r.subarray(0,Xt),e=r.subarray(nr);return new Ke(t,e)}function Ef(r){return r=or(r,nr),new Ir(r)}async function vf(){let{privateKey:r,publicKey:t}=Co();return new Ke(r,t)}async function Xo(r){let{privateKey:t,publicKey:e}=Lo(r);return new Ke(t,e)}function or(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=Zr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):e.encoder.encode(r).substring(1)}async function Qo(r,t){let e=Te.decode(r);return un().decrypt(e,t)}var Bi={};ct(Bi,{MAX_RSA_KEY_SIZE:()=>Kr,RsaPrivateKey:()=>fr,RsaPublicKey:()=>Hr,fromJwk:()=>Yf,generateKeyPair:()=>Gf,unmarshalRsaPrivateKey:()=>Ei,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:()=>xi,jwkToPkcs1:()=>Of,jwkToPkix:()=>Kf,pkcs1ToJwk:()=>Vf,pkixToJwk:()=>Hf});var bn=class extends Qe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Jr(t);let n=fe(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),Os(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()}},Rr=(r,t,e)=>new bn(r,t).update(e).digest();Rr.create=(r,t)=>new bn(r,t);function ta(r,t,e,n){Jr(r);let s=yo({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(Je(i),Je(o),Je(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=fe(t),f=fe(e),l=new Uint8Array(o),u=Rr.create(r,c),d=u._cloneInto().update(f);return{c:i,dkLen:o,asyncTick:a,DK:l,PRF:u,PRFSalt:d}}function ea(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function ra(r,t,e,n){let{c:s,dkLen:i,DK:o,PRF:a,PRFSalt:c}=ta(r,t,e,n),f,l=new Uint8Array(4),u=Le(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 ea(a,c,o,f,d)}async function di(r,t,e,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:f}=ta(r,t,e,n),l,u=new Uint8Array(4),d=Le(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 go(s-1,o,()=>{c._cloneInto(l).update(w).digestInto(w);for(let m=0;m<g.length;m++)g[m]^=w[m]})}return ea(c,f,a,l,w)}var K=ps(na());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 En(...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 gi(){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 sa(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let 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 ia(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 Op=Math.log(2);function vn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function yi(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 se(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var Nr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return yi(this.items)}},_r=[new Uint8Array([1])],oa="0123456789";var lr="",Ut=new ArrayBuffer(0),mi=new Uint8Array(0),Tr="EndOfContent",ca="OCTET STRING",la="BIT STRING";function ie(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?K.BufferSourceConverter.toUint8Array(i.valueHex):mi}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(!se(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",Ut)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:K.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var ee=class{constructor({blockLength:t=0,error:e=lr,warnings:n=[],valueBeforeDecode:s=mi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=K.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:K.Convert.ToHex(this.valueBeforeDecodeView)}}};ee.NAME="baseBlock";var yt=class extends ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};yt.NAME="valueBlock";var Bn=class extends ie(ee){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?K.BufferSourceConverter.toUint8Array(t.valueHex):mi,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",Ut}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=K.BufferSourceConverter.toUint8Array(t);if(!se(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}}};Bn.NAME="identificationBlock";var An=class extends ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=K.BufferSourceConverter.toUint8Array(t);if(!se(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",Ut;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}}};An.NAME="lengthBlock";var S={},dt=class extends ee{constructor({name:t=lr,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Bn(s),this.lenBlock=new An(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 Nr;e||ua(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():K.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${K.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 ia(e,n)}};dt.NAME="BaseBlock";function ua(r){if(r instanceof S.Constructed)for(let t of r.valueBlock.value)ua(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var kn=class extends dt{constructor({value:t=lr,...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}'`}};kn.NAME="BaseStringBlock";var Sn=class extends ie(yt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Sn.NAME="PrimitiveValueBlock";var fa,In=class extends dt{constructor(t={}){super(t,Sn),this.idBlock.isConstructed=!1}};fa=In;S.Primitive=fa;In.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 os(r,t=0,e=r.length){let n=t,s=new dt({},yt),i=new ee;if(!se(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=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let f=s.idBlock.isConstructed?new S.Constructed:new S.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?S.Constructed:S.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 ur(r){if(!r.byteLength){let t=new dt({},yt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return os(K.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Cf(r,t){return r?1:t}var Mt=class extends yt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=K.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let i=e;for(;Cf(this.isIndefiniteForm,n)>0;){let o=os(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===Tr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Tr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new Nr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Ut:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Mt.NAME="ConstructedValueBlock";var ha,Ee=class extends dt{constructor(t={}){super(t,Mt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
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} :`}};na=we;S.Constructed=na;we.NAME="CONSTRUCTED";var kn=class extends yt{fromBER(t,e,n){return e}toBER(t){return Lt}};kn.override="EndOfContentValueBlock";var sa,Sn=class extends dt{constructor(t={}){super(t,kn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};sa=Sn;S.EndOfContent=sa;Sn.NAME=_r;var ia,xe=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}`}};ia=xe;S.Null=ia;xe.NAME="NULL";var In=class extends se(yt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=K.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=K.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,hi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};In.NAME="BooleanValueBlock";var oa,Rn=class extends dt{constructor(t={}){super(t,In),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}`}};oa=Rn;S.Boolean=oa;Rn.NAME="BOOLEAN";var _n=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===_r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Qo)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}}};_n.NAME="OctetStringValueBlock";var aa,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},_n),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=ns(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?we.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${K.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 K.BufferSourceConverter.concat(t)}};aa=ee;S.OctetString=aa;ee.NAME=Qo;var Nn=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===_r){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ta)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=K.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=ns(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}}};Nn.NAME="BitStringValueBlock";var ca,or=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},Nn),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 we.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)}`}}};ca=or;S.BitString=ca;or.NAME=ta;var la;function Ef(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=bn(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=bn(e,i)),i}function Xo(r){if(r>=Ir.length)for(let t=Ir.length;t<=r;t++){let e=new Uint8Array([0]),n=Ir[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=bn(e,n)),Ir.push(n)}return Ir[r]}function vf(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 Nr=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=hi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Wo(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=vf(Xo(n),e),o="-";break;default:e=Ef(e,Xo(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=Jo.charAt(e[c]));return a===!1&&(o+=Jo.charAt(0)),o}};la=Nr;Nr.NAME="IntegerValueBlock";Object.defineProperty(la.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ua,it=class r extends dt{constructor(t={}){super(t,Nr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return wn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){wn();let e=BigInt(t),n=new Rr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(K.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${K.Convert.ToHex(a)}`)+e,l=K.BufferSourceConverter.toUint8Array(K.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()}`}};ua=it;S.Integer=ua;it.NAME="INTEGER";var fa,Tn=class extends it{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};fa=Tn;S.Enumerated=fa;Tn.NAME="ENUMERATED";var Tr=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=K.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=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){wn();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=be(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=K.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}}};Tr.NAME="sidBlock";var Cn=class extends yt{constructor({value:t=ar,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Tr;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 di(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 Tr;if(s>Number.MAX_SAFE_INTEGER){wn();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}};Cn.NAME="ObjectIdentifierValueBlock";var ha,Ct=class extends dt{constructor(t={}){super(t,Cn),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()}}};ha=Ct;S.ObjectIdentifier=ha;Ct.NAME="OBJECT IDENTIFIER";var Cr=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=K.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=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,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=be(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=K.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Cr.NAME="relativeSidBlock";var Ln=class extends yt{constructor({value:t=ar,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Cr;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 di(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 Cr;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}};Ln.NAME="RelativeObjectIdentifierValueBlock";var da,Un=class extends dt{constructor(t={}){super(t,Ln),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()}}};da=Un;S.RelativeObjectIdentifier=da;Un.NAME="RelativeObjectIdentifier";var pa,lt=class extends we{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};pa=lt;S.Sequence=pa;lt.NAME="SEQUENCE";var ga,Dn=class extends we{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ga=Dn;S.Set=ga;Dn.NAME="SET";var Vn=class extends se(yt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=ar}toJSON(){return{...super.toJSON(),value:this.value}}};Vn.NAME="StringValueBlock";var On=class extends Vn{};On.NAME="SimpleStringValueBlock";var wt=class extends vn{constructor({...t}={}){super(t,On)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,K.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}};wt.NAME="SIMPLE STRING";var Hn=class extends wt{fromBuffer(t){this.valueBlock.valueHexView=K.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=K.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=K.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(K.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Hn.NAME="Utf8StringValueBlock";var ya,re=class extends Hn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ya=re;S.Utf8String=ya;re.NAME="UTF8String";var Kn=class extends wt{fromBuffer(t){this.valueBlock.value=K.Convert.ToUtf16String(t),this.valueBlock.valueHexView=K.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(K.Convert.FromUtf16String(t))}};Kn.NAME="BmpStringValueBlock";var ma,Pn=class extends Kn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};ma=Pn;S.BmpString=ma;Pn.NAME="BMPString";var Mn=class extends wt{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=be(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}};Mn.NAME="UniversalStringValueBlock";var ba,Fn=class extends Mn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ba=Fn;S.UniversalString=ba;Fn.NAME="UniversalString";var wa,$n=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};wa=$n;S.NumericString=wa;$n.NAME="NumericString";var xa,qn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};xa=qn;S.PrintableString=xa;qn.NAME="PrintableString";var Ea,jn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Ea=jn;S.TeletexString=Ea;jn.NAME="TeletexString";var va,Yn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};va=Yn;S.VideotexString=va;Yn.NAME="VideotexString";var Ba,Gn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ba=Gn;S.IA5String=Ba;Gn.NAME="IA5String";var Aa,zn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Aa=zn;S.GraphicString=Aa;zn.NAME="GraphicString";var ka,Lr=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ka=Lr;S.VisibleString=ka;Lr.NAME="VisibleString";var Sa,Wn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Sa=Wn;S.GeneralString=Sa;Wn.NAME="GeneralString";var Ia,Zn=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ia=Zn;S.CharacterString=Ia;Zn.NAME="CharacterString";var Ra,Ur=class extends Lr{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,K.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}}};Ra=Ur;S.UTCTime=Ra;Ur.NAME="UTCTime";var _a,Jn=class extends Ur{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}}};_a=Jn;S.GeneralizedTime=_a;Jn.NAME="GeneralizedTime";var Na,Xn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Na=Xn;S.DATE=Na;Xn.NAME="DATE";var Ta,Qn=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ta=Qn;S.TimeOfDay=Ta;Qn.NAME="TimeOfDay";var Ca,ts=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ca=ts;S.DateTime=Ca;ts.NAME="DateTime";var La,es=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};La=es;S.Duration=La;es.NAME="Duration";var Ua,rs=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ua=rs;S.TIME=Ua;rs.NAME="TIME";function Af(r){let{result:t}=cr(r),e=t.valueBlock.value;return{n:W(Pt(e[1].toBigInt()),"base64url"),e:W(Pt(e[2].toBigInt()),"base64url"),d:W(Pt(e[3].toBigInt()),"base64url"),p:W(Pt(e[4].toBigInt()),"base64url"),q:W(Pt(e[5].toBigInt()),"base64url"),dp:W(Pt(e[6].toBigInt()),"base64url"),dq:W(Pt(e[7].toBigInt()),"base64url"),qi:W(Pt(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function kf(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(Mt(F(r.n,"base64url"))),it.fromBigInt(Mt(F(r.e,"base64url"))),it.fromBigInt(Mt(F(r.d,"base64url"))),it.fromBigInt(Mt(F(r.p,"base64url"))),it.fromBigInt(Mt(F(r.q,"base64url"))),it.fromBigInt(Mt(F(r.dp,"base64url"))),it.fromBigInt(Mt(F(r.dq,"base64url"))),it.fromBigInt(Mt(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Sf(r){let{result:t}=cr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:W(Pt(e[0].toBigInt()),"base64url"),e:W(Pt(e[1].toBigInt()),"base64url")}}function If(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 xe]}),new or({valueHex:new lt({value:[it.fromBigInt(Mt(F(r.n,"base64url"))),it.fromBigInt(Mt(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Pt(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 Mt(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 Rf=16,gi=32,yi=1e4;async function _f(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 xe]}),new ee({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=Ht(Rf),a=await ui(pe,t,o,{c:yi,dkLen:gi}),c=Ht(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:yi}),new it({value:gi}),new lt({value:[new Ct({value:"1.2.840.113549.2.11"}),new xe]})]}),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 mi(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}=cr(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:l}=Nf(i),u=await ui(pe,t,a,{c,dkLen:f}),d=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=Dr(await e.subtle.decrypt({name:"AES-CBC",iv:o},d,l)),{result:p}=cr(w);n=Da(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}=cr(s);n=Da(i)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return bi(n)}function Nf(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=Dr(i.valueBlock.value[0].getValue()),a=yi,c=gi;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=Dr(f.valueBlock.value[1].getValue());return{cipherText:Dr(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function Da(r){return Dr(r.valueBlock.value[2].getValue())}function Dr(r){return new Uint8Array(r,0,r.byteLength)}async function Va(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 Ka(t);return{privateKey:e[0],publicKey:e[1]}}async function wi(r){let e=[await mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Tf(r)],n=await Ka({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Oa(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 Ha(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 Ka(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 Tf(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 ss(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 Or=8192,Vr=class{_key;constructor(t){this._key=t}verify(t,e){return Ha(this._key,e,t)}marshal(){return Ee.jwkToPkix(this._key)}get bytes(){return Xt.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return At(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return kt(t)?t.then(({bytes:e})=>e):t.bytes}},lr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Ht(16)}sign(t){return Oa(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Vr(this._publicKey)}marshal(){return Ee.jwkToPkcs1(this._key)}get bytes(){return Ot.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return At(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 Ee.exportToPem(this,t);if(e==="libp2p-key")return rr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function bi(r){let t=Ee.pkcs1ToJwk(r);if(ss(t)>Or)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await wi(t);return new lr(e.privateKey,e.publicKey)}function Lf(r){let t=Ee.pkixToJwk(r);if(ss(t)>Or)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Vr(t)}async function Uf(r){if(ss(r)>Or)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await wi(r);return new lr(t.privateKey,t.publicKey)}async function Df(r){if(r>Or)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Va(r);return new lr(t.privateKey,t.publicKey)}var ki={};ct(ki,{Secp256k1PrivateKey:()=>Kr,Secp256k1PublicKey:()=>Hr,generateKeyPair:()=>Zf,unmarshalSecp256k1PrivateKey:()=>zf,unmarshalSecp256k1PublicKey:()=>Wf});var Vf=(r,t,e)=>r&t^~r&e,Of=(r,t,e)=>r&t^r&e^t&e,Hf=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]),ve=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Be=new Uint32Array(64),Ei=class extends fe{constructor(){super(64,32,8,!1),this.A=ve[0]|0,this.B=ve[1]|0,this.C=ve[2]|0,this.D=ve[3]|0,this.E=ve[4]|0,this.F=ve[5]|0,this.G=ve[6]|0,this.H=ve[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)Be[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=Be[u-15],w=Be[u-2],p=Rt(d,7)^Rt(d,18)^d>>>3,h=Rt(w,17)^Rt(w,19)^w>>>10;Be[u]=h+Be[u-7]+p+Be[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=Rt(a,6)^Rt(a,11)^Rt(a,25),w=l+d+Vf(a,c,f)+Hf[u]+Be[u]|0,h=(Rt(n,2)^Rt(n,13)^Rt(n,22))+Of(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(){Be.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var is=Xe(()=>new Ei);function Kf(r){let t=Er(r);Vt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("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:Pf,hexToBytes:Mf}=tn,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:Pf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Ke,e=typeof r=="string"?Mf(r):r;if(!_t(e))throw new Error("ui8a expected");let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l: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),It=BigInt(1),Gp=BigInt(2),Pa=BigInt(3),zp=BigInt(4);function Ff(r){let t=Kf(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(_t(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,k=e.eql(e.mul(g,x),e.mul(b,A)),_=e.eql(e.mul(m,x),e.mul(T,A));return k&&_}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:g}=t,m=e.mul(g,Pa),{px:A,py:b,pz:T}=this,x=e.ZERO,k=e.ZERO,_=e.ZERO,N=e.mul(A,A),j=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,_),k=e.mul(m,$),k=e.add(x,k),x=e.sub(j,k),k=e.add(j,k),k=e.mul(x,k),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),k=e.add(k,N),$=e.mul(b,T),$=e.add($,$),N=e.mul($,D),x=e.sub(x,N),_=e.mul($,j),_=e.add(_,_),_=e.add(_,_),new u(x,k,_)}add(h){l(h);let{px:g,py:m,pz:A}=this,{px:b,py:T,pz:x}=h,k=e.ZERO,_=e.ZERO,N=e.ZERO,j=t.a,$=e.mul(t.b,Pa),D=e.mul(g,b),nt=e.mul(m,T),et=e.mul(A,x),Bt=e.add(g,m),E=e.add(b,T);Bt=e.mul(Bt,E),E=e.add(D,nt),Bt=e.sub(Bt,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),k=e.add(T,x),R=e.mul(R,k),k=e.add(nt,et),R=e.sub(R,k),N=e.mul(j,E),k=e.mul($,et),N=e.add(k,N),k=e.sub(nt,N),N=e.add(nt,N),_=e.mul(k,N),nt=e.add(D,D),nt=e.add(nt,D),et=e.mul(j,et),E=e.mul($,E),nt=e.add(nt,et),et=e.sub(D,et),et=e.mul(j,et),E=e.add(E,et),D=e.mul(nt,E),_=e.add(_,D),D=e.mul(R,E),k=e.mul(Bt,k),k=e.sub(k,D),D=e.mul(Bt,nt),N=e.mul(R,N),N=e.add(N,D),new u(k,_,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===It)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),k=g,_=g,N=this;for(;b>ie||x>ie;)b&It&&(k=k.add(N)),x&It&&(_=_.add(N)),N=N.double(),b>>=It,x>>=It;return A&&(k=k.negate()),T&&(_=_.negate()),_=new u(e.mul(_.px,m.beta),_.py,_.pz),k.add(_)}multiply(h){a(h);let g=h,m,A,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:k,k2:_}=b.splitScalar(g),{p:N,f:j}=this.wNAF(x),{p:$,f:D}=this.wNAF(_);N=w.constTimeNegate(T,N),$=w.constTimeNegate(k,$),$=new u(e.mul($.px,b.beta),$.py,$.pz),m=N.add($),A=j.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,k)=>k===ie||k===It||!x.equals(A)?x.multiplyUnsafe(k):x.multiply(k),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),k=e.mul(A,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:T,y:x}}isTorsionFree(){let{h,isTorsionFree:g}=t;if(h===It)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===It?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=nn(u,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function $f(r){let t=Er(r);return Vt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ma(r){let t=$f(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 en(E,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:d}=Ff({...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=e.sqrt(I),L=(C&It)===It;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(ye(E,t.nByteLength));function p(E){let R=n>>It;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),Y=a(-I*H),P=a(v*H),q=f.BASE.multiplyAndAddUnsafe(O,Y,P);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 Ce(this.toDERHex())}toDERHex(){return Ke.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ce(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=qs(t.n);return Ao(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=_t(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 k=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(k(E))},N=xr(t.nBitLength);function j(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(ie<=E&&E<N))throw new Error(`bigint expected < 2^${t.nBitLength}`);return ye(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),Y=[j(H),j(O)];if(L!=null){let X=L===!0?y(e.BYTES):L;Y.push(tt("extraEntropy",X))}let P=Wt(...Y),q=O;function st(X){let ut=k(X);if(!d(ut))return;let ft=c(ut),ot=f.BASE.multiply(ut).toAffine(),pt=a(ot.x);if(pt===ie)return;let $t=a(ft*a(q+pt*H));if($t===ie)return;let Se=(ot.x===pt?0:2)|Number(ot.y&It),gr=$t;return I&&p($t)&&(gr=h($t),Se^=1),new m(pt,gr,Se)}return{seed:P,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 Ps(I.hash.outputLen,I.nByteLength,I.hmac)(v,y)}f.BASE._setWindowSize(8);function Bt(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"||_t(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:Y}=L,P=_(R),q=c(Y),st=a(P*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:Bt,ProjectivePoint:f,Signature:m,utils:A}}function qf(r){return{hash:r,hmac:(t,...e)=>Sr(r,t,Jr(...e)),randomBytes:Qe}}function Fa(r,t){let e=n=>Ma({...r,...qf(n)});return Object.freeze({...e(t),create:e})}var ja=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),$a=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),jf=BigInt(1),vi=BigInt(2),qa=(r,t)=>(r+t/vi)/t;function Yf(r){let t=ja,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,vi,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,k=J(x,vi,t);if(!Bi.eql(Bi.sqr(k),r))throw new Error("Cannot find square root");return k}var Bi=rn(ja,void 0,void 0,{sqrt:Yf}),Ut=Fa({a:BigInt(0),b:BigInt(7),Fp:Bi,n:$a,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=$a,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-jf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=qa(i*r,t),c=qa(-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}}}},is),ng=BigInt(0);var sg=Ut.ProjectivePoint;function Ya(){return Ut.utils.randomPrivateKey()}function Ga(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 za(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 Wa(r){return Ut.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Za(r){try{Ut.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Ai(r){try{Ut.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Ja(r){try{return Ut.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Hr=class{_key;constructor(t){Ai(t),this._key=t}verify(t,e){return za(this._key,e,t)}marshal(){return Wa(this._key)}get bytes(){return Xt.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return At(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return kt(t)?{bytes:e}=await t:e=t.bytes,e}},Kr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Ja(t),Za(this._key),Ai(this._publicKey)}sign(t){return Ga(this._key,t)}get public(){return new Hr(this._publicKey)}marshal(){return this._key}get bytes(){return Ot.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return At(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 rr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function zf(r){return new Kr(r)}function Wf(r){return new Hr(r)}async function Zf(){let r=Ya();return new Kr(r)}var Pr={rsa:xi,ed25519:li,secp256k1:ki};function Xa(r){let t=Object.keys(Pr).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Jf(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return Pr[r];throw Xa(r)}async function Qa(r,t){return Jf(r).generateKeyPair(t??2048)}async function Si(r){let t=Ot.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return Pr.rsa.unmarshalRsaPrivateKey(e);case rt.Ed25519:return Pr.ed25519.unmarshalEd25519PrivateKey(e);case rt.Secp256k1:return Pr.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw Xa(t.Type??"RSA")}}async function Mr(r,t){try{let e=await qo(r,t);return await Si(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 mi(r,t)}var Ii=(r,t)=>r<<t|r>>>32-t>>>0,Xf=(r,t,e)=>r&t^~r&e,Qf=(r,t,e)=>r&t^r&e^t&e,Fr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Ae=new Uint32Array(80),Ri=class extends fe{constructor(){super(64,20,8,!1),this.A=Fr[0]|0,this.B=Fr[1]|0,this.C=Fr[2]|0,this.D=Fr[3]|0,this.E=Fr[4]|0}get(){let{A:t,B:e,C:n,D:s,E: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)Ae[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Ae[c]=Ii(Ae[c-3]^Ae[c-8]^Ae[c-14]^Ae[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=Xf(s,i,o),l=1518500249):c<40?(f=s^i^o,l=1859775393):c<60?(f=Qf(s,i,o),l=2400959708):(f=s^i^o,l=3395469782);let u=Ii(n,5)+f+a+l+Ae[c]|0;a=o,o=i,i=Ii(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(){Ae.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},tc=Xe(()=>new Ri);var ec={sha1:tc,"sha2-256":is,"sha2-512":pe};function $r(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(ec).join(" / ");throw new B(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let i=ec[s],o=Go(i,r,t,{c:e,dkLen:n});return _e.encode(o).substring(1)}var th=Symbol.for("nodejs.util.inspect.custom"),rc=Object.values(ze).map(r=>r.decoder).reduce((r,t)=>r.or(t),ze.identity.decoder),nc=114,_i=36,Ni=37,qr=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()})`}[Fi]=!0;toString(){return this.string==null&&(this.string=bt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Ne.createV1(nc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return At(this.multihash.bytes,t);if(typeof t=="string")return eh(t).equals(this);if(t?.multihash?.bytes!=null)return At(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[th](){return`PeerId(${this.toString()})`}},ur=class extends qr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},fr=class extends qr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},hr=class extends qr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function eh(r,t){if(t=t??rc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=br(bt.decode(`z${r}`));return r.startsWith("12D")?new fr({multihash:e}):r.startsWith("16U")?new hr({multihash:e}):new ur({multihash:e})}return rh(rc.decode(r))}function rh(r){try{let t=br(r);if(t.code===le.code){if(t.digest.length===_i)return new fr({multihash:t});if(t.digest.length===Ni)return new hr({multihash:t})}if(t.code===ht.code)return new ur({multihash:t})}catch{return nh(Ne.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function nh(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==nc)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===ht.code)return new ur({multihash:r.multihash});if(t.code===le.code){if(t.digest.length===_i)return new fr({multihash:r.multihash});if(t.digest.length===Ni)return new hr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function sc(r,t){return r.length===_i?new fr({multihash:Dt(le.code,r),privateKey:t}):r.length===Ni?new hr({multihash:Dt(le.code,r),privateKey:t}):new ur({multihash:await ht.digest(r),publicKey:r,privateKey:t})}var oe="/",ic=new TextEncoder().encode(oe),os=ic[0],jr=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]!==os)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=ic),this._buf[0]!==os){let t=new Uint8Array(this._buf.byteLength+1);t.fill(os,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===os;)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 sh(this.baseNamespace())}name(){return ih(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(),...oh(t.map(e=>e.namespaces()))])}};function sh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function ih(r){let t=r.split(":");return t[t.length-1]}function oh(r){return[].concat(...r)}var pc=fs(dc(),1),gc=pc.default;var kc=fs(Ac(),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 Ah="/pkcs8/",Sc="/info/",Pe=new WeakMap,Me={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Ci={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,kc.default)(r.trim())&&r.length>0}async function z(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Ft(r){return new jr(Ah+r)}function ke(r){return new jr(Sc+r)}var ls=class{components;init;log;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=gc(Ci,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<Me.minKeyLength)throw new Error(`dek.keyLength must be least ${Me.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Me.minSaltLength)throw new Error(`dek.saltLength must be least ${Me.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Me.minIterationCount)throw new Error(`dek.iterationCount must be least ${Me.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?$r(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Pe.set(this,{dek:n})}static generateOptions(){let t=Object.assign({},Ci),e=Math.ceil(Me.minSaltLength/3)*3;return t.dek.salt=W(Ht(e),"base64"),t}static get options(){return Ci}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=Ft(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 Qa(e,n),c=await a.id(),f=Pe.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(ke(t),F(JSON.stringify(o))),await d.commit()}catch(a){throw await z(),a}return o}async listKeys(){let t={prefix:Sc},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=ke(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=Ft(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(ke(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=Ft(t),s=Ft(e),i=ke(t),o=ke(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=Ft(t);try{let s=await this.components.datastore.get(n),i=W(s),o=Pe.get(this);if(o==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let a=o.dek;return await(await Mr(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 Mr(n,e);return sc(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=Ft(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 Mr(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=Pe.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(ke(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 Si(e.privateKey),s=Ft(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,M.ERR_KEY_ALREADY_EXISTS);let o=Pe.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(ke(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=Ft(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=Pe.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?$r(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Pe.set(this,{dek:i});let o=await this.listKeys();for(let a of o){let c=await this.components.datastore.get(Ft(a.name)),f=W(c),l=await Mr(f,s),u=i.toString(),d=await l.export(u),w=this.components.datastore.batch(),p={name:a.name,id:a.id};w.put(Ft(a.name),F(d)),w.put(ke(a.name),F(JSON.stringify(p))),await w.commit()}this.log("keychain reconstructed")}};function kh(r={}){return t=>new ls(t,r)}return Pc(Sh);})();
|
|
6
|
+
`)}`:`${e} :`}};ha=Ee;S.Constructed=ha;Ee.NAME="CONSTRUCTED";var Rn=class extends yt{fromBER(t,e,n){return e}toBER(t){return Ut}};Rn.override="EndOfContentValueBlock";var da,_n=class extends dt{constructor(t={}){super(t,Rn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};da=_n;S.EndOfContent=da;_n.NAME=Tr;var pa,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}`}};pa=ve;S.Null=pa;ve.NAME="NULL";var Nn=class extends ie(yt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=K.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=K.BufferSourceConverter.toUint8Array(t);return se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,gi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Nn.NAME="BooleanValueBlock";var ga,Tn=class extends dt{constructor(t={}){super(t,Nn),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ga=Tn;S.Boolean=ga;Tn.NAME="BOOLEAN";var Cn=class extends ie(Mt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===Tr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==ca)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?Mt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Cn.NAME="OctetStringValueBlock";var ya,re=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},Cn),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=os(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} : ${K.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 K.BufferSourceConverter.concat(t)}};ya=re;S.OctetString=ya;re.NAME=ca;var Ln=class extends ie(Mt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Tr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==la)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let 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=K.BufferSourceConverter.toUint8Array(t);if(!se(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=os(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 Mt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ut;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Ln.NAME="BitStringValueBlock";var ma,cr=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},Ln),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)}`}}};ma=cr;S.BitString=ma;cr.NAME=la;var ba;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=En(new Uint8Array([f%10]),i);break;default:i[o-u]=f%10}}return e[0]>0&&(i=En(e,i)),i}function aa(r){if(r>=_r.length)for(let t=_r.length;t<=r;t++){let e=new Uint8Array([0]),n=_r[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=En(e,n)),_r.push(n)}return _r[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 Cr=class extends ie(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=gi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(sa(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let 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(aa(n),e),o="-";break;default:e=Lf(e,aa(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=oa.charAt(e[c]));return a===!1&&(o+=oa.charAt(0)),o}};ba=Cr;Cr.NAME="IntegerValueBlock";Object.defineProperty(ba.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var wa,it=class r extends dt{constructor(t={}){super(t,Cr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return vn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){vn();let e=BigInt(t),n=new Nr,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(K.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${K.Convert.ToHex(a)}`)+e,l=K.BufferSourceConverter.toUint8Array(K.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()}`}};wa=it;S.Integer=wa;it.NAME="INTEGER";var xa,Un=class extends it{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};xa=Un;S.Enumerated=xa;Un.NAME="ENUMERATED";var Lr=class extends ie(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=K.BufferSourceConverter.toUint8Array(t);if(!se(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){vn();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",Ut;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=K.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}}};Lr.NAME="sidBlock";var Dn=class extends yt{constructor({value:t=lr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new Lr;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,Ut;e.push(s)}return yi(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 Lr;if(s>Number.MAX_SAFE_INTEGER){vn();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}};Dn.NAME="ObjectIdentifierValueBlock";var Ea,Lt=class extends dt{constructor(t={}){super(t,Dn),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Ea=Lt;S.ObjectIdentifier=Ea;Lt.NAME="OBJECT IDENTIFIER";var Ur=class extends ie(ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=K.BufferSourceConverter.toUint8Array(t);if(!se(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",Ut;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=K.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Ur.NAME="relativeSidBlock";var Vn=class extends yt{constructor({value:t=lr,...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.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,Ut;n.push(i)}return yi(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 Ur;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}};Vn.NAME="RelativeObjectIdentifierValueBlock";var va,On=class extends dt{constructor(t={}){super(t,Vn),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()}}};va=On;S.RelativeObjectIdentifier=va;On.NAME="RelativeObjectIdentifier";var Ba,lt=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ba=lt;S.Sequence=Ba;lt.NAME="SEQUENCE";var Aa,Hn=class extends Ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Aa=Hn;S.Set=Aa;Hn.NAME="SET";var Kn=class extends ie(yt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=lr}toJSON(){return{...super.toJSON(),value:this.value}}};Kn.NAME="StringValueBlock";var Pn=class extends Kn{};Pn.NAME="SimpleStringValueBlock";var xt=class extends kn{constructor({...t}={}){super(t,Pn)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,K.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 Mn=class extends xt{fromBuffer(t){this.valueBlock.valueHexView=K.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=K.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=K.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(K.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Mn.NAME="Utf8StringValueBlock";var ka,ne=class extends Mn{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ka=ne;S.Utf8String=ka;ne.NAME="UTF8String";var Fn=class extends xt{fromBuffer(t){this.valueBlock.value=K.Convert.ToUtf16String(t),this.valueBlock.valueHexView=K.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(K.Convert.FromUtf16String(t))}};Fn.NAME="BmpStringValueBlock";var Sa,$n=class extends Fn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Sa=$n;S.BmpString=Sa;$n.NAME="BMPString";var qn=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}};qn.NAME="UniversalStringValueBlock";var Ia,jn=class extends qn{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ia=jn;S.UniversalString=Ia;jn.NAME="UniversalString";var Ra,Yn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Ra=Yn;S.NumericString=Ra;Yn.NAME="NumericString";var _a,Gn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};_a=Gn;S.PrintableString=_a;Gn.NAME="PrintableString";var Na,zn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Na=zn;S.TeletexString=Na;zn.NAME="TeletexString";var Ta,Wn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ta=Wn;S.VideotexString=Ta;Wn.NAME="VideotexString";var Ca,Zn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ca=Zn;S.IA5String=Ca;Zn.NAME="IA5String";var La,Jn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};La=Jn;S.GraphicString=La;Jn.NAME="GraphicString";var Ua,Dr=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ua=Dr;S.VisibleString=Ua;Dr.NAME="VisibleString";var Da,Xn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Da=Xn;S.GeneralString=Da;Xn.NAME="GeneralString";var Va,Qn=class extends xt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Va=Qn;S.CharacterString=Va;Qn.NAME="CharacterString";var Oa,Vr=class extends Dr{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,K.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}}};Oa=Vr;S.UTCTime=Oa;Vr.NAME="UTCTime";var Ha,ts=class extends Vr{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}}};Ha=ts;S.GeneralizedTime=Ha;ts.NAME="GeneralizedTime";var Ka,es=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ka=es;S.DATE=Ka;es.NAME="DATE";var Pa,rs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Pa=rs;S.TimeOfDay=Pa;rs.NAME="TimeOfDay";var Ma,ns=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ma=ns;S.DateTime=Ma;ns.NAME="DateTime";var Fa,ss=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Fa=ss;S.Duration=Fa;ss.NAME="Duration";var $a,is=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};$a=is;S.TIME=$a;is.NAME="TIME";function Vf(r){let{result:t}=ur(r),e=t.valueBlock.value;return{n:W(Ft(e[1].toBigInt()),"base64url"),e:W(Ft(e[2].toBigInt()),"base64url"),d:W(Ft(e[3].toBigInt()),"base64url"),p:W(Ft(e[4].toBigInt()),"base64url"),q:W(Ft(e[5].toBigInt()),"base64url"),dp:W(Ft(e[6].toBigInt()),"base64url"),dq:W(Ft(e[7].toBigInt()),"base64url"),qi:W(Ft(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($t(F(r.n,"base64url"))),it.fromBigInt($t(F(r.e,"base64url"))),it.fromBigInt($t(F(r.d,"base64url"))),it.fromBigInt($t(F(r.p,"base64url"))),it.fromBigInt($t(F(r.q,"base64url"))),it.fromBigInt($t(F(r.dp,"base64url"))),it.fromBigInt($t(F(r.dq,"base64url"))),it.fromBigInt($t(F(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Hf(r){let{result:t}=ur(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:W(Ft(e[0].toBigInt()),"base64url"),e:W(Ft(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 Lt({value:"1.2.840.113549.1.1.1"}),new ve]}),new cr({valueHex:new lt({value:[it.fromBigInt($t(F(r.n,"base64url"))),it.fromBigInt($t(F(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ft(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,i=0;for(;s<e;)n[s]=parseInt(t.slice(i,i+2),16),s+=1,i+=2;return n}function $t(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Pf=16,bi=32,wi=1e4;async function Mf(r,t){let e=mt.get(),s=new lt({value:[new it({value:0}),new lt({value:[new Lt({value:"1.2.840.113549.1.1.1"}),new ve]}),new re({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=Pt(Pf),a=await di(ge,t,o,{c:wi,dkLen:bi}),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 re({valueHex:o}),new it({value:wi}),new it({value:bi}),new lt({value:[new Lt({value:"1.2.840.113549.2.11"}),new ve]})]}),d=new lt({value:[new Lt({value:"1.2.840.113549.1.5.13"}),new lt({value:[new lt({value:[new Lt({value:"1.2.840.113549.1.5.12"}),u]}),new lt({value:[new Lt({value:"2.16.840.1.101.3.4.1.42"}),new re({valueHex:c})]})]})]}),p=new lt({value:[d,new re({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 xi(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}=ur(s),{iv:o,salt:a,iterations:c,keySize:f,cipherText:l}=Ff(i),u=await di(ge,t,a,{c,dkLen:f}),d=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),w=Or(await e.subtle.decrypt({name:"AES-CBC",iv:o},d,l)),{result:p}=ur(w);n=qa(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}=ur(s);n=qa(i)}else throw new B("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ei(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=Or(i.valueBlock.value[0].getValue()),a=wi,c=bi;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=Or(f.valueBlock.value[1].getValue());return{cipherText:Or(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:u}}function qa(r){return Or(r.valueBlock.value[2].getValue())}function Or(r){return new Uint8Array(r,0,r.byteLength)}async function ja(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 vi(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 za({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ya(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 Ga(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 $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 as(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,Hr=class{_key;constructor(t){this._key=t}verify(t,e){return Ga(this._key,e,t)}marshal(){return Be.jwkToPkix(this._key)}get bytes(){return Qt.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return St(t)?t.then(({bytes:e})=>e):t.bytes}},fr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Pt(16)}sign(t){return Ya(this._key,t)}get public(){if(this._publicKey==null)throw new B("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Hr(this._publicKey)}marshal(){return Be.jwkToPkcs1(this._key)}get bytes(){return Kt.encode({Type:rt.RSA,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return St(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 sr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ei(r){let t=Be.pkcs1ToJwk(r);if(as(t)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await vi(t);return new fr(e.privateKey,e.publicKey)}function jf(r){let t=Be.pkixToJwk(r);if(as(t)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Hr(t)}async function Yf(r){if(as(r)>Kr)throw new B("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await vi(r);return new fr(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 ja(r);return new fr(t.privateKey,t.publicKey)}var Ri={};ct(Ri,{Secp256k1PrivateKey:()=>Mr,Secp256k1PublicKey:()=>Pr,generateKeyPair:()=>ch,unmarshalSecp256k1PrivateKey:()=>oh,unmarshalSecp256k1PublicKey:()=>ah});var zf=(r,t,e)=>r&t^~r&e,Wf=(r,t,e)=>r&t^r&e^t&e,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]),ke=new Uint32Array(64),Ai=class extends he{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)ke[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=ke[u-15],w=ke[u-2],p=_t(d,7)^_t(d,18)^d>>>3,h=_t(w,17)^_t(w,19)^w>>>10;ke[u]=h+ke[u-7]+p+ke[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+zf(a,c,f)+Zf[u]+ke[u]|0,h=(_t(n,2)^_t(n,13)^_t(n,22))+Wf(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(){ke.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var cs=tr(()=>new Ai);function Jf(r){let t=Br(r);Ht(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Xf,hexToBytes:Qf}=rn,Me={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Me;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:Xf(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Me,e=typeof r=="string"?Qf(r):r;if(!Nt(e))throw new Error("ui8a expected");let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:i}=Me._parseInt(e.subarray(2)),{d:o,l:a}=Me._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}`}},oe=BigInt(0),Rt=BigInt(1),lg=BigInt(2),Wa=BigInt(3),ug=BigInt(4);function th(r){let t=Jf(r),{Fp:e}=t,n=t.toBytes||((p,h,g)=>{let m=h.toAffine();return Zt(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"&&oe<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(Nt(p)&&(p=zt(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:Wt(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,k=e.eql(e.mul(g,x),e.mul(b,A)),_=e.eql(e.mul(m,x),e.mul(T,A));return k&&_}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:g}=t,m=e.mul(g,Wa),{px:A,py:b,pz:T}=this,x=e.ZERO,k=e.ZERO,_=e.ZERO,N=e.mul(A,A),j=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,_),k=e.mul(m,$),k=e.add(x,k),x=e.sub(j,k),k=e.add(j,k),k=e.mul(x,k),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),k=e.add(k,N),$=e.mul(b,T),$=e.add($,$),N=e.mul($,D),x=e.sub(x,N),_=e.mul($,j),_=e.add(_,_),_=e.add(_,_),new u(x,k,_)}add(h){l(h);let{px:g,py:m,pz:A}=this,{px:b,py:T,pz:x}=h,k=e.ZERO,_=e.ZERO,N=e.ZERO,j=t.a,$=e.mul(t.b,Wa),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),k=e.add(T,x),R=e.mul(R,k),k=e.add(nt,et),R=e.sub(R,k),N=e.mul(j,E),k=e.mul($,et),N=e.add(k,N),k=e.sub(nt,N),N=e.add(nt,N),_=e.mul(k,N),nt=e.add(D,D),nt=e.add(nt,D),et=e.mul(j,et),E=e.mul($,E),nt=e.add(nt,et),et=e.sub(D,et),et=e.mul(j,et),E=e.add(E,et),D=e.mul(nt,E),_=e.add(_,D),D=e.mul(R,E),k=e.mul(At,k),k=e.sub(k,D),D=e.mul(At,nt),N=e.mul(R,N),N=e.add(N,D),new u(k,_,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===oe)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),k=g,_=g,N=this;for(;b>oe||x>oe;)b&Rt&&(k=k.add(N)),x&Rt&&(_=_.add(N)),N=N.double(),b>>=Rt,x>>=Rt;return A&&(k=k.negate()),T&&(_=_.negate()),_=new u(e.mul(_.px,m.beta),_.py,_.pz),k.add(_)}multiply(h){a(h);let g=h,m,A,{endo:b}=t;if(b){let{k1neg:T,k1:x,k2neg:k,k2:_}=b.splitScalar(g),{p:N,f:j}=this.wNAF(x),{p:$,f:D}=this.wNAF(_);N=w.constTimeNegate(T,N),$=w.constTimeNegate(k,$),$=new u(e.mul($.px,b.beta),$.py,$.pz),m=N.add($),A=j.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,k)=>k===oe||k===Rt||!x.equals(A)?x.multiplyUnsafe(k):x.multiply(k),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),k=e.mul(A,h);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,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 zt(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=on(u,t.endo?Math.ceil(d/2):d);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function eh(r){let t=Br(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Za(r){let t=eh(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(E){return oe<E&&E<e.ORDER}function a(E){return G(E,n)}function c(E){return nn(E,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:d}=th({...t,toBytes(E,R,V){let v=R.toAffine(),y=e.toBytes(v.x),I=Zt;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=Wt(v);if(!o(y))throw new Error("Point is not on curve");let I=u(y),C=e.sqrt(I),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=>zt(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)=>Wt(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}=Me.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),Y=a(-I*H),P=a(v*H),q=f.BASE.multiplyAndAddUnsafe(O,Y,P);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 Ue(this.toDERHex())}toDERHex(){return Me.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ue(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=Gs(t.n);return Io(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=Nt(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 k=t.bits2int||function(E){let R=Wt(E),V=E.length*8-t.nBitLength;return V>0?R>>BigInt(V):R},_=t.bits2int_modN||function(E){return a(k(E))},N=vr(t.nBitLength);function j(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(oe<=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),Y=[j(H),j(O)];if(L!=null){let X=L===!0?y(e.BYTES):L;Y.push(tt("extraEntropy",X))}let P=Zt(...Y),q=O;function st(X){let ut=k(X);if(!d(ut))return;let ft=c(ut),ot=f.BASE.multiply(ut).toAffine(),pt=a(ot.x);if(pt===oe)return;let jt=a(ft*a(q+pt*H));if(jt===oe)return;let Re=(ot.x===pt?0:2)|Number(ot.y&Rt),mr=jt;return I&&p(jt)&&(mr=h(jt),Re^=1),new m(pt,mr,Re)}return{seed:P,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 $s(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"||Nt(y))try{L=m.fromDER(y)}catch(ot){if(!(ot instanceof Me.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:Y}=L,P=_(R),q=c(Y),st=a(P*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 rh(r){return{hash:r,hmac:(t,...e)=>Rr(r,t,Qr(...e)),randomBytes:er}}function Ja(r,t){let e=n=>Za({...r,...rh(n)});return Object.freeze({...e(t),create:e})}var tc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Xa=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),nh=BigInt(1),ki=BigInt(2),Qa=(r,t)=>(r+t/ki)/t;function sh(r){let t=tc,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,ki,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,k=J(x,ki,t);if(!Si.eql(Si.sqr(k),r))throw new Error("Cannot find square root");return k}var Si=sn(tc,void 0,void 0,{sqrt:sh}),Dt=Ja({a:BigInt(0),b:BigInt(7),Fp:Si,n:Xa,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Xa,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-nh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=Qa(i*r,t),c=Qa(-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}}}},cs),wg=BigInt(0);var xg=Dt.ProjectivePoint;function ec(){return Dt.utils.randomPrivateKey()}function rc(r,t){let e=ht.digest(t instanceof Uint8Array?t:t.subarray());if(St(e))return e.then(({digest:n})=>Dt.sign(n,r).toDERRawBytes()).catch(n=>{throw new B(String(n),"ERR_INVALID_INPUT")});try{return Dt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new B(String(n),"ERR_INVALID_INPUT")}}function nc(r,t,e){let n=ht.digest(e instanceof Uint8Array?e:e.subarray());if(St(n))return n.then(({digest:s})=>Dt.verify(t,s,r)).catch(s=>{throw new B(String(s),"ERR_INVALID_INPUT")});try{return Dt.verify(t,n.digest,r)}catch(s){throw new B(String(s),"ERR_INVALID_INPUT")}}function sc(r){return Dt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function ic(r){try{Dt.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Ii(r){try{Dt.ProjectivePoint.fromHex(r)}catch(t){throw new B(String(t),"ERR_INVALID_PUBLIC_KEY")}}function oc(r){try{return Dt.getPublicKey(r,!0)}catch(t){throw new B(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Pr=class{_key;constructor(t){Ii(t),this._key=t}verify(t,e){return nc(this._key,e,t)}marshal(){return sc(this._key)}get bytes(){return Qt.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}async hash(){let t=ht.digest(this.bytes),e;return St(t)?{bytes:e}=await t:e=t.bytes,e}},Mr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??oc(t),ic(this._key),Ii(this._publicKey)}sign(t){return rc(this._key,t)}get public(){return new Pr(this._publicKey)}marshal(){return this._key}get bytes(){return Kt.encode({Type:rt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return kt(this.bytes,t.bytes)}hash(){let t=ht.digest(this.bytes);return St(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 sr(this.bytes,t);throw new B(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function oh(r){return new Mr(r)}function ah(r){return new Pr(r)}async function ch(){let r=ec();return new Mr(r)}var Fr={rsa:Bi,ed25519:hi,secp256k1:Ri};function ac(r){let t=Object.keys(Fr).join(" / ");return new B(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function lh(r){if(r=r.toLowerCase(),r==="rsa"||r==="ed25519"||r==="secp256k1")return Fr[r];throw ac(r)}async function cc(r,t){return lh(r).generateKeyPair(t??2048)}async function _i(r){let t=Kt.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return Fr.rsa.unmarshalRsaPrivateKey(e);case rt.Ed25519:return Fr.ed25519.unmarshalEd25519PrivateKey(e);case rt.Secp256k1:return Fr.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw ac(t.Type??"RSA")}}async function $r(r,t){try{let e=await Qo(r,t);return await _i(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 xi(r,t)}var Ni=(r,t)=>r<<t|r>>>32-t>>>0,uh=(r,t,e)=>r&t^~r&e,fh=(r,t,e)=>r&t^r&e^t&e,qr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Se=new Uint32Array(80),Ti=class extends he{constructor(){super(64,20,8,!1),this.A=qr[0]|0,this.B=qr[1]|0,this.C=qr[2]|0,this.D=qr[3]|0,this.E=qr[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)Se[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Se[c]=Ni(Se[c-3]^Se[c-8]^Se[c-14]^Se[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=uh(s,i,o),l=1518500249):c<40?(f=s^i^o,l=1859775393):c<60?(f=fh(s,i,o),l=2400959708):(f=s^i^o,l=3395469782);let u=Ni(n,5)+f+a+l+Se[c]|0;a=o,o=i,i=Ni(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(){Se.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},lc=tr(()=>new Ti);var uc={sha1:lc,"sha2-256":cs,"sha2-512":ge};function jr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(uc).join(" / ");throw new B(`Hash '${s}' is unknown or not supported. Must be ${a}`,"ERR_UNSUPPORTED_HASH_TYPE")}let i=uc[s],o=ra(i,r,t,{c:e,dkLen:n});return Te.encode(o).substring(1)}var hh=Symbol.for("nodejs.util.inspect.custom"),fc=Object.values(Ze).map(r=>r.decoder).reduce((r,t)=>r.or(t),Ze.identity.decoder),hc=114,Ci=36,Li=37,Yr=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()})`}[ji]=!0;toString(){return this.string==null&&(this.string=bt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Ce.createV1(hc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return kt(this.multihash.bytes,t);if(typeof t=="string")return dh(t).equals(this);if(t?.multihash?.bytes!=null)return kt(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[hh](){return`PeerId(${this.toString()})`}},hr=class extends Yr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},dr=class extends Yr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},pr=class extends Yr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function dh(r,t){if(t=t??fc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=xr(bt.decode(`z${r}`));return r.startsWith("12D")?new dr({multihash:e}):r.startsWith("16U")?new pr({multihash:e}):new hr({multihash:e})}return ph(fc.decode(r))}function ph(r){try{let t=xr(r);if(t.code===ue.code){if(t.digest.length===Ci)return new dr({multihash:t});if(t.digest.length===Li)return new pr({multihash:t})}if(t.code===ht.code)return new hr({multihash:t})}catch{return gh(Ce.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function gh(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==hc)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===ht.code)return new hr({multihash:r.multihash});if(t.code===ue.code){if(t.digest.length===Ci)return new dr({multihash:r.multihash});if(t.digest.length===Li)return new pr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function dc(r,t){return r.length===Ci?new dr({multihash:Vt(ue.code,r),privateKey:t}):r.length===Li?new pr({multihash:Vt(ue.code,r),privateKey:t}):new hr({multihash:await ht.digest(r),publicKey:r,privateKey:t})}var ae="/",pc=new TextEncoder().encode(ae),ls=pc[0],Gr=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]!==ls)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(ae))}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=pc),this._buf[0]!==ls){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ls,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ls;)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(ae).slice(1)}type(){return yh(this.baseNamespace())}name(){return mh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ae)||(t+=ae),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ae):new r(t.slice(0,-1).join(ae))}child(t){return this.toString()===ae?t:t.toString()===ae?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(),...bh(t.map(e=>e.namespaces()))])}};function yh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function mh(r){let t=r.split(":");return t[t.length-1]}function bh(r){return[].concat(...r)}var Bc=ps(vc(),1),Ac=Bc.default;var Uc=ps(Lc(),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 Vh="/pkcs8/",Dc="/info/",Fe=new WeakMap,$e={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},Di={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function ce(r){return r==null||typeof r!="string"?!1:r===(0,Uc.default)(r.trim())&&r.length>0}async function z(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function qt(r){return new Gr(Vh+r)}function Ie(r){return new Gr(Dc+r)}var hs=class{components;init;log;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=Ac(Di,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<$e.minKeyLength)throw new Error(`dek.keyLength must be least ${$e.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<$e.minSaltLength)throw new Error(`dek.saltLength must be least ${$e.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<$e.minIterationCount)throw new Error(`dek.iterationCount must be least ${$e.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?jr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Fe.set(this,{dek:n})}static generateOptions(){let t=Object.assign({},Di),e=Math.ceil($e.minSaltLength/3)*3;return t.dek.salt=W(Pt(e),"base64"),t}static get options(){return Di}async createKey(t,e,n=2048){if(!ce(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=qt(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 cc(e,n),c=await a.id(),f=Fe.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:Dc},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(!ce(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(!ce(t)||t==="self")throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);let e=qt(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(!ce(t)||t==="self")throw await z(),new B(`Invalid old key name '${t}'`,M.ERR_OLD_KEY_NAME_INVALID);if(!ce(e)||e==="self")throw await z(),new B(`Invalid new key name '${e}'`,M.ERR_NEW_KEY_NAME_INVALID);let n=qt(t),s=qt(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(!ce(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=qt(t);try{let s=await this.components.datastore.get(n),i=W(s),o=Fe.get(this);if(o==null)throw new B("dek missing",M.ERR_INVALID_PARAMETERS);let a=o.dek;return await(await $r(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 $r(n,e);return dc(s.public.bytes,s.bytes)}async importKey(t,e,n){if(!ce(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=qt(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 $r(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=Fe.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(!ce(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 _i(e.privateKey),s=qt(t);if(await this.components.datastore.has(s))throw await z(),new B(`Key '${t}' already exists`,M.ERR_KEY_ALREADY_EXISTS);let o=Fe.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(!ce(t))throw await z(),new B(`Invalid key name '${t}'`,M.ERR_INVALID_KEY_NAME);try{let e=qt(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=Fe.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?jr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Fe.set(this,{dek:i});let o=await this.listKeys();for(let a of o){let c=await this.components.datastore.get(qt(a.name)),f=W(c),l=await $r(f,s),u=i.toString(),d=await l.export(u),w=this.components.datastore.batch(),p={name:a.name,id:a.id};w.put(qt(a.name),F(d)),w.put(Ie(a.name),F(JSON.stringify(p))),await w.commit()}this.log("keychain reconstructed")}};function Oh(r={}){return t=>new hs(t,r)}return Wc(Hh);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
{
|
|
2
|
+
"DEKConfig": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.DEKConfig.html",
|
|
3
|
+
".:DEKConfig": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.DEKConfig.html",
|
|
4
|
+
"KeyInfo": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.KeyInfo.html",
|
|
5
|
+
".:KeyInfo": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.KeyInfo.html",
|
|
6
|
+
"Keychain": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.Keychain.html",
|
|
7
|
+
".:Keychain": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.Keychain.html",
|
|
8
|
+
"KeychainComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.KeychainComponents.html",
|
|
9
|
+
".:KeychainComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.KeychainComponents.html",
|
|
10
|
+
"KeychainInit": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.KeychainInit.html",
|
|
11
|
+
".:KeychainInit": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_keychain.KeychainInit.html",
|
|
12
|
+
"keychain": "https://libp2p.github.io/js-libp2p/functions/_libp2p_keychain.keychain-1.html",
|
|
13
|
+
".:keychain": "https://libp2p.github.io/js-libp2p/functions/_libp2p_keychain.keychain-1.html"
|
|
14
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/keychain",
|
|
3
|
-
"version": "4.0.
|
|
3
|
+
"version": "4.0.8",
|
|
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",
|
|
@@ -58,20 +58,20 @@
|
|
|
58
58
|
"test:electron-main": "aegir test -t electron-main"
|
|
59
59
|
},
|
|
60
60
|
"dependencies": {
|
|
61
|
-
"@libp2p/crypto": "4.0.
|
|
62
|
-
"@libp2p/interface": "1.1.
|
|
63
|
-
"@libp2p/peer-id": "4.0.
|
|
64
|
-
"interface-datastore": "^8.2.
|
|
61
|
+
"@libp2p/crypto": "^4.0.2",
|
|
62
|
+
"@libp2p/interface": "^1.1.3",
|
|
63
|
+
"@libp2p/peer-id": "^4.0.6",
|
|
64
|
+
"interface-datastore": "^8.2.10",
|
|
65
65
|
"merge-options": "^3.0.4",
|
|
66
|
-
"multiformats": "^13.0.
|
|
66
|
+
"multiformats": "^13.0.1",
|
|
67
67
|
"sanitize-filename": "^1.6.3",
|
|
68
|
-
"uint8arrays": "^5.0.
|
|
68
|
+
"uint8arrays": "^5.0.1"
|
|
69
69
|
},
|
|
70
70
|
"devDependencies": {
|
|
71
|
-
"@libp2p/logger": "4.0.
|
|
72
|
-
"@libp2p/peer-id-factory": "4.0.
|
|
73
|
-
"aegir": "^42.
|
|
74
|
-
"datastore-core": "^9.
|
|
71
|
+
"@libp2p/logger": "^4.0.6",
|
|
72
|
+
"@libp2p/peer-id-factory": "^4.0.6",
|
|
73
|
+
"aegir": "^42.2.3",
|
|
74
|
+
"datastore-core": "^9.2.7"
|
|
75
75
|
},
|
|
76
76
|
"sideEffects": false
|
|
77
77
|
}
|