@libp2p/keychain 5.1.3 → 5.1.4-0b9090aea
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.js +3 -3
- package/dist/src/utils/export.d.ts +5 -1
- package/dist/src/utils/export.d.ts.map +1 -1
- package/dist/src/utils/export.js +14 -0
- package/dist/src/utils/export.js.map +1 -1
- package/package.json +4 -4
- package/src/utils/export.ts +16 -1
- package/dist/typedoc-urls.json +0 -14
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 ll=Object.create;var Zr=Object.defineProperty;var ul=Object.getOwnPropertyDescriptor;var fl=Object.getOwnPropertyNames;var hl=Object.getPrototypeOf,dl=Object.prototype.hasOwnProperty;var Ee=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ut=(r,t)=>{for(var e in t)Zr(r,e,{get:t[e],enumerable:!0})},ni=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of fl(t))!dl.call(r,s)&&s!==e&&Zr(r,s,{get:()=>t[s],enumerable:!(n=ul(t,s))||n.enumerable});return r};var Ss=(r,t,e)=>(e=r!=null?ll(hl(r)):{},ni(t||!r||!r.__esModule?Zr(e,"default",{value:r,enumerable:!0}):e,r)),pl=r=>ni(Zr({},"__esModule",{value:!0}),r);var $a=Ee((Km,ja)=>{"use strict";ja.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var Ya=Ee((Wa,Ja)=>{"use strict";var Un=$a(),{hasOwnProperty:Ga}=Object.prototype,{propertyIsEnumerable:oh}=Object,sr=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),ih=Wa,za={concatArrays:!1,ignoreUndefined:!1},Tn=r=>{let t=[];for(let e in r)Ga.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)oh.call(r,n)&&t.push(n)}return t};function or(r){return Array.isArray(r)?ah(r):Un(r)?ch(r):r}function ah(r){let t=r.slice(0,0);return Tn(r).forEach(e=>{sr(t,e,or(r[e]))}),t}function ch(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return Tn(r).forEach(e=>{sr(t,e,or(r[e]))}),t}var Za=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?sr(r,s,Mo(r[s],t[s],n)):sr(r,s,or(t[s])))}),r),lh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)Ga.call(o,a)&&(i.push(String(a)),o===r?sr(n,s++,o[a]):sr(n,s++,or(o[a])));n=Za(n,o,Tn(o).filter(a=>!i.includes(a)),e)}),n};function Mo(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?lh(r,t,e):!Un(t)||!Un(r)?or(t):Za(r,t,Tn(t),e)}Ja.exports=function(...r){let t=Mo(or(za),this!==ih&&this||{},za),e={_:{}};for(let n of r)if(n!==void 0){if(!Un(n))throw new TypeError("`"+n+"` is not an Option Object");e=Mo(e,{_:n},t)}return e._}});var ec=Ee((Pm,tc)=>{"use strict";function uh(r){return r>=55296&&r<=56319}function fh(r){return r>=56320&&r<=57343}tc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],uh(i)&&fh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var nc=Ee((Fm,rc)=>{"use strict";function hh(r){return r>=55296&&r<=56319}function dh(r){return r>=56320&&r<=57343}rc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),dh(s)?o!=null&&hh(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var oc=Ee((qm,sc)=>{"use strict";var ph=ec(),gh=nc();sc.exports=ph.bind(null,gh)});var cc=Ee((jm,ac)=>{"use strict";var mh=oc(),yh=/[\/\?<>\\:\*\|"]/g,bh=/[\x00-\x1f\x80-\x9f]/g,wh=/^\.+$/,xh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,vh=/[\. ]+$/;function ic(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(yh,t).replace(bh,t).replace(wh,t).replace(xh,t).replace(vh,t);return mh(e,255)}ac.exports=function(r,t){var e=t&&t.replacement||"",n=ic(r,e);return e===""?n:ic(n,"")}});var lc=Ee(ar=>{"use strict";var Eh="[object ArrayBuffer]",Yt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Eh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},Po="string",Ah=/^[0-9a-f\s]+$/i,Sh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,kh=/^[a-zA-Z0-9-_]+$/,Rn=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=Yt.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},St=class{static toString(t,e=!1){let n=Yt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},Vn=class r{static isHex(t){return typeof t===Po&&Ah.test(t)}static isBase64(t){return typeof t===Po&&Sh.test(t)}static isBase64Url(t){return typeof t===Po&&kh.test(t)}static ToString(t,e="utf8"){let n=Yt.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=Yt.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 Rn.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 Rn.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=Yt.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Yt.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return 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,"")||""}};Vn.DEFAULT_UTF8_ENCODING="utf8";function Ih(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function Nh(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function Ch(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=Yt;ar.Convert=Vn;ar.assign=Ih;ar.combine=Nh;ar.isEqual=Ch});var $h={};ut($h,{keychain:()=>jh});var hr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},dr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Wr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var si={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Wr("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var yt=si;var O=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ke=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},pr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var Jr=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Me=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var oi=Symbol.for("@libp2p/service-capabilities"),Qh=Symbol.for("@libp2p/service-dependencies");var Us={};ut(Us,{base58btc:()=>nt,base58flickr:()=>xl});var Bd=new Uint8Array(0);function ii(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Pt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function ai(r){return new TextEncoder().encode(r)}function ci(r){return new TextDecoder().decode(r)}function gl(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var y=0,d=0,w=0,B=b.length;w!==B&&b[w]===0;)w++,y++;for(var p=(B-w)*l+1>>>0,S=new Uint8Array(p);w!==B;){for(var L=b[w],T=0,I=p-1;(L!==0||T<d)&&I!==-1;I--,T++)L+=256*S[I]>>>0,S[I]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");d=T,w++}for(var U=p-d;U!==p&&S[U]===0;)U++;for(var N=c.repeat(y);U<p;++U)N+=r.charAt(S[U]);return N}function h(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var y=0;if(b[y]!==" "){for(var d=0,w=0;b[y]===c;)d++,y++;for(var B=(b.length-y)*f+1>>>0,p=new Uint8Array(B);b[y];){var S=e[b.charCodeAt(y)];if(S===255)return;for(var L=0,T=B-1;(S!==0||L<w)&&T!==-1;T--,L++)S+=a*p[T]>>>0,p[T]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");w=L,y++}if(b[y]!==" "){for(var I=B-w;I!==B&&p[I]===0;)I++;for(var U=new Uint8Array(d+(B-I)),N=d;I!==B;)U[N++]=p[I++];return U}}}function m(b){var y=h(b);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:m}}var ml=gl,yl=ml,ui=yl;var ks=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")}},Is=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return fi(this,t)}},Ns=class{decoders;constructor(t){this.decoders=t}or(t){return fi(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 fi(r,t){return new Ns({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Cs=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 ks(t,e,n),this.decoder=new Is(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Pe({name:r,prefix:t,encode:e,decode:n}){return new Cs(r,t,e,n)}function se({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=ui(e,r);return Pe({prefix:t,name:r,encode:n,decode:o=>Pt(s(o))})}function bl(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++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,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function wl(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pe({prefix:t,name:r,encode(s){return wl(s,n,e)},decode(s){return bl(s,n,e,r)}})}var nt=se({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),xl=se({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ts={};ut(Ts,{base32:()=>Fe,base32hex:()=>Al,base32hexpad:()=>kl,base32hexpadupper:()=>Il,base32hexupper:()=>Sl,base32pad:()=>Bl,base32padupper:()=>El,base32upper:()=>vl,base32z:()=>Nl});var Fe=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),vl=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Bl=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),El=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Al=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Sl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),kl=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Il=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Nl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ls={};ut(Ls,{base36:()=>gr,base36upper:()=>Cl});var gr=se({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Cl=se({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ul=pi,hi=128,Tl=127,Ll=~Tl,Rl=Math.pow(2,31);function pi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Rl;)t[e++]=r&255|hi,r/=128;for(;r⋘)t[e++]=r&255|hi,r>>>=7;return t[e]=r|0,pi.bytes=e-n+1,t}var Vl=Rs,Ol=128,di=127;function Rs(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Rs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&di)<<s:(i&di)*Math.pow(2,s),s+=7}while(i>=Ol);return Rs.bytes=o-n,e}var Hl=Math.pow(2,7),_l=Math.pow(2,14),Dl=Math.pow(2,21),Kl=Math.pow(2,28),Ml=Math.pow(2,35),Pl=Math.pow(2,42),Fl=Math.pow(2,49),ql=Math.pow(2,56),jl=Math.pow(2,63),$l=function(r){return r<Hl?1:r<_l?2:r<Dl?3:r<Kl?4:r<Ml?5:r<Pl?6:r<Fl?7:r<ql?8:r<jl?9:10},zl={encode:Ul,decode:Vl,encodingLength:$l},Gl=zl,mr=Gl;function yr(r,t=0){return[mr.decode(r,t),mr.decode.bytes]}function qe(r,t,e=0){return mr.encode(r,t,e),t}function je(r){return mr.encodingLength(r)}function kt(r,t){let e=t.byteLength,n=je(r),s=n+je(e),o=new Uint8Array(s+e);return qe(r,o,0),qe(e,o,n),o.set(t,s),new $e(r,e,t,o)}function gi(r){let t=Pt(r),[e,n]=yr(t),[s,o]=yr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new $e(e,s,i,t)}function mi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ii(r.bytes,e.bytes)}}var $e=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function yi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Wl(e,Vs(r),t??nt.encoder);default:return Jl(e,Vs(r),t??Fe.encoder)}}var bi=new WeakMap;function Vs(r){let t=bi.get(r);if(t==null){let e=new Map;return bi.set(r,e),e}return t}var Ht=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==wr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Yl)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=kt(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&&mi(t.multihash,n.multihash)}toString(t){return yi(this,t)}toJSON(){return{"/":yi(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??wi(n,s,o.bytes))}else if(e[Xl]===!0){let{version:n,multihash:s,code:o}=e,i=gi(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==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=wi(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=Pt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new $e(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=yr(t.subarray(e));return e+=h,u},s=n(),o=wr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=Zl(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Vs(o).set(n,t),o}};function Zl(r,t){switch(r[0]){case"Q":{let e=t??nt;return[nt.prefix,e.decode(`${nt.prefix}${r}`)]}case nt.prefix:{let e=t??nt;return[nt.prefix,e.decode(r)]}case Fe.prefix:{let e=t??Fe;return[Fe.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Wl(r,t,e){let{prefix:n}=e;if(n!==nt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function Jl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var wr=112,Yl=18;function wi(r,t,e){let n=je(r),s=n+je(t),o=new Uint8Array(s+e.byteLength);return qe(r,o,0),qe(t,o,n),o.set(e,s),o}var Xl=Symbol.for("@ipld/js-cid/CID");var Os={};ut(Os,{identity:()=>xr});var xi=0,Ql="identity",vi=Pt;function tu(r){return kt(xi,vi(r))}var xr={code:xi,name:Ql,encode:vi,digest:tu};function It(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function eu(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ge(r,...t){if(!eu(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function Xr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ze(r.outputLen),ze(r.blockLen)}function 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 Bi(r,t){Ge(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ae=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Se(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Nt(r,t){return r<<32-t|r>>>t}function Qr(r,t){return r<<t|r>>>32-t>>>0}var ru=async()=>{};async function Ei(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await ru(),n+=o)}}function Ai(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function oe(r){return typeof r=="string"&&(r=Ai(r)),Ge(r),r}function Hs(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Ge(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var We=class{clone(){return this._cloneInto()}};function Si(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Je(r){let t=n=>r().update(oe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ye(r=32){if(Ae&&typeof Ae.getRandomValues=="function")return Ae.getRandomValues(new Uint8Array(r));if(Ae&&typeof Ae.randomBytes=="function")return Ae.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function nu(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function tn(r,t,e){return r&t^~r&e}function en(r,t,e){return r&t^r&e^t&e}var ie=class extends We{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Se(this.buffer)}update(t){Ze(this);let{view:e,buffer:n,blockLen:s}=this;t=oe(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Se(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ze(this),Bi(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;nu(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Se(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let 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],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var rn=BigInt(4294967295),_s=BigInt(32);function ki(r,t=!1){return t?{h:Number(r&rn),l:Number(r>>_s&rn)}:{h:Number(r>>_s&rn)|0,l:Number(r&rn)|0}}function su(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=ki(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var ou=(r,t)=>BigInt(r>>>0)<<_s|BigInt(t>>>0),iu=(r,t,e)=>r>>>e,au=(r,t,e)=>r<<32-e|t>>>e,cu=(r,t,e)=>r>>>e|t<<32-e,lu=(r,t,e)=>r<<32-e|t>>>e,uu=(r,t,e)=>r<<64-e|t>>>e-32,fu=(r,t,e)=>r>>>e-32|t<<64-e,hu=(r,t)=>t,du=(r,t)=>r,pu=(r,t,e)=>r<<e|t>>>32-e,gu=(r,t,e)=>t<<e|r>>>32-e,mu=(r,t,e)=>t<<e-32|r>>>64-e,yu=(r,t,e)=>r<<e-32|t>>>64-e;function bu(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var wu=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),xu=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,vu=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Bu=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Eu=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Au=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Su={fromBig:ki,split:su,toBig:ou,shrSH:iu,shrSL:au,rotrSH:cu,rotrSL:lu,rotrBH:uu,rotrBL:fu,rotr32H:hu,rotr32L:du,rotlSH:pu,rotlSL:gu,rotlBH:mu,rotlBL:yu,add:bu,add3L:wu,add3H:xu,add4L:vu,add4H:Bu,add5H:Au,add5L:Eu},_=Su;var[ku,Iu]=_.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ae=new Uint32Array(80),ce=new Uint32Array(80),Ds=class extends ie{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:m,Gl:b,Hh:y,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,m,b,y,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,m,b,y,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=m|0,this.Gl=b|0,this.Hh=y|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)ae[p]=t.getUint32(e),ce[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=ae[p-15]|0,L=ce[p-15]|0,T=_.rotrSH(S,L,1)^_.rotrSH(S,L,8)^_.shrSH(S,L,7),I=_.rotrSL(S,L,1)^_.rotrSL(S,L,8)^_.shrSL(S,L,7),U=ae[p-2]|0,N=ce[p-2]|0,G=_.rotrSH(U,N,19)^_.rotrBH(U,N,61)^_.shrSH(U,N,6),F=_.rotrSL(U,N,19)^_.rotrBL(U,N,61)^_.shrSL(U,N,6),K=_.add4L(I,F,ce[p-7],ce[p-16]),Q=_.add4H(K,T,G,ae[p-7],ae[p-16]);ae[p]=Q|0,ce[p]=K|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:m,Fl:b,Gh:y,Gl:d,Hh:w,Hl:B}=this;for(let p=0;p<80;p++){let S=_.rotrSH(u,h,14)^_.rotrSH(u,h,18)^_.rotrBH(u,h,41),L=_.rotrSL(u,h,14)^_.rotrSL(u,h,18)^_.rotrBL(u,h,41),T=u&m^~u&y,I=h&b^~h&d,U=_.add5L(B,L,I,Iu[p],ce[p]),N=_.add5H(U,w,S,T,ku[p],ae[p]),G=U|0,F=_.rotrSH(n,s,28)^_.rotrBH(n,s,34)^_.rotrBH(n,s,39),K=_.rotrSL(n,s,28)^_.rotrBL(n,s,34)^_.rotrBL(n,s,39),Q=n&o^n&a^o&a,E=s&i^s&c^i&c;w=y|0,B=d|0,y=m|0,d=b|0,m=u|0,b=h|0,{h:u,l:h}=_.add(f|0,l|0,N|0,G|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let C=_.add3L(G,K,E);n=_.add3H(C,N,F,Q),s=C|0}({h:n,l:s}=_.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=_.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=_.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=_.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=_.add(this.Eh|0,this.El|0,u|0,h|0),{h:m,l:b}=_.add(this.Fh|0,this.Fl|0,m|0,b|0),{h:y,l:d}=_.add(this.Gh|0,this.Gl|0,y|0,d|0),{h:w,l:B}=_.add(this.Hh|0,this.Hl|0,w|0,B|0),this.set(n,s,o,i,a,c,f,l,u,h,m,b,y,d,w,B)}roundClean(){ae.fill(0),ce.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var le=Je(()=>new Ds);var on={};ut(on,{aInRange:()=>bt,abool:()=>Ct,abytes:()=>Xe,bitGet:()=>Ru,bitLen:()=>Fs,bitMask:()=>Br,bitSet:()=>Vu,bytesToHex:()=>qt,bytesToNumberBE:()=>jt,bytesToNumberLE:()=>fe,concatBytes:()=>$t,createHmacDrbg:()=>qs,ensureBytes:()=>J,equalBytes:()=>Tu,hexToBytes:()=>Ie,hexToNumber:()=>Ps,inRange:()=>vr,isBytes:()=>ue,memoized:()=>Ce,notImplemented:()=>Hu,numberToBytesBE:()=>he,numberToBytesLE:()=>Ne,numberToHexUnpadded:()=>ke,numberToVarBytesBE:()=>Uu,utf8ToBytes:()=>Lu,validateObject:()=>_t});var nn=BigInt(0),sn=BigInt(1),Nu=BigInt(2);function ue(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Xe(r){if(!ue(r))throw new Error("Uint8Array expected")}function Ct(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Cu=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qt(r){Xe(r);let t="";for(let e=0;e<r.length;e++)t+=Cu[r[e]];return t}function ke(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ps(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?nn:BigInt("0x"+r)}var Ft={_0:48,_9:57,A:65,F:70,a:97,f:102};function Ii(r){if(r>=Ft._0&&r<=Ft._9)return r-Ft._0;if(r>=Ft.A&&r<=Ft.F)return r-(Ft.A-10);if(r>=Ft.a&&r<=Ft.f)return r-(Ft.a-10)}function Ie(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=Ii(r.charCodeAt(o)),a=Ii(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function jt(r){return Ps(qt(r))}function fe(r){return Xe(r),Ps(qt(Uint8Array.from(r).reverse()))}function he(r,t){return Ie(r.toString(16).padStart(t*2,"0"))}function Ne(r,t){return he(r,t).reverse()}function Uu(r){return Ie(ke(r))}function J(r,t,e){let n;if(typeof t=="string")try{n=Ie(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(ue(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function $t(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Xe(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Tu(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 Lu(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Ks=r=>typeof r=="bigint"&&nn<=r;function vr(r,t,e){return Ks(r)&&Ks(t)&&Ks(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!vr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Fs(r){let t;for(t=0;r>nn;r>>=sn,t+=1);return t}function Ru(r,t){return r>>BigInt(t)&sn}function Vu(r,t,e){return r|(e?sn:nn)<<BigInt(t)}var Br=r=>(Nu<<BigInt(r-1))-sn,Ms=r=>new Uint8Array(r),Ni=r=>Uint8Array.from(r);function qs(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Ms(r),s=Ms(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=Ms())=>{s=a(Ni([0]),u),n=a(),u.length!==0&&(s=a(Ni([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let m=n.slice();h.push(m),u+=n.length}return $t(...h)};return(u,h)=>{i(),c(u);let m;for(;!(m=h(f()));)c();return i(),m}}var Ou={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||ue(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function _t(r,t,e={}){let n=(s,o,i)=>{let a=Ou[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var Hu=()=>{throw new Error("not implemented")};function Ce(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var tt=BigInt(0),Z=BigInt(1),Ue=BigInt(2),_u=BigInt(3),js=BigInt(4),Ci=BigInt(5),Ui=BigInt(8),Du=BigInt(9),Ku=BigInt(16);function $(r,t){let e=r%t;return e>=tt?e:t+e}function Mu(r,t,e){if(t<tt)throw new Error("invalid exponent, negatives unsupported");if(e<=tt)throw new Error("invalid modulus");if(e===Z)return tt;let n=Z;for(;t>tt;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function W(r,t,e){let n=r;for(;t-- >tt;)n*=n,n%=e;return n}function an(r,t){if(r===tt)throw new Error("invert: expected non-zero number");if(t<=tt)throw new Error("invert: expected positive modulus, got "+t);let e=$(r,t),n=t,s=tt,o=Z,i=Z,a=tt;for(;e!==tt;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==Z)throw new Error("invert: does not exist");return $(s,t)}function Pu(r){let t=(r-Z)/Ue,e,n,s;for(e=r-Z,n=0;e%Ue===tt;e/=Ue,n++);for(s=Ue;s<r&&Mu(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/js;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(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,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let m=1;for(let y=a.sqr(h);m<f&&!a.eql(y,a.ONE);m++)y=a.sqr(y);let b=a.pow(l,Z<<BigInt(f-m-1));l=a.sqr(b),u=a.mul(u,b),h=a.mul(h,l),f=m}return u}}function Fu(r){if(r%js===_u){let t=(r+Z)/js;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%Ui===Ci){let t=(r-Ci)/Ui;return function(n,s){let o=n.mul(s,Ue),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ue),i),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%Ku,Pu(r)}var Ti=(r,t)=>($(r,t)&Z)===Z,qu=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function $s(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=qu.reduce((n,s)=>(n[s]="function",n),t);return _t(r,e)}function ju(r,t,e){if(e<tt)throw new Error("invalid exponent, negatives unsupported");if(e===tt)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>tt;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function $u(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function zs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function de(r,t,e=!1,n={}){if(r<=tt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=zs(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Br(s),ZERO:tt,ONE:Z,create:c=>$(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return tt<=c&&c<r},is0:c=>c===tt,isOdd:c=>(c&Z)===Z,neg:c=>$(-c,r),eql:(c,f)=>c===f,sqr:c=>$(c*c,r),add:(c,f)=>$(c+f,r),sub:(c,f)=>$(c-f,r),mul:(c,f)=>$(c*f,r),pow:(c,f)=>ju(a,c,f),div:(c,f)=>$(c*an(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>an(c,r),sqrt:n.sqrt||(c=>(i||(i=Fu(r)),i(a,c))),invertBatch:c=>$u(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Ne(c,o):he(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?fe(c):jt(c)}});return Object.freeze(a)}function Li(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=Li(r);return t+Math.ceil(t/2)}function Ri(r,t,e=!1){let n=r.length,s=Li(t),o=Gs(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?fe(r):jt(r),a=$(i,t-Z)+Z;return e?Ne(a,s):he(a,s)}var Vi=BigInt(0),cn=BigInt(1);function Zs(r,t){let e=t.negate();return r?e:t}function Oi(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Ws(r,t){Oi(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function zu(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Gu(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Js=new WeakMap,Hi=new WeakMap;function Ys(r){return Hi.get(r)||1}function ln(r,t){return{constTimeNegate:Zs,hasPrecomputes(e){return Ys(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>Vi;)n&cn&&(s=s.add(o)),o=o.double(),n>>=cn;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=Ws(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=Ws(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let h=0;h<o;h++){let m=h*i,b=Number(s&f);s>>=u,b>i&&(b-=l,s+=cn);let y=m,d=m+Math.abs(b)-1,w=h%2!==0,B=b<0;b===0?c=c.add(Zs(w,n[y])):a=a.add(Zs(B,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=Ws(e,t),c=BigInt(2**e-1),f=2**e,l=BigInt(e);for(let u=0;u<i;u++){let h=u*a;if(s===Vi)break;let m=Number(s&c);if(s>>=l,m>a&&(m-=f,s+=cn),m===0)continue;let b=n[h+Math.abs(m)-1];m<0&&(b=b.negate()),o=o.add(b)}return o},getPrecomputes(e,n,s){let o=Js.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&Js.set(n,s(o))),o},wNAFCached(e,n,s){let o=Ys(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=Ys(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){Oi(n,t),Hi.set(e,n),Js.delete(e)}}}function un(r,t,e,n){if(zu(e,r),Gu(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=Fs(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let m=0;m<n.length;m++){let b=n[m],y=Number(b>>BigInt(u)&BigInt(a));c[y]=c[y].add(e[m])}let h=s;for(let m=c.length-1,b=s;m>0;m--)b=b.add(c[m]),h=h.add(b);if(l=l.add(h),u!==0)for(let m=0;m<i;m++)l=l.double()}return l}function Er(r){return $s(r.Fp),_t(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...zs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ut=BigInt(0),wt=BigInt(1),fn=BigInt(2),Zu=BigInt(8),Wu={zip215:!0};function Ju(r){let t=Er(r);return _t(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function _i(r){let t=Ju(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=fn<<BigInt(a*8)-wt,l=e.create,u=de(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:Ut}}}),m=t.adjustScalarBytes||(x=>x),b=t.domain||((x,g,v)=>{if(Ct("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function y(x,g){bt("coordinate "+x,g,Ut,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let w=Ce((x,g)=>{let{ex:v,ey:k,ez:R}=x,V=x.is0();g==null&&(g=V?Zu:e.inv(R));let D=l(v*g),P=l(k*g),H=l(R*g);if(V)return{x:Ut,y:wt};if(H!==wt)throw new Error("invZ was invalid");return{x:D,y:P}}),B=Ce(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:R,ez:V,et:D}=x,P=l(k*k),H=l(R*R),j=l(V*V),z=l(j*j),et=l(P*g),rt=l(j*l(et+H)),it=l(z+l(v*l(P*H)));if(rt!==it)throw new Error("bad point: equation left != right (1)");let lt=l(k*R),mt=l(V*D);if(lt!==mt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,R){this.ex=g,this.ey=v,this.ez=k,this.et=R,y("x",g),y("y",v),y("z",k),y("t",R),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return y("x",v),y("y",k),new p(v,k,wt,l(v*k))}static normalizeZ(g){let v=e.invertBatch(g.map(k=>k.ez));return g.map((k,R)=>k.toAffine(v[R])).map(p.fromAffine)}static msm(g,v){return un(p,u,g,v)}_setWindowSize(g){T.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:v,ey:k,ez:R}=this,{ex:V,ey:D,ez:P}=g,H=l(v*P),j=l(V*R),z=l(k*P),et=l(D*R);return H===j&&z===et}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:R}=this,V=l(v*v),D=l(k*k),P=l(fn*l(R*R)),H=l(g*V),j=v+k,z=l(l(j*j)-V-D),et=H+D,rt=et-P,it=H-D,lt=l(z*rt),mt=l(et*it),dt=l(z*it),Ot=l(rt*et);return new p(lt,mt,Ot,dt)}add(g){d(g);let{a:v,d:k}=t,{ex:R,ey:V,ez:D,et:P}=this,{ex:H,ey:j,ez:z,et}=g;if(v===BigInt(-1)){let Jo=l((V-R)*(j+H)),Yo=l((V+R)*(j-H)),As=l(Yo-Jo);if(As===Ut)return this.double();let Xo=l(D*fn*et),Qo=l(P*fn*z),ti=Qo+Xo,ei=Yo+Jo,ri=Qo-Xo,ol=l(ti*As),il=l(ei*ri),al=l(ti*ri),cl=l(As*ei);return new p(ol,il,cl,al)}let rt=l(R*H),it=l(V*j),lt=l(P*k*et),mt=l(D*z),dt=l((R+V)*(H+j)-rt-it),Ot=mt-lt,Mt=mt+lt,fr=l(it-v*rt),el=l(dt*Ot),rl=l(Mt*fr),nl=l(dt*fr),sl=l(Ot*Mt);return new p(el,rl,sl,nl)}subtract(g){return this.add(g.negate())}wNAF(g){return T.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;bt("scalar",v,wt,n);let{p:k,f:R}=this.wNAF(v);return p.normalizeZ([k,R])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return bt("scalar",k,Ut,n),k===Ut?L:this.is0()||k===wt?this:T.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return T.unsafeLadder(this,n).is0()}toAffine(g){return w(this,g)}clearCofactor(){let{h:g}=t;return g===wt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:R}=t,V=e.BYTES;g=J("pointHex",g,V),Ct("zip215",v);let D=g.slice(),P=g[V-1];D[V-1]=P&-129;let H=fe(D),j=v?f:e.ORDER;bt("pointHex.y",H,Ut,j);let z=l(H*H),et=l(z-wt),rt=l(k*z-R),{isValid:it,value:lt}=h(et,rt);if(!it)throw new Error("Point.fromHex: invalid y coordinate");let mt=(lt&wt)===wt,dt=(P&128)!==0;if(!v&<===Ut&&dt)throw new Error("Point.fromHex: x=0 and x_0=1");return dt!==mt&&(lt=l(-lt)),p.fromAffine({x:lt,y:H})}static fromPrivateKey(g){return N(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=Ne(v,e.BYTES);return k[k.length-1]|=g&wt?128:0,k}toHex(){return qt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,wt,l(t.Gx*t.Gy)),p.ZERO=new p(Ut,wt,wt,Ut);let{BASE:S,ZERO:L}=p,T=ln(p,a*8);function I(x){return $(x,n)}function U(x){return I(fe(x))}function N(x){let g=e.BYTES;x=J("private key",x,g);let v=J("hashed private key",o(x),2*g),k=m(v.slice(0,g)),R=v.slice(g,2*g),V=U(k),D=S.multiply(V),P=D.toRawBytes();return{head:k,prefix:R,scalar:V,point:D,pointBytes:P}}function G(x){return N(x).pointBytes}function F(x=new Uint8Array,...g){let v=$t(...g);return U(o(b(v,J("context",x),!!s)))}function K(x,g,v={}){x=J("message",x),s&&(x=s(x));let{prefix:k,scalar:R,pointBytes:V}=N(g),D=F(v.context,k,x),P=S.multiply(D).toRawBytes(),H=F(v.context,P,V,x),j=I(D+H*R);bt("signature.s",j,Ut,n);let z=$t(P,Ne(j,e.BYTES));return J("result",z,e.BYTES*2)}let Q=Wu;function E(x,g,v,k=Q){let{context:R,zip215:V}=k,D=e.BYTES;x=J("signature",x,2*D),g=J("message",g),v=J("publicKey",v,D),V!==void 0&&Ct("zip215",V),s&&(g=s(g));let P=fe(x.slice(D,2*D)),H,j,z;try{H=p.fromHex(v,V),j=p.fromHex(x.slice(0,D),V),z=S.multiplyUnsafe(P)}catch{return!1}if(!V&&H.isSmallOrder())return!1;let et=F(R,j.toRawBytes(),H.toRawBytes(),g);return j.add(H.multiplyUnsafe(et)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:G,sign:K,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var Xs=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Di=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),p0=BigInt(0),Yu=BigInt(1),Ki=BigInt(2),g0=BigInt(3),Xu=BigInt(5),Qu=BigInt(8);function tf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Xs,a=r*r%o*r%o,c=W(a,Ki,o)*a%o,f=W(c,Yu,o)*r%o,l=W(f,Xu,o)*f%o,u=W(l,t,o)*l%o,h=W(u,e,o)*u%o,m=W(h,n,o)*h%o,b=W(m,s,o)*m%o,y=W(b,s,o)*m%o,d=W(y,t,o)*l%o;return{pow_p_5_8:W(d,Ki,o)*r%o,b2:a}}function ef(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function rf(r,t){let e=Xs,n=$(t*t*t,e),s=$(n*n*t,e),o=tf(r*s).pow_p_5_8,i=$(r*n*o,e),a=$(t*i*i,e),c=i,f=$(i*Di,e),l=a===r,u=a===$(-r,e),h=a===$(-r*Di,e);return l&&(i=c),(u||h)&&(i=f),Ti(i,e)&&(i=$(-i,e)),{isValid:l||u,value:i}}var nf=de(Xs,void 0,!0),sf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:nf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Qu,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:le,randomBytes:Ye,adjustScalarBytes:ef,uvRatio:rf},Qs=_i(sf);var Ar=32,zt=64,of=32;function Mi(r,t){let e=r.subarray(0,of);return Qs.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Pi(r,t,e){return Qs.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var hn=class{type="Ed25519";raw;constructor(t){this.raw=kr(t,Ar)}toMultihash(){return xr.digest(dn(this))}toCID(){return Ht.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}verify(t,e){return Pi(this.raw,e,t)}},Sr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=kr(t,zt),this.publicKey=new hn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}sign(t){return Mi(this.raw,t)}};function to(r){if(r.length>zt){r=kr(r,zt+Ar);let n=r.subarray(0,zt),s=r.subarray(zt,r.length);return new Sr(n,s)}r=kr(r,zt);let t=r.subarray(0,zt),e=r.subarray(Ar);return new Sr(t,e)}function kr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new O(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function Gt(r=0){return new Uint8Array(r)}function Bt(r=0){return new Uint8Array(r)}var af=Math.pow(2,7),cf=Math.pow(2,14),lf=Math.pow(2,21),qi=Math.pow(2,28),ji=Math.pow(2,35),$i=Math.pow(2,42),zi=Math.pow(2,49),pt=128,pe=127;function Ir(r){if(r<af)return 1;if(r<cf)return 2;if(r<lf)return 3;if(r<qi)return 4;if(r<ji)return 5;if(r<$i)return 6;if(r<zi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Gi(r,t,e=0){switch(Ir(r)){case 8:t[e++]=r&255|pt,r/=128;case 7:t[e++]=r&255|pt,r/=128;case 6:t[e++]=r&255|pt,r/=128;case 5:t[e++]=r&255|pt,r/=128;case 4:t[e++]=r&255|pt,r>>>=7;case 3:t[e++]=r&255|pt,r>>>=7;case 2:t[e++]=r&255|pt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Zi(r,t){let e=r[t],n=0;if(n+=e&pe,e<pt||(e=r[t+1],n+=(e&pe)<<7,e<pt)||(e=r[t+2],n+=(e&pe)<<14,e<pt)||(e=r[t+3],n+=(e&pe)<<21,e<pt)||(e=r[t+4],n+=(e&pe)*qi,e<pt)||(e=r[t+5],n+=(e&pe)*ji,e<pt)||(e=r[t+6],n+=(e&pe)*$i,e<pt)||(e=r[t+7],n+=(e&pe)*zi,e<pt))return n;throw new RangeError("Could not decode varint")}var eo=new Float32Array([-0]),ge=new Uint8Array(eo.buffer);function Wi(r,t,e){eo[0]=r,t[e]=ge[0],t[e+1]=ge[1],t[e+2]=ge[2],t[e+3]=ge[3]}function Ji(r,t){return ge[0]=r[t],ge[1]=r[t+1],ge[2]=r[t+2],ge[3]=r[t+3],eo[0]}var ro=new Float64Array([-0]),ft=new Uint8Array(ro.buffer);function Yi(r,t,e){ro[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function Xi(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],ro[0]}var uf=BigInt(Number.MAX_SAFE_INTEGER),ff=BigInt(Number.MIN_SAFE_INTEGER),Et=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Te;if(t<uf&&t>ff)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Qi&&(s=0n,++n>Qi&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Te;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Te}},Te=new Et(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var Qi=4294967296n;function ta(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function ea(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function no(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Tt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function pn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var so=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 pn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Tt(this,4);return pn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Tt(this,4);let t=Ji(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Tt(this,4);let t=Xi(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Tt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ea(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Tt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Tt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Et(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Tt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Tt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Tt(this,8);let t=pn(this.buf,this.pos+=4),e=pn(this.buf,this.pos+=4);return new Et(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Zi(this.buf,this.pos);return this.pos+=Ir(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function oo(r){return new so(r instanceof Uint8Array?r:r.subarray())}function gn(r,t,e){let n=oo(r);return t.decode(n,void 0,e)}var io={};ut(io,{base10:()=>hf});var hf=se({prefix:"9",name:"base10",alphabet:"0123456789"});var ao={};ut(ao,{base16:()=>df,base16upper:()=>pf});var df=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),pf=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var co={};ut(co,{base2:()=>gf});var gf=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var lo={};ut(lo,{base256emoji:()=>xf});var na=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}"),mf=na.reduce((r,t,e)=>(r[e]=t,r),[]),yf=na.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function bf(r){return r.reduce((t,e)=>(t+=mf[e],t),"")}function wf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=yf[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var xf=Pe({prefix:"\u{1F680}",name:"base256emoji",encode:bf,decode:wf});var uo={};ut(uo,{base64:()=>Le,base64pad:()=>vf,base64url:()=>Bf,base64urlpad:()=>Ef});var Le=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),vf=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Bf=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Ef=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var fo={};ut(fo,{base8:()=>Af});var Af=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ho={};ut(ho,{identity:()=>Sf});var Sf=Pe({prefix:"\0",name:"identity",encode:r=>ci(r),decode:r=>ai(r)});var J0=new TextEncoder,Y0=new TextDecoder;var mo={};ut(mo,{sha256:()=>Qe,sha512:()=>Nf});function go({name:r,code:t,encode:e}){return new po(r,t,e)}var po=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?kt(this.code,e):e.then(n=>kt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function oa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Qe=go({name:"sha2-256",code:18,encode:oa("SHA-256")}),Nf=go({name:"sha2-512",code:19,encode:oa("SHA-512")});var yo={...ho,...co,...fo,...io,...ao,...Ts,...Ls,...Us,...uo,...lo},lp={...mo,...Os};function aa(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ia=aa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),bo=aa("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=Bt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Cf={utf8:ia,"utf-8":ia,hex:yo.base16,latin1:bo,ascii:bo,binary:bo,...yo},mn=Cf;function q(r,t="utf8"){let e=mn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function wo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return Bt(i);s+i>t&&(n=Bt(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Re=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function xo(){}var Bo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Uf=wo();function Tf(r){return globalThis.Buffer!=null?Bt(r):Uf(r)}var Cr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Re(xo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Re(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Eo((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(yn,10,Et.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Et.fromBigInt(t);return this._push(yn,e.length(),e)}uint64Number(t){return this._push(Gi,Ir(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Et.fromBigInt(t).zzEncode();return this._push(yn,e.length(),e)}sint64Number(t){let e=Et.fromNumber(t).zzEncode();return this._push(yn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(vo,1,t?1:0)}fixed32(t){return this._push(Nr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Et.fromBigInt(t);return this._push(Nr,4,e.lo)._push(Nr,4,e.hi)}fixed64Number(t){let e=Et.fromNumber(t);return this._push(Nr,4,e.lo)._push(Nr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Wi,4,t)}double(t){return this._push(Yi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(vo,1,0):this.uint32(e)._push(Rf,e,t)}string(t){let e=ta(t);return e!==0?this.uint32(e)._push(no,e,t):this._push(vo,1,0)}fork(){return this.states=new Bo(this),this.head=this.tail=new Re(xo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Re(xo,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=Tf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function vo(r,t,e){t[e]=r&255}function Lf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Eo=class extends Re{next;constructor(t,e){super(Lf,t,e),this.next=void 0}};function yn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Nr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Rf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Cr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Vf,t,r),this},Cr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Of,t,r),this});function Vf(r,t,e){t.set(r,e)}function Of(r,t,e){r.length<40?no(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function Ao(){return new Cr}function bn(r,t){let e=Ao();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var tr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(tr||(tr={}));function wn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function So(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return wn("enum",tr.VARINT,e,n)}function xn(r,t){return wn("message",tr.LENGTH_DELIMITED,r,t)}var st;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(st||(st={}));var ko;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(ko||(ko={}));(function(r){r.codec=()=>So(ko)})(st||(st={}));var me;(function(r){let t;r.codec=()=>(t==null&&(t=xn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),st.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=st.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>bn(e,r.codec()),r.decode=(e,n)=>gn(e,r.codec(),n)})(me||(me={}));var Ur;(function(r){let t;r.codec=()=>(t==null&&(t=xn((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),st.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=st.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>bn(e,r.codec()),r.decode=(e,n)=>gn(e,r.codec(),n)})(Ur||(Ur={}));var Lr={};ut(Lr,{MAX_RSA_KEY_SIZE:()=>To,generateRSAKeyPair:()=>va,jwkToJWKKeyPair:()=>Ba,jwkToPkcs1:()=>Gf,jwkToPkix:()=>Ro,jwkToRSAPrivateKey:()=>xa,pkcs1ToJwk:()=>ya,pkcs1ToRSAPrivateKey:()=>An,pkixToJwk:()=>ba,pkixToRSAPublicKey:()=>wa});var 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]),ye=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),be=new Uint32Array(64),Io=class extends ie{constructor(){super(64,32,8,!1),this.A=ye[0]|0,this.B=ye[1]|0,this.C=ye[2]|0,this.D=ye[3]|0,this.E=ye[4]|0,this.F=ye[5]|0,this.G=ye[6]|0,this.H=ye[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)be[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=be[u-15],m=be[u-2],b=Nt(h,7)^Nt(h,18)^h>>>3,y=Nt(m,17)^Nt(m,19)^m>>>10;be[u]=y+be[u-7]+b+be[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Nt(a,6)^Nt(a,11)^Nt(a,25),m=l+h+tn(a,c,f)+Hf[u]+be[u]|0,y=(Nt(n,2)^Nt(n,13)^Nt(n,22))+en(n,s,o)|0;l=f,f=c,c=a,a=i+m|0,i=o,o=s,s=n,n=m+y|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){be.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var we=Je(()=>new Io);function Y(r,t="utf8"){let e=mn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function er(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=Bt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var ua=Symbol.for("@achingbrain/uint8arraylist");function la(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function vn(r){return!!r?.[ua]}var Lt=class r{bufs;length;[ua]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(vn(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(vn(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=la(this.bufs,t);return e.buf[e.index]}set(t,e){let n=la(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(vn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return er(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:er(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!vn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let m=this.get(u+h);if(n[h]!==m){l=Math.max(1,h-a[m]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Bt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=Gt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Bt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=Gt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=Gt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=Gt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!It(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var _f=parseInt("11111",2),Co=parseInt("10000000",2),Df=parseInt("01111111",2),fa={2:Kf,3:Ff,5:Pf,6:Mf,16:No,22:No,48:No};function Tr(r,t={offset:0}){let e=r[t.offset]&_f;if(t.offset++,fa[e]!=null)return fa[e](r,t);throw new Error("No decoder for tag "+e)}function Bn(r,t){let e=0;if((r[t.offset]&Co)===Co){let n=r[t.offset]&Df,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function No(r,t){Bn(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Tr(r,t);if(n===null)break;e.push(n)}return e}function Kf(r,t){let e=Bn(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Mf(r,t){let e=Bn(r,t);return t.offset+=e,["oid-unimplemented"]}function Pf(r,t){return t.offset++,null}function Ff(r,t){let e=Bn(r,t),n=r[t.offset];t.offset++;let s=r.subarray(t.offset,t.offset+e);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return Tr(s,{offset:0})}function qf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new Lt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Uo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=qf(r.byteLength);return new Lt(Uint8Array.from([t.byteLength|Co]),t)}function At(r){let t=new Lt,e=parseInt("10000000",2);return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new Lt(Uint8Array.from([2]),Uo(t),t)}function ha(r){let t=Uint8Array.from([0]),e=new Lt(t,r);return new Lt(Uint8Array.from([3]),Uo(e),e)}function En(r){let t=new Lt;for(let e of r)t.append(e);return new Lt(Uint8Array.from([48]),Uo(t),t)}function Ve(r){if(isNaN(r)||r<=0)throw new O("random bytes length must be a Number bigger than 0");return Ye(r)}async function da(r){let t=await yt.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 jf(t);return{privateKey:e[0],publicKey:e[1]}}async function pa(r,t){let e=await yt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await yt.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 yt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return yt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function jf(r){if(r.privateKey==null||r.publicKey==null)throw new O("Private and public key are required");return Promise.all([yt.get().subtle.exportKey("jwk",r.privateKey),yt.get().subtle.exportKey("jwk",r.publicKey)])}function ma(r){if(r.kty!=="RSA")throw new O("invalid key type");if(r.n==null)throw new O("invalid key modulus");return q(r.n,"base64url").length*8}var rr=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Lr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return Ht.createV1(114,this._multihash)}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}verify(t,e){return ga(this._key,e,t)}},Rr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Lr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}sign(t){return pa(this._key,t)}};var To=8192,Lo=18,$f=1062,zf=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function ya(r){let t=Tr(r);return{n:Y(t[1],"base64url"),e:Y(t[2],"base64url"),d:Y(t[3],"base64url"),p:Y(t[4],"base64url"),q:Y(t[5],"base64url"),dp:Y(t[6],"base64url"),dq:Y(t[7],"base64url"),qi:Y(t[8],"base64url"),kty:"RSA"}}function Gf(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 O("JWK was missing components");return En([At(Uint8Array.from([0])),At(q(r.n,"base64url")),At(q(r.e,"base64url")),At(q(r.d,"base64url")),At(q(r.p,"base64url")),At(q(r.q,"base64url")),At(q(r.dp,"base64url")),At(q(r.dq,"base64url")),At(q(r.qi,"base64url"))]).subarray()}function ba(r){let t=Tr(r,{offset:0});return{kty:"RSA",n:Y(t[1][0],"base64url"),e:Y(t[1][1],"base64url")}}function Ro(r){if(r.n==null||r.e==null)throw new O("JWK was missing components");return En([zf,ha(En([At(q(r.n,"base64url")),At(q(r.e,"base64url"))]))]).subarray()}function An(r){let t=ya(r);return xa(t)}function wa(r,t){if(r.byteLength>=$f)throw new Ke("Key size is too large");let e=ba(r);if(t==null){let n=we(me.encode({Type:st.RSA,Data:r}));t=kt(Lo,n)}return new rr(e,t)}function xa(r){if(ma(r)>To)throw new O("Key size is too large");let t=Ba(r),e=we(me.encode({Type:st.RSA,Data:Ro(t.publicKey)})),n=kt(Lo,e);return new Rr(t.privateKey,new rr(t.publicKey,n))}async function va(r){if(r>To)throw new O("Key size is too large");let t=await da(r),e=we(me.encode({Type:st.RSA,Data:Ro(t.publicKey)})),n=kt(Lo,e);return new Rr(t.privateKey,new rr(t.publicKey,n))}function Ba(r){if(r==null)throw new O("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Sn=class extends We{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Xr(t);let n=oe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return Ze(this),this.iHash.update(t),this}digestInto(t){Ze(this),Ge(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Vr=(r,t,e)=>new Sn(r,t).update(e).digest();Vr.create=(r,t)=>new Sn(r,t);function Ea(r){r.lowS!==void 0&&Ct("lowS",r.lowS),r.prehash!==void 0&&Ct("prehash",r.prehash)}function Zf(r){let t=Er(r);_t(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Wf,hexToBytes:Jf}=on,Vo=class extends Error{constructor(t=""){super(t)}},Zt={Err:Vo,_tlv:{encode:(r,t)=>{let{Err:e}=Zt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=ke(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?ke(s.length/2|128):"";return ke(r)+o+s+t},decode(r,t){let{Err:e}=Zt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Zt;if(r<Wt)throw new t("integer: negative integers are not allowed");let e=ke(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Zt;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Wf(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Zt,s=typeof r=="string"?Jf(r):r;Xe(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Zt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Wt=BigInt(0),ot=BigInt(1),Cg=BigInt(2),Aa=BigInt(3),Ug=BigInt(4);function Yf(r){let t=Zf(r),{Fp:e}=t,n=de(t.n,t.nBitLength),s=t.toBytes||((y,d,w)=>{let B=d.toAffine();return $t(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(y=>{let d=y.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:B}});function i(y){let{a:d,b:w}=t,B=e.sqr(y),p=e.mul(B,y);return e.add(e.add(p,e.mul(y,d)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(y){return vr(y,ot,t.n)}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:B,n:p}=t;if(d&&typeof y!="bigint"){if(ue(y)&&(y=qt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("invalid private key");y=y.padStart(w*2,"0")}let S;try{S=typeof y=="bigint"?y:jt(J("private key",y,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof y)}return B&&(S=$(S,p)),bt("private key",S,ot,p),S}function f(y){if(!(y instanceof h))throw new Error("ProjectivePoint expected")}let l=Ce((y,d)=>{let{px:w,py:B,pz:p}=y;if(e.eql(p,e.ONE))return{x:w,y:B};let S=y.is0();d==null&&(d=S?e.ONE:e.inv(p));let L=e.mul(w,d),T=e.mul(B,d),I=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:L,y:T}}),u=Ce(y=>{if(y.is0()){if(t.allowInfinityPoint&&!e.is0(y.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=y.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let B=e.sqr(w),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,w,B){if(this.px=d,this.py=w,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:w,y:B}=d||{};if(!d||!e.isValid(w)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(w)&&p(B)?h.ZERO:new h(w,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(w[p])).map(h.fromAffine)}static fromHex(d){let w=h.fromAffine(o(J("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,w){return un(h,n,d,w)}_setWindowSize(d){b.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:L,pz:T}=d,I=e.eql(e.mul(w,T),e.mul(S,p)),U=e.eql(e.mul(B,T),e.mul(L,p));return I&&U}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,B=e.mul(w,Aa),{px:p,py:S,pz:L}=this,T=e.ZERO,I=e.ZERO,U=e.ZERO,N=e.mul(p,p),G=e.mul(S,S),F=e.mul(L,L),K=e.mul(p,S);return K=e.add(K,K),U=e.mul(p,L),U=e.add(U,U),T=e.mul(d,U),I=e.mul(B,F),I=e.add(T,I),T=e.sub(G,I),I=e.add(G,I),I=e.mul(T,I),T=e.mul(K,T),U=e.mul(B,U),F=e.mul(d,F),K=e.sub(N,F),K=e.mul(d,K),K=e.add(K,U),U=e.add(N,N),N=e.add(U,N),N=e.add(N,F),N=e.mul(N,K),I=e.add(I,N),F=e.mul(S,L),F=e.add(F,F),N=e.mul(F,K),T=e.sub(T,N),U=e.mul(F,G),U=e.add(U,U),U=e.add(U,U),new h(T,I,U)}add(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:L,pz:T}=d,I=e.ZERO,U=e.ZERO,N=e.ZERO,G=t.a,F=e.mul(t.b,Aa),K=e.mul(w,S),Q=e.mul(B,L),E=e.mul(p,T),C=e.add(w,B),x=e.add(S,L);C=e.mul(C,x),x=e.add(K,Q),C=e.sub(C,x),x=e.add(w,p);let g=e.add(S,T);return x=e.mul(x,g),g=e.add(K,E),x=e.sub(x,g),g=e.add(B,p),I=e.add(L,T),g=e.mul(g,I),I=e.add(Q,E),g=e.sub(g,I),N=e.mul(G,x),I=e.mul(F,E),N=e.add(I,N),I=e.sub(Q,N),N=e.add(Q,N),U=e.mul(I,N),Q=e.add(K,K),Q=e.add(Q,K),E=e.mul(G,E),x=e.mul(F,x),Q=e.add(Q,E),E=e.sub(K,E),E=e.mul(G,E),x=e.add(x,E),K=e.mul(Q,x),U=e.add(U,K),K=e.mul(g,x),I=e.mul(C,I),I=e.sub(I,K),K=e.mul(C,Q),N=e.mul(g,N),N=e.add(N,K),new h(I,U,N)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return b.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:w,n:B}=t;bt("scalar",d,Wt,B);let p=h.ZERO;if(d===Wt)return p;if(this.is0()||d===ot)return this;if(!w||b.hasPrecomputes(this))return b.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:S,k1:L,k2neg:T,k2:I}=w.splitScalar(d),U=p,N=p,G=this;for(;L>Wt||I>Wt;)L&ot&&(U=U.add(G)),I&ot&&(N=N.add(G)),G=G.double(),L>>=ot,I>>=ot;return S&&(U=U.negate()),T&&(N=N.negate()),N=new h(e.mul(N.px,w.beta),N.py,N.pz),U.add(N)}multiply(d){let{endo:w,n:B}=t;bt("scalar",d,ot,B);let p,S;if(w){let{k1neg:L,k1:T,k2neg:I,k2:U}=w.splitScalar(d),{p:N,f:G}=this.wNAF(T),{p:F,f:K}=this.wNAF(U);N=b.constTimeNegate(L,N),F=b.constTimeNegate(I,F),F=new h(e.mul(F.px,w.beta),F.py,F.pz),p=N.add(F),S=G.add(K)}else{let{p:L,f:T}=this.wNAF(d);p=L,S=T}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,w,B){let p=h.BASE,S=(T,I)=>I===Wt||I===ot||!T.equals(p)?T.multiplyUnsafe(I):T.multiply(I),L=S(this,w).add(S(d,B));return L.is0()?void 0:L}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===ot)return!0;if(w)return w(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===ot?this:w?w(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Ct("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Ct("isCompressed",d),qt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,b=ln(h,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Xf(r){let t=Er(r);return _t(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Sa(r){let t=Xf(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return $(E,n)}function a(E){return an(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Yf({...t,toBytes(E,C,x){let g=C.toAffine(),v=e.toBytes(g.x),k=$t;return Ct("isCompressed",x),x?k(Uint8Array.from([C.hasEvenY()?2:3]),v):k(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(E){let C=E.length,x=E[0],g=E.subarray(1);if(C===s&&(x===2||x===3)){let v=jt(g);if(!vr(v,ot,e.ORDER))throw new Error("Point is not on curve");let k=l(v),R;try{R=e.sqrt(k)}catch(P){let H=P instanceof Error?": "+P.message:"";throw new Error("Point is not on curve"+H)}let V=(R&ot)===ot;return(x&1)===1!==V&&(R=e.neg(R)),{x:v,y:R}}else if(C===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),k=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:k}}else{let v=s,k=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+k+", got "+C)}}}),h=E=>qt(he(E,t.nByteLength));function m(E){let C=n>>ot;return E>C}function b(E){return m(E)?i(-E):E}let y=(E,C,x)=>jt(E.slice(C,x));class d{constructor(C,x,g){this.r=C,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(C){let x=t.nByteLength;return C=J("compactSignature",C,x*2),new d(y(C,0,x),y(C,x,2*x))}static fromDER(C){let{r:x,s:g}=Zt.toSig(J("DER",C));return new d(x,g)}assertValidity(){bt("r",this.r,ot,n),bt("s",this.s,ot,n)}addRecoveryBit(C){return new d(this.r,this.s,C)}recoverPublicKey(C){let{r:x,s:g,recovery:v}=this,k=T(J("msgHash",C));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let R=v===2||v===3?x+t.n:x;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let V=(v&1)===0?"02":"03",D=c.fromHex(V+h(R)),P=a(R),H=i(-k*P),j=i(g*P),z=c.BASE.multiplyAndAddUnsafe(D,H,j);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ie(this.toDERHex())}toDERHex(){return Zt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ie(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let w={isValidPrivateKey(E){try{return f(E),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let E=Gs(t.n);return Ri(t.randomBytes(E),t.n)},precompute(E=8,C=c.BASE){return C._setWindowSize(E),C.multiply(BigInt(3)),C}};function B(E,C=!0){return c.fromPrivateKey(E).toRawBytes(C)}function p(E){let C=ue(E),x=typeof E=="string",g=(C||x)&&E.length;return C?g===s||g===o:x?g===2*s||g===2*o:E instanceof c}function S(E,C,x=!0){if(p(E))throw new Error("first arg must be private key");if(!p(C))throw new Error("second arg must be public key");return c.fromHex(C).multiply(f(E)).toRawBytes(x)}let L=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let C=jt(E),x=E.length*8-t.nBitLength;return x>0?C>>BigInt(x):C},T=t.bits2int_modN||function(E){return i(L(E))},I=Br(t.nBitLength);function U(E){return bt("num < 2^"+t.nBitLength,E,Wt,I),he(E,t.nByteLength)}function N(E,C,x=G){if(["recovered","canonical"].some(rt=>rt in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:k,prehash:R,extraEntropy:V}=x;k==null&&(k=!0),E=J("msgHash",E),Ea(x),R&&(E=J("prehashed msgHash",g(E)));let D=T(E),P=f(C),H=[U(P),U(D)];if(V!=null&&V!==!1){let rt=V===!0?v(e.BYTES):V;H.push(J("extraEntropy",rt))}let j=$t(...H),z=D;function et(rt){let it=L(rt);if(!u(it))return;let lt=a(it),mt=c.BASE.multiply(it).toAffine(),dt=i(mt.x);if(dt===Wt)return;let Ot=i(lt*i(z+dt*P));if(Ot===Wt)return;let Mt=(mt.x===dt?0:2)|Number(mt.y&ot),fr=Ot;return k&&m(Ot)&&(fr=b(Ot),Mt^=1),new d(dt,fr,Mt)}return{seed:j,k2sig:et}}let G={lowS:t.lowS,prehash:!1},F={lowS:t.lowS,prehash:!1};function K(E,C,x=G){let{seed:g,k2sig:v}=N(E,C,x),k=t;return qs(k.hash.outputLen,k.nByteLength,k.hmac)(g,v)}c.BASE._setWindowSize(8);function Q(E,C,x,g=F){let v=E;C=J("msgHash",C),x=J("publicKey",x);let{lowS:k,prehash:R,format:V}=g;if(Ea(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(V!==void 0&&V!=="compact"&&V!=="der")throw new Error("format must be compact or der");let D=typeof v=="string"||ue(v),P=!D&&!V&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!D&&!P)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let H,j;try{if(P&&(H=new d(v.r,v.s)),D){try{V!=="compact"&&(H=d.fromDER(v))}catch(Mt){if(!(Mt instanceof Zt.Err))throw Mt}!H&&V!=="der"&&(H=d.fromCompact(v))}j=c.fromHex(x)}catch{return!1}if(!H||k&&H.hasHighS())return!1;R&&(C=t.hash(C));let{r:z,s:et}=H,rt=T(C),it=a(et),lt=i(rt*it),mt=i(z*it),dt=c.BASE.multiplyAndAddUnsafe(j,lt,mt)?.toAffine();return dt?i(dt.x)===z:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:S,sign:K,verify:Q,ProjectivePoint:c,Signature:d,utils:w}}function Qf(r){return{hash:r,hmac:(t,...e)=>Vr(r,t,Hs(...e)),randomBytes:Ye}}function ka(r,t){let e=n=>Sa({...r,...Qf(n)});return{...e(t),create:e}}var Ca=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ia=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),th=BigInt(1),Oo=BigInt(2),Na=(r,t)=>(r+t/Oo)/t;function eh(r){let t=Ca,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,l=f*f*r%t,u=W(l,e,t)*l%t,h=W(u,e,t)*l%t,m=W(h,Oo,t)*f%t,b=W(m,s,t)*m%t,y=W(b,o,t)*b%t,d=W(y,a,t)*y%t,w=W(d,c,t)*d%t,B=W(w,a,t)*y%t,p=W(B,e,t)*l%t,S=W(p,i,t)*b%t,L=W(S,n,t)*f%t,T=W(L,Oo,t);if(!Ho.eql(Ho.sqr(T),r))throw new Error("Cannot find square root");return T}var Ho=de(Ca,void 0,void 0,{sqrt:eh}),Rt=ka({a:BigInt(0),b:BigInt(7),Fp:Ho,n:Ia,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ia,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-th*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Na(o*r,t),c=Na(-n*r,t),f=$(r-a*e-c*s,t),l=$(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},we),Kg=BigInt(0);var Mg=Rt.ProjectivePoint;function _o(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ua(r,t){let e=Qe.digest(t instanceof Uint8Array?t:t.subarray());if(_o(e))return e.then(({digest:n})=>Rt.sign(n,r).toDERRawBytes()).catch(n=>{throw new hr(String(n))});try{return Rt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new hr(String(n))}}function Ta(r,t,e){let n=Qe.digest(e instanceof Uint8Array?e:e.subarray());if(_o(n))return n.then(({digest:s})=>Rt.verify(t,s,r)).catch(s=>{throw new dr(String(s))});try{return Rt.verify(t,n.digest,r)}catch(s){throw new dr(String(s))}}var kn=class{type="secp256k1";raw;_key;constructor(t){this._key=Va(t),this.raw=La(this._key)}toMultihash(){return xr.digest(dn(this))}toCID(){return Ht.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}verify(t,e){return Ta(this._key,e,t)}},In=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Ra(t),this.publicKey=new kn(e??Oa(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:It(this.raw,t.raw)}sign(t){return Ua(this.raw,t)}};function Do(r){return new In(r)}function La(r){return Rt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ra(r){try{return Rt.getPublicKey(r,!0),r}catch(t){throw new pr(String(t))}}function Va(r){try{return Rt.ProjectivePoint.fromHex(r),r}catch(t){throw new Ke(String(t))}}function Oa(r){try{return Rt.getPublicKey(r,!0)}catch(t){throw new pr(String(t))}}function dn(r){return me.encode({Type:st[r.type],Data:r.raw})}function Ha(r){let t=Ur.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case st.RSA:return An(e);case st.Ed25519:return to(e);case st.secp256k1:return Do(e);default:throw new Me}}function _a(r){return r.byteLength===64?to(r):r.byteLength===32?Do(r):An(r)}function nr(r){return Ur.encode({Type:st[r.type],Data:r.raw})}function Da(r,t,e,n){Xr(r);let s=Si({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(ze(o),ze(i),ze(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=oe(t),f=oe(e),l=new Uint8Array(i),u=Vr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function Ka(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function Ma(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Da(r,t,e,n),f,l=new Uint8Array(4),u=Se(l),h=new Uint8Array(a.outputLen);for(let m=1,b=0;b<o;m++,b+=a.outputLen){let y=i.subarray(b,b+a.outputLen);u.setInt32(0,m,!1),(f=c._cloneInto(f)).update(l).digestInto(h),y.set(h.subarray(0,y.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let w=0;w<y.length;w++)y[w]^=h[w]}}return Ka(a,c,i,f,h)}async function Nn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=Da(r,t,e,n),l,u=new Uint8Array(4),h=Se(u),m=new Uint8Array(c.outputLen);for(let b=1,y=0;y<o;b++,y+=c.outputLen){let d=a.subarray(y,y+c.outputLen);h.setInt32(0,b,!1),(l=f._cloneInto(l)).update(u).digestInto(m),d.set(m.subarray(0,d.length)),await Ei(s-1,i,()=>{c._cloneInto(l).update(m).digestInto(m);for(let w=0;w<d.length;w++)d[w]^=m[w]})}return Ka(c,f,a,l,m)}var Or=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),xe=new Uint32Array(80),Ko=class extends ie{constructor(){super(64,20,8,!1),this.A=Or[0]|0,this.B=Or[1]|0,this.C=Or[2]|0,this.D=Or[3]|0,this.E=Or[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)xe[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)xe[c]=Qr(xe[c-3]^xe[c-8]^xe[c-14]^xe[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=tn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=en(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=Qr(n,5)+f+a+l+xe[c]|0;a=i,i=o,o=Qr(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){xe.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},Pa=Je(()=>new Ko);var Fa={sha1:Pa,"sha2-256":we,"sha2-512":le};function Hr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Fa).join(" / ");throw new O(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Fa[s],i=Ma(o,r,t,{c:e,dkLen:n});return Le.encode(i).substring(1)}var Jt="/",qa=new TextEncoder().encode(Jt),Cn=qa[0],_r=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Cn)throw new Error("Invalid key")}toString(t="utf8"){return Y(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Jt))}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=qa),this._buf[0]!==Cn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Cn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Cn;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(Jt).slice(1)}type(){return rh(this.baseNamespace())}name(){return nh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Jt)||(t+=Jt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Jt):new r(t.slice(0,-1).join(Jt))}child(t){return this.toString()===Jt?t:t.toString()===Jt?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(),...sh(t.map(e=>e.namespaces()))])}};function rh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function nh(r){let t=r.split(":");return t[t.length-1]}function sh(r){return[].concat(...r)}var Xa=Ss(Ya(),1),Qa=Xa.default;var tl=Ss(cc(),1);var ir={};ut(ir,{create:()=>Bh,derivedEmptyPasswordKey:()=>Ln});var Ln={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Bh(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=yt.get();e*=8;async function c(u,h){let m=a.getRandomValues(new Uint8Array(o)),b=a.getRandomValues(new Uint8Array(n)),y={name:t,iv:b};typeof h=="string"&&(h=q(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",Ln,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",Ln,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}let w=await a.subtle.encrypt(y,d,u);return er([m,y.iv,new Uint8Array(w)])}async function f(u,h){let m=u.subarray(0,o),b=u.subarray(o,o+n),y=u.subarray(o+n),d={name:t,iv:b};typeof h=="string"&&(h=q(h));let w;if(h.length===0)try{let p={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",Ln,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,w,y);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}var M=Ss(lc());function Oe(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function ve(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function On(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function Fo(){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=Oe(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Oe(o,8)-n}function uc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=ve(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=ve(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function fc(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 xt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Jm=Math.log(2);function Hn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function qo(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function re(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 Kr=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return qo(this.items)}},Dr=[new Uint8Array([1])],hc="0123456789";var cr="",Vt=new ArrayBuffer(0),jo=new Uint8Array(0),Mr="EndOfContent",pc="OCTET STRING",gc="BIT STRING";function ne(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):jo}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!re(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Vt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Xt=class{constructor({blockLength:t=0,error:e=cr,warnings:n=[],valueBeforeDecode:s=jo}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};Xt.NAME="baseBlock";var ht=class extends Xt{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};ht.NAME="valueBlock";var _n=class extends ne(Xt){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):jo,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Vt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=ve(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let m=0;m<f.length;m++)h[m]=f[m];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(u),this.blockLength<=9?this.tagNumber=Oe(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}}};_n.NAME="identificationBlock";var Dn=class extends Xt{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Oe(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=ve(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Dn.NAME="lengthBlock";var A={},at=class extends Xt{constructor({name:t=cr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new _n(s),this.lenBlock=new Dn(s),this.valueBlock=o?new o(s):new ht(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 Kr;e||mc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return fc(e,n)}};at.NAME="BaseBlock";function mc(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)mc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Kn=class extends at{constructor({value:t=cr,...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 Mn=class extends ne(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Mn.NAME="PrimitiveValueBlock";var yc,Pn=class extends at{constructor(t={}){super(t,Mn),this.idBlock.isConstructed=!1}};yc=Pn;A.Primitive=yc;Pn.NAME="PRIMITIVE";function Th(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 vs(r,t=0,e=r.length){let n=t,s=new at({},ht),o=new Xt;if(!re(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=at;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.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?A.Constructed:A.Primitive}return s=Th(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 Bs(r){if(!r.byteLength){let t=new at({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return vs(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Lh(r,t){return r?1:t}var Dt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;Lh(this.isIndefiniteForm,n)>0;){let i=vs(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Mr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Mr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new Kr;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Dt.NAME="ConstructedValueBlock";var bc,Be=class extends at{constructor(t={}){super(t,Dt),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 Cl=Object.create;var tn=Object.defineProperty;var Nl=Object.getOwnPropertyDescriptor;var Tl=Object.getOwnPropertyNames;var Ul=Object.getPrototypeOf,Ll=Object.prototype.hasOwnProperty;var Se=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ut=(r,t)=>{for(var e in t)tn(r,e,{get:t[e],enumerable:!0})},gi=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tl(t))!Ll.call(r,s)&&s!==e&&tn(r,s,{get:()=>t[s],enumerable:!(n=Nl(t,s))||n.enumerable});return r};var Us=(r,t,e)=>(e=r!=null?Cl(Ul(r)):{},gi(t||!r||!r.__esModule?tn(e,"default",{value:r,enumerable:!0}):e,r)),Rl=r=>gi(tn({},"__esModule",{value:!0}),r);var uc=Se((Hm,lc)=>{"use strict";lc.exports=r=>{if(Object.prototype.toString.call(r)!=="[object Object]")return!1;let t=Object.getPrototypeOf(r);return t===null||t===Object.prototype}});var yc=Se((pc,gc)=>{"use strict";var Dn=uc(),{hasOwnProperty:hc}=Object.prototype,{propertyIsEnumerable:Rh}=Object,ur=(r,t,e)=>Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0}),_h=pc,fc={concatArrays:!1,ignoreUndefined:!1},Kn=r=>{let t=[];for(let e in r)hc.call(r,e)&&t.push(e);if(Object.getOwnPropertySymbols){let e=Object.getOwnPropertySymbols(r);for(let n of e)Rh.call(r,n)&&t.push(n)}return t};function fr(r){return Array.isArray(r)?Dh(r):Dn(r)?Kh(r):r}function Dh(r){let t=r.slice(0,0);return Kn(r).forEach(e=>{ur(t,e,fr(r[e]))}),t}function Kh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return Kn(r).forEach(e=>{ur(t,e,fr(r[e]))}),t}var dc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?ur(r,s,Qo(r[s],t[s],n)):ur(r,s,fr(t[s])))}),r),Oh=(r,t,e)=>{let n=r.slice(0,0),s=0;return[r,t].forEach(o=>{let i=[];for(let a=0;a<o.length;a++)hc.call(o,a)&&(i.push(String(a)),o===r?ur(n,s++,o[a]):ur(n,s++,fr(o[a])));n=dc(n,o,Kn(o).filter(a=>!i.includes(a)),e)}),n};function Qo(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?Oh(r,t,e):!Dn(t)||!Dn(r)?fr(t):dc(r,t,Kn(t),e)}gc.exports=function(...r){let t=Qo(fr(fc),this!==_h&&this||{},fc),e={_:{}};for(let n of r)if(n!==void 0){if(!Dn(n))throw new TypeError("`"+n+"` is not an Option Object");e=Qo(e,{_:n},t)}return e._}});var xc=Se((Mm,wc)=>{"use strict";function Vh(r){return r>=55296&&r<=56319}function Hh(r){return r>=56320&&r<=57343}wc.exports=function(t,e,n){if(typeof e!="string")throw new Error("Input must be string");for(var s=e.length,o=0,i,a,c=0;c<s;c+=1){if(i=e.charCodeAt(c),a=e[c],Vh(i)&&Hh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Bc=Se((Fm,vc)=>{"use strict";function Ph(r){return r>=55296&&r<=56319}function Mh(r){return r>=56320&&r<=57343}vc.exports=function(t){if(typeof t!="string")throw new Error("Input must be string");for(var e=t.length,n=0,s=null,o=null,i=0;i<e;i++)s=t.charCodeAt(i),Mh(s)?o!=null&&Ph(o)?n+=1:n+=3:s<=127?n+=1:s>=128&&s<=2047?n+=2:s>=2048&&s<=65535&&(n+=3),o=s;return n}});var Ac=Se((qm,Ec)=>{"use strict";var Fh=xc(),qh=Bc();Ec.exports=Fh.bind(null,qh)});var Ic=Se((jm,kc)=>{"use strict";var jh=Ac(),$h=/[\/\?<>\\:\*\|"]/g,Gh=/[\x00-\x1f\x80-\x9f]/g,zh=/^\.+$/,Wh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,Zh=/[\. ]+$/;function Sc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace($h,t).replace(Gh,t).replace(zh,t).replace(Wh,t).replace(Zh,t);return jh(e,255)}kc.exports=function(r,t){var e=t&&t.replacement||"",n=Sc(r,e);return e===""?n:Sc(n,"")}});var Cc=Se(dr=>{"use strict";var Yh="[object ArrayBuffer]",Qt=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Yh}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},ti="string",Xh=/^[0-9a-f\s]+$/i,Qh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,td=/^[a-zA-Z0-9-_]+$/,Vn=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 o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Ct=class{static toString(t,e=!1){let n=Qt.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},Hn=class r{static isHex(t){return typeof t===ti&&Xh.test(t)}static isBase64(t){return typeof t===ti&&Qh.test(t)}static isBase64Url(t){return typeof t===ti&&td.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 Ct.toString(n,!0);case"utf16":case"utf16be":return Ct.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 Ct.fromString(t,!0);case"utf16":case"utf16be":return Ct.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 Vn.fromString(t);case"utf16":case"utf16be":return Ct.fromString(t);case"utf16le":case"usc2":return Ct.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 Vn.toString(t);case"utf16":case"utf16be":return Ct.toString(t);case"utf16le":case"usc2":return Ct.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 o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Ct.toString(t,e)}static FromUtf16String(t,e=!1){return Ct.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,"")||""}};Hn.DEFAULT_UTF8_ENCODING="utf8";function ed(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function rd(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function nd(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}dr.BufferSourceConverter=Qt;dr.Convert=Hn;dr.assign=ed;dr.combine=rd;dr.isEqual=nd});var xd={};ut(xd,{keychain:()=>wd});var br=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},wr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},en=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var yi={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new en("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var wt=yi;var L=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},qe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},xr=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var rn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var je=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var mi=Symbol.for("@libp2p/service-capabilities"),Cd=Symbol.for("@libp2p/service-dependencies");var Ks={};ut(Ks,{base58btc:()=>Q,base58flickr:()=>Hl});var Yd=new Uint8Array(0);function bi(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function jt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function wi(r){return new TextEncoder().encode(r)}function xi(r){return new TextDecoder().decode(r)}function _l(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var m=0,d=0,w=0,B=b.length;w!==B&&b[w]===0;)w++,m++;for(var p=(B-w)*l+1>>>0,S=new Uint8Array(p);w!==B;){for(var R=b[w],U=0,I=p-1;(R!==0||U<d)&&I!==-1;I--,U++)R+=256*S[I]>>>0,S[I]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");d=U,w++}for(var T=p-d;T!==p&&S[T]===0;)T++;for(var C=c.repeat(m);T<p;++T)C+=r.charAt(S[T]);return C}function h(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var m=0;if(b[m]!==" "){for(var d=0,w=0;b[m]===c;)d++,m++;for(var B=(b.length-m)*f+1>>>0,p=new Uint8Array(B);b[m];){var S=e[b.charCodeAt(m)];if(S===255)return;for(var R=0,U=B-1;(S!==0||R<w)&&U!==-1;U--,R++)S+=a*p[U]>>>0,p[U]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");w=R,m++}if(b[m]!==" "){for(var I=B-w;I!==B&&p[I]===0;)I++;for(var T=new Uint8Array(d+(B-I)),C=d;I!==B;)T[C++]=p[I++];return T}}}function y(b){var m=h(b);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:h,decode:y}}var Dl=_l,Kl=Dl,Bi=Kl;var Ls=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")}},Rs=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ei(this,t)}},_s=class{decoders;constructor(t){this.decoders=t}or(t){return Ei(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 Ei(r,t){return new _s({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ds=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 Ls(t,e,n),this.decoder=new Rs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function $e({name:r,prefix:t,encode:e,decode:n}){return new Ds(r,t,e,n)}function ie({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Bi(e,r);return $e({prefix:t,name:r,encode:n,decode:o=>jt(s(o))})}function Ol(r,t,e,n){let s={};for(let l=0;l<t.length;++l)s[t[l]]=l;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,f=0;for(let l=0;l<o;++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,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Vl(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;(o.length*e&7)!==0;)o+="=";return o}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return $e({prefix:t,name:r,encode(s){return Vl(s,n,e)},decode(s){return Ol(s,n,e,r)}})}var Q=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Hl=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Os={};ut(Os,{base32:()=>Ge,base32hex:()=>ql,base32hexpad:()=>$l,base32hexpadupper:()=>Gl,base32hexupper:()=>jl,base32pad:()=>Ml,base32padupper:()=>Fl,base32upper:()=>Pl,base32z:()=>zl});var Ge=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Pl=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Ml=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Fl=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ql=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),jl=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),$l=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Gl=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),zl=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Vs={};ut(Vs,{base36:()=>vr,base36upper:()=>Wl});var vr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Wl=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Zl=ki,Ai=128,Jl=127,Yl=~Jl,Xl=Math.pow(2,31);function ki(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Xl;)t[e++]=r&255|Ai,r/=128;for(;r&Yl;)t[e++]=r&255|Ai,r>>>=7;return t[e]=r|0,ki.bytes=e-n+1,t}var Ql=Hs,tu=128,Si=127;function Hs(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Hs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Si)<<s:(i&Si)*Math.pow(2,s),s+=7}while(i>=tu);return Hs.bytes=o-n,e}var eu=Math.pow(2,7),ru=Math.pow(2,14),nu=Math.pow(2,21),su=Math.pow(2,28),ou=Math.pow(2,35),iu=Math.pow(2,42),au=Math.pow(2,49),cu=Math.pow(2,56),lu=Math.pow(2,63),uu=function(r){return r<eu?1:r<ru?2:r<nu?3:r<su?4:r<ou?5:r<iu?6:r<au?7:r<cu?8:r<lu?9:10},fu={encode:Zl,decode:Ql,encodingLength:uu},hu=fu,Br=hu;function Er(r,t=0){return[Br.decode(r,t),Br.decode.bytes]}function ze(r,t,e=0){return Br.encode(r,t,e),t}function We(r){return Br.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=We(r),s=n+We(e),o=new Uint8Array(s+e);return ze(r,o,0),ze(e,o,n),o.set(t,s),new Ze(r,e,t,o)}function Ii(r){let t=jt(r),[e,n]=Er(t),[s,o]=Er(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ze(e,s,i,t)}function Ci(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&bi(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Ni(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return pu(e,Ps(r),t??Q.encoder);default:return gu(e,Ps(r),t??Ge.encoder)}}var Ti=new WeakMap;function Ps(r){let t=Ti.get(r);if(t==null){let e=new Map;return Ti.set(r,e),e}return t}var It=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!==Sr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==yu)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=Nt(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&&Ci(t.multihash,n.multihash)}toString(t){return Ni(this,t)}toJSON(){return{"/":Ni(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??Ui(n,s,o.bytes))}else if(e[mu]===!0){let{version:n,multihash:s,code:o}=e,i=Ii(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Sr)throw new Error(`Version 0 CID must use dag-pb (code: ${Sr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Ui(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Sr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=jt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Ze(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,h]=Er(t.subarray(e));return e+=h,u},s=n(),o=Sr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),f=e+c,l=f-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:f}}static parse(t,e){let[n,s]=du(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ps(o).set(n,t),o}};function du(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case Ge.prefix:{let e=t??Ge;return[Ge.prefix,e.decode(r)]}case vr.prefix:{let e=t??vr;return[vr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function pu(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function gu(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Sr=112,yu=18;function Ui(r,t,e){let n=We(r),s=n+We(t),o=new Uint8Array(s+e.byteLength);return ze(r,o,0),ze(t,o,n),o.set(e,s),o}var mu=Symbol.for("@ipld/js-cid/CID");var Ms={};ut(Ms,{identity:()=>ke});var Li=0,bu="identity",Ri=jt;function wu(r){return Nt(Li,Ri(r))}var ke={code:Li,name:bu,encode:Ri,digest:wu};function xt(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 $t(r=0){return new Uint8Array(r)}function St(r=0){return new Uint8Array(r)}function Je(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=St(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Di=Symbol.for("@achingbrain/uint8arraylist");function _i(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function sn(r){return!!r?.[Di]}var pt=class r{bufs;length;[Di]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(sn(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(sn(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=_i(this.bufs,t);return e.buf[e.index]}set(t,e){let n=_i(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(sn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Je(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Je(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let f=t>=a&&t<c,l=e>a&&e<=c;if(f&&l){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!sn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,l;for(let u=e;u<=c;u+=l){l=0;for(let h=f;h>=0;h--){let y=this.get(u+h);if(n[h]!==y){l=Math.max(1,h-a[y]);break}}if(l===0)return u}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=$t(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=St(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=$t(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=$t(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=$t(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!xt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};var Fs={};ut(Fs,{base10:()=>xu});var xu=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var qs={};ut(qs,{base16:()=>vu,base16upper:()=>Bu});var vu=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Bu=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var js={};ut(js,{base2:()=>Eu});var Eu=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var $s={};ut($s,{base256emoji:()=>Cu});var Ki=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}"),Au=Ki.reduce((r,t,e)=>(r[e]=t,r),[]),Su=Ki.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ku(r){return r.reduce((t,e)=>(t+=Au[e],t),"")}function Iu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Su[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Cu=$e({prefix:"\u{1F680}",name:"base256emoji",encode:ku,decode:Iu});var Gs={};ut(Gs,{base64:()=>Ie,base64pad:()=>Nu,base64url:()=>Tu,base64urlpad:()=>Uu});var Ie=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Nu=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Tu=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Uu=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var zs={};ut(zs,{base8:()=>Lu});var Lu=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ws={};ut(Ws,{identity:()=>Ru});var Ru=$e({prefix:"\0",name:"identity",encode:r=>xi(r),decode:r=>wi(r)});var _0=new TextEncoder,D0=new TextDecoder;var Ys={};ut(Ys,{sha256:()=>Ye,sha512:()=>Ku});function Js({name:r,code:t,encode:e}){return new Zs(r,t,e)}var Zs=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?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Vi(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ye=Js({name:"sha2-256",code:18,encode:Vi("SHA-256")}),Ku=Js({name:"sha2-512",code:19,encode:Vi("SHA-512")});var Xs={...Ws,...js,...zs,...Fs,...qs,...Os,...Vs,...Ks,...Gs,...$s},z0={...Ys,...Ms};function Pi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Hi=Pi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Qs=Pi("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=St(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Ou={utf8:Hi,"utf-8":Hi,hex:Xs.base16,latin1:Qs,ascii:Qs,binary:Qs,...Xs},on=Ou;function H(r,t="utf8"){let e=on[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function j(r,t="utf8"){let e=on[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Vu=parseInt("11111",2),to=parseInt("10000000",2),Hu=parseInt("01111111",2),Mi={0:kr,1:kr,2:Pu,3:qu,4:ju,5:Fu,6:Mu,16:kr,22:kr,48:kr};function Tt(r,t={offset:0}){let e=r[t.offset]&Vu;if(t.offset++,Mi[e]!=null)return Mi[e](r,t);throw new Error("No decoder for tag "+e)}function Ir(r,t){let e=0;if((r[t.offset]&to)===to){let n=r[t.offset]&Hu,s="0x";t.offset++;for(let o=0;o<n;o++,t.offset++)s+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(s,16)}else e=r[t.offset],t.offset++;return e}function kr(r,t){Ir(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Tt(r,t);if(n===null)break;e.push(n)}return e}function Pu(r,t){let e=Ir(r,t),n=t.offset,s=t.offset+e,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return t.offset+=e,Uint8Array.from(o)}function Mu(r,t){let e=Ir(r,t),n=t.offset+e,s=r[t.offset];t.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let l=0;for(let u=0;u<c.length;u++)l+=c[u]<<u*7;a+=`.${l}`,c=[]}}return a}function Fu(r,t){return t.offset++,null}function qu(r,t){let e=Ir(r,t),n=r[t.offset];t.offset++;let s=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function ju(r,t){let e=Ir(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function $u(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new pt;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function an(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=$u(r.byteLength);return new pt(Uint8Array.from([t.byteLength|to]),t)}function gt(r){let t=new pt,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new pt(Uint8Array.from([2]),an(t),t)}function Cr(r){let t=Uint8Array.from([0]),e=new pt(t,r);return new pt(Uint8Array.from([3]),an(e),e)}function Fi(r){return new pt(Uint8Array.from([4]),an(r),r)}function Ut(r,t=48){let e=new pt;for(let n of r)e.append(n);return new pt(Uint8Array.from([t]),an(e),e)}var qi="1.2.840.10045.3.1.7",ji="1.3.132.0.34",$i="1.3.132.0.35";async function Gi(r,t){let e=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]),n=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},e,t.subarray());return new Uint8Array(n,0,n.byteLength)}async function zi(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var Gu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),zu=Uint8Array.from([6,5,43,129,4,0,34]),Wu=Uint8Array.from([6,5,43,129,4,0,35]),Zu={ext:!0,kty:"EC",crv:"P-256"},Ju={ext:!0,kty:"EC",crv:"P-384"},Yu={ext:!0,kty:"EC",crv:"P-521"},eo=32,ro=48,no=66;function Wi(r){let t=Tt(r);return so(t)}function so(r){let t=r[1],e=j(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===eo)return o=j(n.subarray(s,s+eo),"base64url"),i=j(n.subarray(s+eo),"base64url"),new Xe({...Zu,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===ro)return o=j(n.subarray(s,s+ro),"base64url"),i=j(n.subarray(s+ro),"base64url"),new Xe({...Ju,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===no)return o=j(n.subarray(s,s+no),"base64url"),i=j(n.subarray(s+no),"base64url"),new Xe({...Yu,key_ops:["sign"],d:e,x:o,y:i});throw new L(`Private key length was wrong length, got ${t.byteLength}, expected 32, 48 or 66`)}function Zi(r){return Ut([gt(Uint8Array.from([1])),Fi(H(r.d??"","base64url")),Ut([Yi(r.crv)],160),Ut([Cr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Ji(r){return Ut([gt(Uint8Array.from([1])),Ut([Yi(r.crv)],160),Ut([Cr(new pt(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Yi(r){if(r==="P-256")return Gu;if(r==="P-384")return zu;if(r==="P-521")return Wu;throw new L(`Invalid curve ${r}`)}var cn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Ji(this.jwk)),this._raw}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async verify(t,e){return zi(this.jwk,e,t)}},Xe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new cn({crv:t.crv,ext:t.ext,key_ops:["verify"],kty:"EC",x:t.x,y:t.y})}get raw(){return this._raw==null&&(this._raw=Zi(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async sign(t){return Gi(this.jwk,t)}};function tr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Xu(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function er(r,...t){if(!Xu(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function ln(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");tr(r.outputLen),tr(r.blockLen)}function rr(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 Xi(r,t){er(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ce=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ne(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Lt(r,t){return r<<32-t|r>>>t}function un(r,t){return r<<t|r>>>32-t>>>0}var Qu=async()=>{};async function Qi(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await Qu(),n+=o)}}function ta(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function ae(r){return typeof r=="string"&&(r=ta(r)),er(r),r}function oo(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];er(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var nr=class{clone(){return this._cloneInto()}};function ea(r,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function sr(r){let t=n=>r().update(ae(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function or(r=32){if(Ce&&typeof Ce.getRandomValues=="function")return Ce.getRandomValues(new Uint8Array(r));if(Ce&&typeof Ce.randomBytes=="function")return Ce.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function tf(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function fn(r,t,e){return r&t^~r&e}function hn(r,t,e){return r&t^r&e^t&e}var ce=class extends nr{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=Ne(this.buffer)}update(t){rr(this);let{view:e,buffer:n,blockLen:s}=this;t=ae(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=Ne(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){rr(this),Xi(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;tf(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Ne(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],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var dn=BigInt(4294967295),io=BigInt(32);function ra(r,t=!1){return t?{h:Number(r&dn),l:Number(r>>io&dn)}:{h:Number(r>>io&dn)|0,l:Number(r&dn)|0}}function ef(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=ra(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var rf=(r,t)=>BigInt(r>>>0)<<io|BigInt(t>>>0),nf=(r,t,e)=>r>>>e,sf=(r,t,e)=>r<<32-e|t>>>e,of=(r,t,e)=>r>>>e|t<<32-e,af=(r,t,e)=>r<<32-e|t>>>e,cf=(r,t,e)=>r<<64-e|t>>>e-32,lf=(r,t,e)=>r>>>e-32|t<<64-e,uf=(r,t)=>t,ff=(r,t)=>r,hf=(r,t,e)=>r<<e|t>>>32-e,df=(r,t,e)=>t<<e|r>>>32-e,pf=(r,t,e)=>t<<e-32|r>>>64-e,gf=(r,t,e)=>r<<e-32|t>>>64-e;function yf(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var mf=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,wf=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),xf=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,vf=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Bf=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Ef={fromBig:ra,split:ef,toBig:rf,shrSH:nf,shrSL:sf,rotrSH:of,rotrSL:af,rotrBH:cf,rotrBL:lf,rotr32H:uf,rotr32L:ff,rotlSH:hf,rotlSL:df,rotlBH:pf,rotlBL:gf,add:yf,add3L:mf,add3H:bf,add4L:wf,add4H:xf,add5H:Bf,add5L:vf},O=Ef;var[Af,Sf]=O.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))),le=new Uint32Array(80),ue=new Uint32Array(80),ao=class extends ce{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:f,El:l,Fh:u,Fl:h,Gh:y,Gl:b,Hh:m,Hl:d}=this;return[t,e,n,s,o,i,a,c,f,l,u,h,y,b,m,d]}set(t,e,n,s,o,i,a,c,f,l,u,h,y,b,m,d){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=l|0,this.Fh=u|0,this.Fl=h|0,this.Gh=y|0,this.Gl=b|0,this.Hh=m|0,this.Hl=d|0}process(t,e){for(let p=0;p<16;p++,e+=4)le[p]=t.getUint32(e),ue[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let S=le[p-15]|0,R=ue[p-15]|0,U=O.rotrSH(S,R,1)^O.rotrSH(S,R,8)^O.shrSH(S,R,7),I=O.rotrSL(S,R,1)^O.rotrSL(S,R,8)^O.shrSL(S,R,7),T=le[p-2]|0,C=ue[p-2]|0,W=O.rotrSH(T,C,19)^O.rotrBH(T,C,61)^O.shrSH(T,C,6),q=O.rotrSL(T,C,19)^O.rotrBL(T,C,61)^O.shrSL(T,C,6),P=O.add4L(I,q,ue[p-7],ue[p-16]),tt=O.add4H(P,U,W,le[p-7],le[p-16]);le[p]=tt|0,ue[p]=P|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:f,Dl:l,Eh:u,El:h,Fh:y,Fl:b,Gh:m,Gl:d,Hh:w,Hl:B}=this;for(let p=0;p<80;p++){let S=O.rotrSH(u,h,14)^O.rotrSH(u,h,18)^O.rotrBH(u,h,41),R=O.rotrSL(u,h,14)^O.rotrSL(u,h,18)^O.rotrBL(u,h,41),U=u&y^~u&m,I=h&b^~h&d,T=O.add5L(B,R,I,Sf[p],ue[p]),C=O.add5H(T,w,S,U,Af[p],le[p]),W=T|0,q=O.rotrSH(n,s,28)^O.rotrBH(n,s,34)^O.rotrBH(n,s,39),P=O.rotrSL(n,s,28)^O.rotrBL(n,s,34)^O.rotrBL(n,s,39),tt=n&o^n&a^o&a,E=s&i^s&c^i&c;w=m|0,B=d|0,m=y|0,d=b|0,y=u|0,b=h|0,{h:u,l:h}=O.add(f|0,l|0,C|0,W|0),f=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let N=O.add3L(W,P,E);n=O.add3H(N,C,q,tt),s=N|0}({h:n,l:s}=O.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=O.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=O.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l}=O.add(this.Dh|0,this.Dl|0,f|0,l|0),{h:u,l:h}=O.add(this.Eh|0,this.El|0,u|0,h|0),{h:y,l:b}=O.add(this.Fh|0,this.Fl|0,y|0,b|0),{h:m,l:d}=O.add(this.Gh|0,this.Gl|0,m|0,d|0),{h:w,l:B}=O.add(this.Hh|0,this.Hl|0,w|0,B|0),this.set(n,s,o,i,a,c,f,l,u,h,y,b,m,d,w,B)}roundClean(){le.fill(0),ue.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 fe=sr(()=>new ao);var yn={};ut(yn,{aInRange:()=>vt,abool:()=>Rt,abytes:()=>ir,bitGet:()=>Uf,bitLen:()=>fo,bitMask:()=>Tr,bitSet:()=>Lf,bytesToHex:()=>zt,bytesToNumberBE:()=>Wt,bytesToNumberLE:()=>de,concatBytes:()=>Zt,createHmacDrbg:()=>ho,ensureBytes:()=>Y,equalBytes:()=>Nf,hexToBytes:()=>Ue,hexToNumber:()=>uo,inRange:()=>Nr,isBytes:()=>he,memoized:()=>Re,notImplemented:()=>_f,numberToBytesBE:()=>pe,numberToBytesLE:()=>Le,numberToHexUnpadded:()=>Te,numberToVarBytesBE:()=>Cf,utf8ToBytes:()=>Tf,validateObject:()=>Pt});var pn=BigInt(0),gn=BigInt(1),kf=BigInt(2);function he(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ir(r){if(!he(r))throw new Error("Uint8Array expected")}function Rt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var If=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function zt(r){ir(r);let t="";for(let e=0;e<r.length;e++)t+=If[r[e]];return t}function Te(r){let t=r.toString(16);return t.length&1?"0"+t:t}function uo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?pn:BigInt("0x"+r)}var Gt={_0:48,_9:57,A:65,F:70,a:97,f:102};function na(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("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=na(r.charCodeAt(o)),a=na(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Wt(r){return uo(zt(r))}function de(r){return ir(r),uo(zt(Uint8Array.from(r).reverse()))}function pe(r,t){return Ue(r.toString(16).padStart(t*2,"0"))}function Le(r,t){return pe(r,t).reverse()}function Cf(r){return Ue(Te(r))}function Y(r,t,e){let n;if(typeof t=="string")try{n=Ue(t)}catch(o){throw new Error(r+" must be hex string or Uint8Array, cause: "+o)}else if(he(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function Zt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];ir(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function Nf(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 Tf(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var co=r=>typeof r=="bigint"&&pn<=r;function Nr(r,t,e){return co(r)&&co(t)&&co(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!Nr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function fo(r){let t;for(t=0;r>pn;r>>=gn,t+=1);return t}function Uf(r,t){return r>>BigInt(t)&gn}function Lf(r,t,e){return r|(e?gn:pn)<<BigInt(t)}var Tr=r=>(kf<<BigInt(r-1))-gn,lo=r=>new Uint8Array(r),sa=r=>Uint8Array.from(r);function ho(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=lo(r),s=lo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=lo())=>{s=a(sa([0]),u),n=a(),u.length!==0&&(s=a(sa([1]),u),n=a())},f=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,h=[];for(;u<t;){n=a();let y=n.slice();h.push(y),u+=n.length}return Zt(...h)};return(u,h)=>{i(),c(u);let y;for(;!(y=h(f()));)c();return i(),y}}var Rf={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"||he(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 Pt(r,t,e={}){let n=(s,o,i)=>{let a=Rf[o];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+o+", got "+c)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var _f=()=>{throw new Error("not implemented")};function Re(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var et=BigInt(0),Z=BigInt(1),_e=BigInt(2),Df=BigInt(3),po=BigInt(4),oa=BigInt(5),ia=BigInt(8),Kf=BigInt(9),Of=BigInt(16);function G(r,t){let e=r%t;return e>=et?e:t+e}function Vf(r,t,e){if(t<et)throw new Error("invalid exponent, negatives unsupported");if(e<=et)throw new Error("invalid modulus");if(e===Z)return et;let n=Z;for(;t>et;)t&Z&&(n=n*r%e),r=r*r%e,t>>=Z;return n}function J(r,t,e){let n=r;for(;t-- >et;)n*=n,n%=e;return n}function mn(r,t){if(r===et)throw new Error("invert: expected non-zero number");if(t<=et)throw new Error("invert: expected positive modulus, got "+t);let e=G(r,t),n=t,s=et,o=Z,i=Z,a=et;for(;e!==et;){let f=n/e,l=n%e,u=s-i*f,h=o-a*f;n=e,e=l,s=i,o=a,i=u,a=h}if(n!==Z)throw new Error("invert: does not exist");return G(s,t)}function Hf(r){let t=(r-Z)/_e,e,n,s;for(e=r-Z,n=0;e%_e===et;e/=_e,n++);for(s=_e;s<r&&Vf(s,t,r)!==r-Z;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+Z)/po;return function(c,f){let l=c.pow(f,i);if(!c.eql(c.sqr(l),f))throw new Error("Cannot find square root");return l}}let o=(e+Z)/_e;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,o),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let m=a.sqr(h);y<f&&!a.eql(m,a.ONE);y++)m=a.sqr(m);let b=a.pow(l,Z<<BigInt(f-y-1));l=a.sqr(b),u=a.mul(u,b),h=a.mul(h,l),f=y}return u}}function Pf(r){if(r%po===Df){let t=(r+Z)/po;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%ia===oa){let t=(r-oa)/ia;return function(n,s){let o=n.mul(s,_e),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,_e),i),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%Of,Hf(r)}var aa=(r,t)=>(G(r,t)&Z)===Z,Mf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function go(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Mf.reduce((n,s)=>(n[s]="function",n),t);return Pt(r,e)}function Ff(r,t,e){if(e<et)throw new Error("invalid exponent, negatives unsupported");if(e===et)return r.ONE;if(e===Z)return t;let n=r.ONE,s=t;for(;e>et;)e&Z&&(n=r.mul(n,s)),s=r.sqr(s),e>>=Z;return n}function qf(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function yo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ge(r,t,e=!1,n={}){if(r<=et)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:o}=yo(r,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:s,BYTES:o,MASK:Tr(s),ZERO:et,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 et<=c&&c<r},is0:c=>c===et,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)=>Ff(a,c,f),div:(c,f)=>G(c*mn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>mn(c,r),sqrt:n.sqrt||(c=>(i||(i=Pf(r)),i(a,c))),invertBatch:c=>qf(a,c),cmov:(c,f,l)=>l?f:c,toBytes:c=>e?Le(c,o):pe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+c.length);return e?de(c):Wt(c)}});return Object.freeze(a)}function ca(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 mo(r){let t=ca(r);return t+Math.ceil(t/2)}function la(r,t,e=!1){let n=r.length,s=ca(t),o=mo(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?de(r):Wt(r),a=G(i,t-Z)+Z;return e?Le(a,s):pe(a,s)}var ua=BigInt(0),bn=BigInt(1);function bo(r,t){let e=t.negate();return r?e:t}function fa(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function wo(r,t){fa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function jf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function $f(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var xo=new WeakMap,ha=new WeakMap;function vo(r){return ha.get(r)||1}function wn(r,t){return{constTimeNegate:bo,hasPrecomputes(e){return vo(e)!==1},unsafeLadder(e,n,s=r.ZERO){let o=e;for(;n>ua;)n&bn&&(s=s.add(o)),o=o.double(),n>>=bn;return s},precomputeWindow(e,n){let{windows:s,windowSize:o}=wo(n,t),i=[],a=e,c=a;for(let f=0;f<s;f++){c=a,i.push(c);for(let l=1;l<o;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,s){let{windows:o,windowSize:i}=wo(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let h=0;h<o;h++){let y=h*i,b=Number(s&f);s>>=u,b>i&&(b-=l,s+=bn);let m=y,d=y+Math.abs(b)-1,w=h%2!==0,B=b<0;b===0?c=c.add(bo(w,n[m])):a=a.add(bo(B,n[d]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,o=r.ZERO){let{windows:i,windowSize:a}=wo(e,t),c=BigInt(2**e-1),f=2**e,l=BigInt(e);for(let u=0;u<i;u++){let h=u*a;if(s===ua)break;let y=Number(s&c);if(s>>=l,y>a&&(y-=f,s+=bn),y===0)continue;let b=n[h+Math.abs(y)-1];y<0&&(b=b.negate()),o=o.add(b)}return o},getPrecomputes(e,n,s){let o=xo.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&xo.set(n,s(o))),o},wNAFCached(e,n,s){let o=vo(e);return this.wNAF(o,this.getPrecomputes(o,e,s),n)},wNAFCachedUnsafe(e,n,s,o){let i=vo(e);return i===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(i,this.getPrecomputes(i,e,s),n,o)},setWindowSize(e,n){fa(n,t),ha.set(e,n),xo.delete(e)}}}function xn(r,t,e,n){if(jf(e,r),$f(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,o=fo(BigInt(e.length)),i=o>12?o-3:o>4?o-2:o?2:1,a=(1<<i)-1,c=new Array(a+1).fill(s),f=Math.floor((t.BITS-1)/i)*i,l=s;for(let u=f;u>=0;u-=i){c.fill(s);for(let y=0;y<n.length;y++){let b=n[y],m=Number(b>>BigInt(u)&BigInt(a));c[m]=c[m].add(e[y])}let h=s;for(let y=c.length-1,b=s;y>0;y--)b=b.add(c[y]),h=h.add(b);if(l=l.add(h),u!==0)for(let y=0;y<i;y++)l=l.double()}return l}function Ur(r){return go(r.Fp),Pt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...yo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var _t=BigInt(0),Bt=BigInt(1),vn=BigInt(2),Gf=BigInt(8),zf={zip215:!0};function Wf(r){let t=Ur(r);return Pt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function da(r){let t=Wf(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,f=vn<<BigInt(a*8)-Bt,l=e.create,u=ge(t.n,t.nBitLength),h=t.uvRatio||((x,g)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(g))}}catch{return{isValid:!1,value:_t}}}),y=t.adjustScalarBytes||(x=>x),b=t.domain||((x,g,v)=>{if(Rt("phflag",v),g.length||v)throw new Error("Contexts/pre-hash are not supported");return x});function m(x,g){vt("coordinate "+x,g,_t,f)}function d(x){if(!(x instanceof p))throw new Error("ExtendedPoint expected")}let w=Re((x,g)=>{let{ex:v,ey:k,ez:_}=x,D=x.is0();g==null&&(g=D?Gf:e.inv(_));let V=l(v*g),F=l(k*g),K=l(_*g);if(D)return{x:_t,y:Bt};if(K!==Bt)throw new Error("invZ was invalid");return{x:V,y:F}}),B=Re(x=>{let{a:g,d:v}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:k,ey:_,ez:D,et:V}=x,F=l(k*k),K=l(_*_),$=l(D*D),z=l($*$),nt=l(F*g),st=l($*l(nt+K)),it=l(z+l(v*l(F*K)));if(st!==it)throw new Error("bad point: equation left != right (1)");let lt=l(k*_),bt=l(D*V);if(lt!==bt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,v,k,_){this.ex=g,this.ey=v,this.ez=k,this.et=_,m("x",g),m("y",v),m("z",k),m("t",_),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:v,y:k}=g||{};return m("x",v),m("y",k),new p(v,k,Bt,l(v*k))}static normalizeZ(g){let v=e.invertBatch(g.map(k=>k.ez));return g.map((k,_)=>k.toAffine(v[_])).map(p.fromAffine)}static msm(g,v){return xn(p,u,g,v)}_setWindowSize(g){U.setWindowSize(this,g)}assertValidity(){B(this)}equals(g){d(g);let{ex:v,ey:k,ez:_}=this,{ex:D,ey:V,ez:F}=g,K=l(v*F),$=l(D*_),z=l(k*F),nt=l(V*_);return K===$&&z===nt}is0(){return this.equals(p.ZERO)}negate(){return new p(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:g}=t,{ex:v,ey:k,ez:_}=this,D=l(v*v),V=l(k*k),F=l(vn*l(_*_)),K=l(g*D),$=v+k,z=l(l($*$)-D-V),nt=K+V,st=nt-F,it=K-V,lt=l(z*st),bt=l(nt*it),dt=l(z*it),Ht=l(st*nt);return new p(lt,bt,Ht,dt)}add(g){d(g);let{a:v,d:k}=t,{ex:_,ey:D,ez:V,et:F}=this,{ex:K,ey:$,ez:z,et:nt}=g;if(v===BigInt(-1)){let ci=l((D-_)*($+K)),li=l((D+_)*($-K)),Ts=l(li-ci);if(Ts===_t)return this.double();let ui=l(V*vn*nt),fi=l(F*vn*z),hi=fi+ui,di=li+ci,pi=fi-ui,Al=l(hi*Ts),Sl=l(di*pi),kl=l(hi*pi),Il=l(Ts*di);return new p(Al,Sl,Il,kl)}let st=l(_*K),it=l(D*$),lt=l(F*k*nt),bt=l(V*z),dt=l((_+D)*(K+$)-st-it),Ht=bt-lt,qt=bt+lt,mr=l(it-v*st),xl=l(dt*Ht),vl=l(qt*mr),Bl=l(dt*mr),El=l(Ht*qt);return new p(xl,vl,El,Bl)}subtract(g){return this.add(g.negate())}wNAF(g){return U.wNAFCached(this,g,p.normalizeZ)}multiply(g){let v=g;vt("scalar",v,Bt,n);let{p:k,f:_}=this.wNAF(v);return p.normalizeZ([k,_])[0]}multiplyUnsafe(g,v=p.ZERO){let k=g;return vt("scalar",k,_t,n),k===_t?R:this.is0()||k===Bt?this:U.wNAFCachedUnsafe(this,k,p.normalizeZ,v)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return U.unsafeLadder(this,n).is0()}toAffine(g){return w(this,g)}clearCofactor(){let{h:g}=t;return g===Bt?this:this.multiplyUnsafe(g)}static fromHex(g,v=!1){let{d:k,a:_}=t,D=e.BYTES;g=Y("pointHex",g,D),Rt("zip215",v);let V=g.slice(),F=g[D-1];V[D-1]=F&-129;let K=de(V),$=v?f:e.ORDER;vt("pointHex.y",K,_t,$);let z=l(K*K),nt=l(z-Bt),st=l(k*z-_),{isValid:it,value:lt}=h(nt,st);if(!it)throw new Error("Point.fromHex: invalid y coordinate");let bt=(lt&Bt)===Bt,dt=(F&128)!==0;if(!v&<===_t&&dt)throw new Error("Point.fromHex: x=0 and x_0=1");return dt!==bt&&(lt=l(-lt)),p.fromAffine({x:lt,y:K})}static fromPrivateKey(g){return C(g).point}toRawBytes(){let{x:g,y:v}=this.toAffine(),k=Le(v,e.BYTES);return k[k.length-1]|=g&Bt?128:0,k}toHex(){return zt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Bt,l(t.Gx*t.Gy)),p.ZERO=new p(_t,Bt,Bt,_t);let{BASE:S,ZERO:R}=p,U=wn(p,a*8);function I(x){return G(x,n)}function T(x){return I(de(x))}function C(x){let g=e.BYTES;x=Y("private key",x,g);let v=Y("hashed private key",o(x),2*g),k=y(v.slice(0,g)),_=v.slice(g,2*g),D=T(k),V=S.multiply(D),F=V.toRawBytes();return{head:k,prefix:_,scalar:D,point:V,pointBytes:F}}function W(x){return C(x).pointBytes}function q(x=new Uint8Array,...g){let v=Zt(...g);return T(o(b(v,Y("context",x),!!s)))}function P(x,g,v={}){x=Y("message",x),s&&(x=s(x));let{prefix:k,scalar:_,pointBytes:D}=C(g),V=q(v.context,k,x),F=S.multiply(V).toRawBytes(),K=q(v.context,F,D,x),$=I(V+K*_);vt("signature.s",$,_t,n);let z=Zt(F,Le($,e.BYTES));return Y("result",z,e.BYTES*2)}let tt=zf;function E(x,g,v,k=tt){let{context:_,zip215:D}=k,V=e.BYTES;x=Y("signature",x,2*V),g=Y("message",g),v=Y("publicKey",v,V),D!==void 0&&Rt("zip215",D),s&&(g=s(g));let F=de(x.slice(V,2*V)),K,$,z;try{K=p.fromHex(v,D),$=p.fromHex(x.slice(0,V),D),z=S.multiplyUnsafe(F)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let nt=q(_,$.toRawBytes(),K.toRawBytes(),g);return $.add(K.multiplyUnsafe(nt)).subtract(z).clearCofactor().equals(p.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:W,sign:P,verify:E,ExtendedPoint:p,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>i(e.BYTES),precompute(x=8,g=p.BASE){return g._setWindowSize(x),g.multiply(BigInt(3)),g}}}}var Bo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),pa=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),zp=BigInt(0),Zf=BigInt(1),ga=BigInt(2),Wp=BigInt(3),Jf=BigInt(5),Yf=BigInt(8);function Xf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Bo,a=r*r%o*r%o,c=J(a,ga,o)*a%o,f=J(c,Zf,o)*r%o,l=J(f,Jf,o)*f%o,u=J(l,t,o)*l%o,h=J(u,e,o)*u%o,y=J(h,n,o)*h%o,b=J(y,s,o)*y%o,m=J(b,s,o)*y%o,d=J(m,t,o)*l%o;return{pow_p_5_8:J(d,ga,o)*r%o,b2:a}}function Qf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function th(r,t){let e=Bo,n=G(t*t*t,e),s=G(n*n*t,e),o=Xf(r*s).pow_p_5_8,i=G(r*n*o,e),a=G(t*i*i,e),c=i,f=G(i*pa,e),l=a===r,u=a===G(-r,e),h=a===G(-r*pa,e);return l&&(i=c),(u||h)&&(i=f),aa(i,e)&&(i=G(-i,e)),{isValid:l||u,value:i}}var eh=ge(Bo,void 0,!0),rh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:eh,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Yf,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:fe,randomBytes:or,adjustScalarBytes:Qf,uvRatio:th},Eo=da(rh);var ar=32,Dt=64,nh=32;function ya(r,t){let e=r.subarray(0,nh);return Eo.sign(t instanceof Uint8Array?t:t.subarray(),e)}function ma(r,t,e){return Eo.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Bn=class{type="Ed25519";raw;constructor(t){this.raw=Rr(t,ar)}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return ma(this.raw,e,t)}},Lr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Rr(t,Dt),this.publicKey=new Bn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return ya(this.raw,t)}};function Ao(r){if(r.length>Dt){r=Rr(r,Dt+ar);let n=r.subarray(0,Dt),s=r.subarray(Dt,r.length);return new Lr(n,s)}r=Rr(r,Dt);let t=r.subarray(0,Dt),e=r.subarray(ar);return new Lr(t,e)}function Rr(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new L(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var sh=Math.pow(2,7),oh=Math.pow(2,14),ih=Math.pow(2,21),wa=Math.pow(2,28),xa=Math.pow(2,35),va=Math.pow(2,42),Ba=Math.pow(2,49),yt=128,ye=127;function _r(r){if(r<sh)return 1;if(r<oh)return 2;if(r<ih)return 3;if(r<wa)return 4;if(r<xa)return 5;if(r<va)return 6;if(r<Ba)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ea(r,t,e=0){switch(_r(r)){case 8:t[e++]=r&255|yt,r/=128;case 7:t[e++]=r&255|yt,r/=128;case 6:t[e++]=r&255|yt,r/=128;case 5:t[e++]=r&255|yt,r/=128;case 4:t[e++]=r&255|yt,r>>>=7;case 3:t[e++]=r&255|yt,r>>>=7;case 2:t[e++]=r&255|yt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Aa(r,t){let e=r[t],n=0;if(n+=e&ye,e<yt||(e=r[t+1],n+=(e&ye)<<7,e<yt)||(e=r[t+2],n+=(e&ye)<<14,e<yt)||(e=r[t+3],n+=(e&ye)<<21,e<yt)||(e=r[t+4],n+=(e&ye)*wa,e<yt)||(e=r[t+5],n+=(e&ye)*xa,e<yt)||(e=r[t+6],n+=(e&ye)*va,e<yt)||(e=r[t+7],n+=(e&ye)*Ba,e<yt))return n;throw new RangeError("Could not decode varint")}var So=new Float32Array([-0]),me=new Uint8Array(So.buffer);function Sa(r,t,e){So[0]=r,t[e]=me[0],t[e+1]=me[1],t[e+2]=me[2],t[e+3]=me[3]}function ka(r,t){return me[0]=r[t],me[1]=r[t+1],me[2]=r[t+2],me[3]=r[t+3],So[0]}var ko=new Float64Array([-0]),ft=new Uint8Array(ko.buffer);function Ia(r,t,e){ko[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3],t[e+4]=ft[4],t[e+5]=ft[5],t[e+6]=ft[6],t[e+7]=ft[7]}function Ca(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],ft[4]=r[t+4],ft[5]=r[t+5],ft[6]=r[t+6],ft[7]=r[t+7],ko[0]}var ah=BigInt(Number.MAX_SAFE_INTEGER),ch=BigInt(Number.MIN_SAFE_INTEGER),kt=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<ah&&t>ch)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>Na&&(s=0n,++n>Na&&(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 kt(0,0);De.toBigInt=function(){return 0n};De.zzEncode=De.zzDecode=function(){return this};De.length=function(){return 1};var Na=4294967296n;function Ta(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ua(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Io(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Kt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function En(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Co=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,Kt(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 Kt(this,4);return En(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Kt(this,4);return En(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Kt(this,4);let t=ka(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Kt(this,4);let t=Ca(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 Kt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ua(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Kt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Kt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new kt(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 Kt(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 Kt(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 Kt(this,8);let t=En(this.buf,this.pos+=4),e=En(this.buf,this.pos+=4);return new kt(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=Aa(this.buf,this.pos);return this.pos+=_r(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 No(r){return new Co(r instanceof Uint8Array?r:r.subarray())}function An(r,t,e){let n=No(r);return t.decode(n,void 0,e)}function To(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return St(i);s+i>t&&(n=St(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Uo(){}var Ro=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},lh=To();function uh(r){return globalThis.Buffer!=null?St(r):lh(r)}var Kr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(Uo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new _o((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(Sn,10,kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=kt.fromBigInt(t);return this._push(Sn,e.length(),e)}uint64Number(t){return this._push(Ea,_r(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=kt.fromBigInt(t).zzEncode();return this._push(Sn,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(Sn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Lo,1,t?1:0)}fixed32(t){return this._push(Dr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(Dr,4,e.lo)._push(Dr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(Dr,4,e.lo)._push(Dr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Sa,4,t)}double(t){return this._push(Ia,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Lo,1,0):this.uint32(e)._push(hh,e,t)}string(t){let e=Ta(t);return e!==0?this.uint32(e)._push(Io,e,t):this._push(Lo,1,0)}fork(){return this.states=new Ro(this),this.head=this.tail=new Ke(Uo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Ke(Uo,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=uh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Lo(r,t,e){t[e]=r&255}function fh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var _o=class extends Ke{next;constructor(t,e){super(fh,t,e),this.next=void 0}};function Sn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Dr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function hh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Kr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(dh,t,r),this},Kr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(ph,t,r),this});function dh(r,t,e){t.set(r,e)}function ph(r,t,e){r.length<40?Io(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(H(r),e)}function Do(){return new Kr}function kn(r,t){let e=Do();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var cr;(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"})(cr||(cr={}));function In(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ko(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return In("enum",cr.VARINT,e,n)}function Cn(r,t){return In("message",cr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var Oo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Oo||(Oo={}));(function(r){r.codec=()=>Ko(Oo)})(rt||(rt={}));var be;(function(r){let t;r.codec=()=>(t==null&&(t=Cn((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,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>kn(e,r.codec()),r.decode=(e,n)=>An(e,r.codec(),n)})(be||(be={}));var Or;(function(r){let t;r.codec=()=>(t==null&&(t=Cn((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,s={})=>{let o={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{o.Type=rt.codec().decode(e);break}case 2:{o.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return o})),t),r.encode=e=>kn(e,r.codec()),r.decode=(e,n)=>An(e,r.codec(),n)})(Or||(Or={}));function Oe(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return or(r)}var Hr={};ut(Hr,{MAX_RSA_KEY_SIZE:()=>Ho,generateRSAKeyPair:()=>Oa,jwkToJWKKeyPair:()=>Va,jwkToPkcs1:()=>wh,jwkToPkix:()=>qo,jwkToRSAPrivateKey:()=>Go,pkcs1MessageToJwk:()=>Mo,pkcs1MessageToRSAPrivateKey:()=>Nn,pkcs1ToJwk:()=>bh,pkcs1ToRSAPrivateKey:()=>jo,pkixMessageToJwk:()=>Fo,pkixMessageToRSAPublicKey:()=>$o,pkixToJwk:()=>xh,pkixToRSAPublicKey:()=>Ka});var gh=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),xe=new Uint32Array(64),Vo=class extends ce{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)xe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let h=xe[u-15],y=xe[u-2],b=Lt(h,7)^Lt(h,18)^h>>>3,m=Lt(y,17)^Lt(y,19)^y>>>10;xe[u]=m+xe[u-7]+b+xe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:f,H:l}=this;for(let u=0;u<64;u++){let h=Lt(a,6)^Lt(a,11)^Lt(a,25),y=l+h+fn(a,c,f)+gh[u]+xe[u]|0,m=(Lt(n,2)^Lt(n,13)^Lt(n,22))+hn(n,s,o)|0;l=f,f=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+m|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,f,l)}roundClean(){xe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var ve=sr(()=>new Vo);var lr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Hr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return It.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Da(this.jwk,e,t)}},Vr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Hr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return _a(this.jwk,t)}};var Ho=8192,Po=18,yh=1062,mh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function bh(r){let t=Tt(r);return Mo(t)}function Mo(r){return{n:j(r[1],"base64url"),e:j(r[2],"base64url"),d:j(r[3],"base64url"),p:j(r[4],"base64url"),q:j(r[5],"base64url"),dp:j(r[6],"base64url"),dq:j(r[7],"base64url"),qi:j(r[8],"base64url"),kty:"RSA"}}function wh(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 L("JWK was missing components");return Ut([gt(Uint8Array.from([0])),gt(H(r.n,"base64url")),gt(H(r.e,"base64url")),gt(H(r.d,"base64url")),gt(H(r.p,"base64url")),gt(H(r.q,"base64url")),gt(H(r.dp,"base64url")),gt(H(r.dq,"base64url")),gt(H(r.qi,"base64url"))]).subarray()}function xh(r){let t=Tt(r,{offset:0});return Fo(t)}function Fo(r){let t=Tt(r[1],{offset:0});return{kty:"RSA",n:j(t[0],"base64url"),e:j(t[1],"base64url")}}function qo(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Ut([mh,Cr(Ut([gt(H(r.n,"base64url")),gt(H(r.e,"base64url"))]))]).subarray()}function jo(r){let t=Tt(r);return Nn(t)}function Nn(r){let t=Mo(r);return Go(t)}function Ka(r,t){if(r.byteLength>=yh)throw new qe("Key size is too large");let e=Tt(r,{offset:0});return $o(e,r,t)}function $o(r,t,e){let n=Fo(r);if(e==null){let s=ve(be.encode({Type:rt.RSA,Data:t}));e=Nt(Po,s)}return new lr(n,e)}function Go(r){if(Pa(r)>Ho)throw new L("Key size is too large");let t=Va(r),e=ve(be.encode({Type:rt.RSA,Data:qo(t.publicKey)})),n=Nt(Po,e);return new Vr(t.privateKey,new lr(t.publicKey,n))}async function Oa(r){if(r>Ho)throw new L("Key size is too large");let t=await Ha(r),e=ve(be.encode({Type:rt.RSA,Data:qo(t.publicKey)})),n=Nt(Po,e);return new Vr(t.privateKey,new lr(t.publicKey,n))}function Va(r){if(r==null)throw new L("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ha(r){let t=await wt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await vh(t);return{privateKey:e[0],publicKey:e[1]}}async function _a(r,t){let e=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await wt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Da(r,t,e){let n=await wt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return wt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function vh(r){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");return Promise.all([wt.get().subtle.exportKey("jwk",r.privateKey),wt.get().subtle.exportKey("jwk",r.publicKey)])}function Pa(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return H(r.n,"base64url").length*8}var Tn=class extends nr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ln(t);let n=ae(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return rr(this),this.iHash.update(t),this}digestInto(t){rr(this),er(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Pr=(r,t,e)=>new Tn(r,t).update(e).digest();Pr.create=(r,t)=>new Tn(r,t);function Ma(r){r.lowS!==void 0&&Rt("lowS",r.lowS),r.prehash!==void 0&&Rt("prehash",r.prehash)}function Bh(r){let t=Ur(r);Pt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Eh,hexToBytes:Ah}=yn,zo=class extends Error{constructor(t=""){super(t)}},Jt={Err:zo,_tlv:{encode:(r,t)=>{let{Err:e}=Jt;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Te(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Te(s.length/2|128):"";return Te(r)+o+s+t},decode(r,t){let{Err:e}=Jt,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of f)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Jt;if(r<Yt)throw new t("integer: negative integers are not allowed");let e=Te(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Jt;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Eh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Jt,s=typeof r=="string"?Ah(r):r;ir(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:f,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=Jt,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},Yt=BigInt(0),ot=BigInt(1),xy=BigInt(2),Fa=BigInt(3),vy=BigInt(4);function Sh(r){let t=Bh(r),{Fp:e}=t,n=ge(t.n,t.nBitLength),s=t.toBytes||((m,d,w)=>{let B=d.toAffine();return Zt(Uint8Array.from([4]),e.toBytes(B.x),e.toBytes(B.y))}),o=t.fromBytes||(m=>{let d=m.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),B=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:B}});function i(m){let{a:d,b:w}=t,B=e.sqr(m),p=e.mul(B,m);return e.add(e.add(p,e.mul(m,d)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Nr(m,ot,t.n)}function c(m){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:B,n:p}=t;if(d&&typeof m!="bigint"){if(he(m)&&(m=zt(m)),typeof m!="string"||!d.includes(m.length))throw new Error("invalid private key");m=m.padStart(w*2,"0")}let S;try{S=typeof m=="bigint"?m:Wt(Y("private key",m,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof m)}return B&&(S=G(S,p)),vt("private key",S,ot,p),S}function f(m){if(!(m instanceof h))throw new Error("ProjectivePoint expected")}let l=Re((m,d)=>{let{px:w,py:B,pz:p}=m;if(e.eql(p,e.ONE))return{x:w,y:B};let S=m.is0();d==null&&(d=S?e.ONE:e.inv(p));let R=e.mul(w,d),U=e.mul(B,d),I=e.mul(p,d);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:R,y:U}}),u=Re(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=m.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let B=e.sqr(w),p=i(d);if(!e.eql(B,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class h{constructor(d,w,B){if(this.px=d,this.py=w,this.pz=B,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(B==null||!e.isValid(B))throw new Error("z required");Object.freeze(this)}static fromAffine(d){let{x:w,y:B}=d||{};if(!d||!e.isValid(w)||!e.isValid(B))throw new Error("invalid affine point");if(d instanceof h)throw new Error("projective point not allowed");let p=S=>e.eql(S,e.ZERO);return p(w)&&p(B)?h.ZERO:new h(w,B,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(B=>B.pz));return d.map((B,p)=>B.toAffine(w[p])).map(h.fromAffine)}static fromHex(d){let w=h.fromAffine(o(Y("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return h.BASE.multiply(c(d))}static msm(d,w){return xn(h,n,d,w)}_setWindowSize(d){b.setWindowSize(this,d)}assertValidity(){u(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:R,pz:U}=d,I=e.eql(e.mul(w,U),e.mul(S,p)),T=e.eql(e.mul(B,U),e.mul(R,p));return I&&T}negate(){return new h(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,B=e.mul(w,Fa),{px:p,py:S,pz:R}=this,U=e.ZERO,I=e.ZERO,T=e.ZERO,C=e.mul(p,p),W=e.mul(S,S),q=e.mul(R,R),P=e.mul(p,S);return P=e.add(P,P),T=e.mul(p,R),T=e.add(T,T),U=e.mul(d,T),I=e.mul(B,q),I=e.add(U,I),U=e.sub(W,I),I=e.add(W,I),I=e.mul(U,I),U=e.mul(P,U),T=e.mul(B,T),q=e.mul(d,q),P=e.sub(C,q),P=e.mul(d,P),P=e.add(P,T),T=e.add(C,C),C=e.add(T,C),C=e.add(C,q),C=e.mul(C,P),I=e.add(I,C),q=e.mul(S,R),q=e.add(q,q),C=e.mul(q,P),U=e.sub(U,C),T=e.mul(q,W),T=e.add(T,T),T=e.add(T,T),new h(U,I,T)}add(d){f(d);let{px:w,py:B,pz:p}=this,{px:S,py:R,pz:U}=d,I=e.ZERO,T=e.ZERO,C=e.ZERO,W=t.a,q=e.mul(t.b,Fa),P=e.mul(w,S),tt=e.mul(B,R),E=e.mul(p,U),N=e.add(w,B),x=e.add(S,R);N=e.mul(N,x),x=e.add(P,tt),N=e.sub(N,x),x=e.add(w,p);let g=e.add(S,U);return x=e.mul(x,g),g=e.add(P,E),x=e.sub(x,g),g=e.add(B,p),I=e.add(R,U),g=e.mul(g,I),I=e.add(tt,E),g=e.sub(g,I),C=e.mul(W,x),I=e.mul(q,E),C=e.add(I,C),I=e.sub(tt,C),C=e.add(tt,C),T=e.mul(I,C),tt=e.add(P,P),tt=e.add(tt,P),E=e.mul(W,E),x=e.mul(q,x),tt=e.add(tt,E),E=e.sub(P,E),E=e.mul(W,E),x=e.add(x,E),P=e.mul(tt,x),T=e.add(T,P),P=e.mul(g,x),I=e.mul(N,I),I=e.sub(I,P),P=e.mul(N,tt),C=e.mul(g,C),C=e.add(C,P),new h(I,T,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(h.ZERO)}wNAF(d){return b.wNAFCached(this,d,h.normalizeZ)}multiplyUnsafe(d){let{endo:w,n:B}=t;vt("scalar",d,Yt,B);let p=h.ZERO;if(d===Yt)return p;if(this.is0()||d===ot)return this;if(!w||b.hasPrecomputes(this))return b.wNAFCachedUnsafe(this,d,h.normalizeZ);let{k1neg:S,k1:R,k2neg:U,k2:I}=w.splitScalar(d),T=p,C=p,W=this;for(;R>Yt||I>Yt;)R&ot&&(T=T.add(W)),I&ot&&(C=C.add(W)),W=W.double(),R>>=ot,I>>=ot;return S&&(T=T.negate()),U&&(C=C.negate()),C=new h(e.mul(C.px,w.beta),C.py,C.pz),T.add(C)}multiply(d){let{endo:w,n:B}=t;vt("scalar",d,ot,B);let p,S;if(w){let{k1neg:R,k1:U,k2neg:I,k2:T}=w.splitScalar(d),{p:C,f:W}=this.wNAF(U),{p:q,f:P}=this.wNAF(T);C=b.constTimeNegate(R,C),q=b.constTimeNegate(I,q),q=new h(e.mul(q.px,w.beta),q.py,q.pz),p=C.add(q),S=W.add(P)}else{let{p:R,f:U}=this.wNAF(d);p=R,S=U}return h.normalizeZ([p,S])[0]}multiplyAndAddUnsafe(d,w,B){let p=h.BASE,S=(U,I)=>I===Yt||I===ot||!U.equals(p)?U.multiplyUnsafe(I):U.multiply(I),R=S(this,w).add(S(d,B));return R.is0()?void 0:R}toAffine(d){return l(this,d)}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===ot)return!0;if(w)return w(h,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===ot?this:w?w(h,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return Rt("isCompressed",d),this.assertValidity(),s(h,this,d)}toHex(d=!0){return Rt("isCompressed",d),zt(this.toRawBytes(d))}}h.BASE=new h(t.Gx,t.Gy,e.ONE),h.ZERO=new h(e.ZERO,e.ONE,e.ZERO);let y=t.nBitLength,b=wn(h,t.endo?Math.ceil(y/2):y);return{CURVE:t,ProjectivePoint:h,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function kh(r){let t=Ur(r);return Pt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function qa(r){let t=kh(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(E){return G(E,n)}function a(E){return mn(E,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:u}=Sh({...t,toBytes(E,N,x){let g=N.toAffine(),v=e.toBytes(g.x),k=Zt;return Rt("isCompressed",x),x?k(Uint8Array.from([N.hasEvenY()?2:3]),v):k(Uint8Array.from([4]),v,e.toBytes(g.y))},fromBytes(E){let N=E.length,x=E[0],g=E.subarray(1);if(N===s&&(x===2||x===3)){let v=Wt(g);if(!Nr(v,ot,e.ORDER))throw new Error("Point is not on curve");let k=l(v),_;try{_=e.sqrt(k)}catch(F){let K=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+K)}let D=(_&ot)===ot;return(x&1)===1!==D&&(_=e.neg(_)),{x:v,y:_}}else if(N===o&&x===4){let v=e.fromBytes(g.subarray(0,e.BYTES)),k=e.fromBytes(g.subarray(e.BYTES,2*e.BYTES));return{x:v,y:k}}else{let v=s,k=o;throw new Error("invalid Point, expected length of "+v+", or uncompressed "+k+", got "+N)}}}),h=E=>zt(pe(E,t.nByteLength));function y(E){let N=n>>ot;return E>N}function b(E){return y(E)?i(-E):E}let m=(E,N,x)=>Wt(E.slice(N,x));class d{constructor(N,x,g){this.r=N,this.s=x,this.recovery=g,this.assertValidity()}static fromCompact(N){let x=t.nByteLength;return N=Y("compactSignature",N,x*2),new d(m(N,0,x),m(N,x,2*x))}static fromDER(N){let{r:x,s:g}=Jt.toSig(Y("DER",N));return new d(x,g)}assertValidity(){vt("r",this.r,ot,n),vt("s",this.s,ot,n)}addRecoveryBit(N){return new d(this.r,this.s,N)}recoverPublicKey(N){let{r:x,s:g,recovery:v}=this,k=U(Y("msgHash",N));if(v==null||![0,1,2,3].includes(v))throw new Error("recovery id invalid");let _=v===2||v===3?x+t.n:x;if(_>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(v&1)===0?"02":"03",V=c.fromHex(D+h(_)),F=a(_),K=i(-k*F),$=i(g*F),z=c.BASE.multiplyAndAddUnsafe(V,K,$);if(!z)throw new Error("point at infinify");return z.assertValidity(),z}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ue(this.toDERHex())}toDERHex(){return Jt.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ue(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let w={isValidPrivateKey(E){try{return f(E),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let E=mo(t.n);return la(t.randomBytes(E),t.n)},precompute(E=8,N=c.BASE){return N._setWindowSize(E),N.multiply(BigInt(3)),N}};function B(E,N=!0){return c.fromPrivateKey(E).toRawBytes(N)}function p(E){let N=he(E),x=typeof E=="string",g=(N||x)&&E.length;return N?g===s||g===o:x?g===2*s||g===2*o:E instanceof c}function S(E,N,x=!0){if(p(E))throw new Error("first arg must be private key");if(!p(N))throw new Error("second arg must be public key");return c.fromHex(N).multiply(f(E)).toRawBytes(x)}let R=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let N=Wt(E),x=E.length*8-t.nBitLength;return x>0?N>>BigInt(x):N},U=t.bits2int_modN||function(E){return i(R(E))},I=Tr(t.nBitLength);function T(E){return vt("num < 2^"+t.nBitLength,E,Yt,I),pe(E,t.nByteLength)}function C(E,N,x=W){if(["recovered","canonical"].some(st=>st in x))throw new Error("sign() legacy options not supported");let{hash:g,randomBytes:v}=t,{lowS:k,prehash:_,extraEntropy:D}=x;k==null&&(k=!0),E=Y("msgHash",E),Ma(x),_&&(E=Y("prehashed msgHash",g(E)));let V=U(E),F=f(N),K=[T(F),T(V)];if(D!=null&&D!==!1){let st=D===!0?v(e.BYTES):D;K.push(Y("extraEntropy",st))}let $=Zt(...K),z=V;function nt(st){let it=R(st);if(!u(it))return;let lt=a(it),bt=c.BASE.multiply(it).toAffine(),dt=i(bt.x);if(dt===Yt)return;let Ht=i(lt*i(z+dt*F));if(Ht===Yt)return;let qt=(bt.x===dt?0:2)|Number(bt.y&ot),mr=Ht;return k&&y(Ht)&&(mr=b(Ht),qt^=1),new d(dt,mr,qt)}return{seed:$,k2sig:nt}}let W={lowS:t.lowS,prehash:!1},q={lowS:t.lowS,prehash:!1};function P(E,N,x=W){let{seed:g,k2sig:v}=C(E,N,x),k=t;return ho(k.hash.outputLen,k.nByteLength,k.hmac)(g,v)}c.BASE._setWindowSize(8);function tt(E,N,x,g=q){let v=E;N=Y("msgHash",N),x=Y("publicKey",x);let{lowS:k,prehash:_,format:D}=g;if(Ma(g),"strict"in g)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let V=typeof v=="string"||he(v),F=!V&&!D&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!V&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,$;try{if(F&&(K=new d(v.r,v.s)),V){try{D!=="compact"&&(K=d.fromDER(v))}catch(qt){if(!(qt instanceof Jt.Err))throw qt}!K&&D!=="der"&&(K=d.fromCompact(v))}$=c.fromHex(x)}catch{return!1}if(!K||k&&K.hasHighS())return!1;_&&(N=t.hash(N));let{r:z,s:nt}=K,st=U(N),it=a(nt),lt=i(st*it),bt=i(z*it),dt=c.BASE.multiplyAndAddUnsafe($,lt,bt)?.toAffine();return dt?i(dt.x)===z:!1}return{CURVE:t,getPublicKey:B,getSharedSecret:S,sign:P,verify:tt,ProjectivePoint:c,Signature:d,utils:w}}function Ih(r){return{hash:r,hmac:(t,...e)=>Pr(r,t,oo(...e)),randomBytes:or}}function ja(r,t){let e=n=>qa({...r,...Ih(n)});return{...e(t),create:e}}var za=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),$a=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ch=BigInt(1),Wo=BigInt(2),Ga=(r,t)=>(r+t/Wo)/t;function Nh(r){let t=za,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=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,h=J(u,e,t)*l%t,y=J(h,Wo,t)*f%t,b=J(y,s,t)*y%t,m=J(b,o,t)*b%t,d=J(m,a,t)*m%t,w=J(d,c,t)*d%t,B=J(w,a,t)*m%t,p=J(B,e,t)*l%t,S=J(p,i,t)*b%t,R=J(S,n,t)*f%t,U=J(R,Wo,t);if(!Zo.eql(Zo.sqr(U),r))throw new Error("Cannot find square root");return U}var Zo=ge(za,void 0,void 0,{sqrt:Nh}),Ot=ja({a:BigInt(0),b:BigInt(7),Fp:Zo,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=-Ch*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ga(o*r,t),c=Ga(-n*r,t),f=G(r-a*e-c*s,t),l=G(-a*n-c*o,t),u=f>i,h=l>i;if(u&&(f=t-f),h&&(l=t-l),f>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:f,k2neg:h,k2:l}}}},ve),Ty=BigInt(0);var Uy=Ot.ProjectivePoint;function Jo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Wa=32;function Za(r,t){let e=Ye.digest(t instanceof Uint8Array?t:t.subarray());if(Jo(e))return e.then(({digest:n})=>Ot.sign(n,r).toDERRawBytes()).catch(n=>{throw new br(String(n))});try{return Ot.sign(e.digest,r).toDERRawBytes()}catch(n){throw new br(String(n))}}function Ja(r,t,e){let n=Ye.digest(e instanceof Uint8Array?e:e.subarray());if(Jo(n))return n.then(({digest:s})=>Ot.verify(t,s,r)).catch(s=>{throw new wr(String(s))});try{return Ot.verify(t,n.digest,r)}catch(s){throw new wr(String(s))}}var Un=class{type="secp256k1";raw;_key;constructor(t){this._key=Qa(t),this.raw=Ya(this._key)}toMultihash(){return ke.digest(Qe(this))}toCID(){return It.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Ja(this._key,e,t)}},Ln=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Xa(t),this.publicKey=new Un(e??tc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t){return Za(this.raw,t)}};function Yo(r){return new Ln(r)}function Ya(r){return Ot.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Xa(r){try{return Ot.getPublicKey(r,!0),r}catch(t){throw new xr(String(t))}}function Qa(r){try{return Ot.ProjectivePoint.fromHex(r),r}catch(t){throw new qe(String(t))}}function tc(r){try{return Ot.getPublicKey(r,!0)}catch(t){throw new xr(String(t))}}function Qe(r){return be.encode({Type:rt[r.type],Data:r.raw})}function ec(r){let t=Or.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return jo(e);case rt.Ed25519:return Ao(e);case rt.secp256k1:return Yo(e);case rt.ECDSA:return Wi(e);default:throw new je}}function rc(r){if(r.byteLength===Dt)return Ao(r);if(r.byteLength===Wa)return Yo(r);let t=Tt(r),e=t[2]?.[0];if(e===qi||e===ji||e===$i)return so(t);if(t.length>8)return Nn(t);throw new L("Could not extract private key from raw bytes")}function Ve(r){return Or.encode({Type:rt[r.type],Data:r.raw})}function nc(r,t,e,n){ln(r);let s=ea({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(tr(o),tr(i),tr(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=ae(t),f=ae(e),l=new Uint8Array(i),u=Pr.create(r,c),h=u._cloneInto().update(f);return{c:o,dkLen:i,asyncTick:a,DK:l,PRF:u,PRFSalt:h}}function sc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}function oc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=nc(r,t,e,n),f,l=new Uint8Array(4),u=Ne(l),h=new Uint8Array(a.outputLen);for(let y=1,b=0;b<o;y++,b+=a.outputLen){let m=i.subarray(b,b+a.outputLen);u.setInt32(0,y,!1),(f=c._cloneInto(f)).update(l).digestInto(h),m.set(h.subarray(0,m.length));for(let d=1;d<s;d++){a._cloneInto(f).update(h).digestInto(h);for(let w=0;w<m.length;w++)m[w]^=h[w]}}return sc(a,c,i,f,h)}async function Rn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=nc(r,t,e,n),l,u=new Uint8Array(4),h=Ne(u),y=new Uint8Array(c.outputLen);for(let b=1,m=0;m<o;b++,m+=c.outputLen){let d=a.subarray(m,m+c.outputLen);h.setInt32(0,b,!1),(l=f._cloneInto(l)).update(u).digestInto(y),d.set(y.subarray(0,d.length)),await Qi(s-1,i,()=>{c._cloneInto(l).update(y).digestInto(y);for(let w=0;w<d.length;w++)d[w]^=y[w]})}return sc(c,f,a,l,y)}var Mr=new Uint32Array([1732584193,4023233417,2562383102,271733878,3285377520]),Be=new Uint32Array(80),Xo=class extends ce{constructor(){super(64,20,8,!1),this.A=Mr[0]|0,this.B=Mr[1]|0,this.C=Mr[2]|0,this.D=Mr[3]|0,this.E=Mr[4]|0}get(){let{A:t,B:e,C:n,D:s,E:o}=this;return[t,e,n,s,o]}set(t,e,n,s,o){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0}process(t,e){for(let c=0;c<16;c++,e+=4)Be[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Be[c]=un(Be[c-3]^Be[c-8]^Be[c-14]^Be[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let f,l;c<20?(f=fn(s,o,i),l=1518500249):c<40?(f=s^o^i,l=1859775393):c<60?(f=hn(s,o,i),l=2400959708):(f=s^o^i,l=3395469782);let u=un(n,5)+f+a+l+Be[c]|0;a=i,i=o,o=un(s,30),s=n,n=u}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,this.set(n,s,o,i,a)}roundClean(){Be.fill(0)}destroy(){this.set(0,0,0,0,0),this.buffer.fill(0)}},ic=sr(()=>new Xo);var ac={sha1:ic,"sha2-256":ve,"sha2-512":fe};function Fr(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(ac).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=ac[s],i=oc(o,r,t,{c:e,dkLen:n});return Ie.encode(i).substring(1)}var Xt="/",cc=new TextEncoder().encode(Xt),_n=cc[0],qr=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=H(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]!==_n)throw new Error("Invalid key")}toString(t="utf8"){return j(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Xt))}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=cc),this._buf[0]!==_n){let t=new Uint8Array(this._buf.byteLength+1);t.fill(_n,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===_n;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(Xt).slice(1)}type(){return Th(this.baseNamespace())}name(){return Uh(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Xt)||(t+=Xt),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Xt):new r(t.slice(0,-1).join(Xt))}child(t){return this.toString()===Xt?t:t.toString()===Xt?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(),...Lh(t.map(e=>e.namespaces()))])}};function Th(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Uh(r){let t=r.split(":");return t[t.length-1]}function Lh(r){return[].concat(...r)}var mc=Us(yc(),1),bc=mc.default;var wl=Us(Ic(),1);var hr={};ut(hr,{create:()=>Jh,derivedEmptyPasswordKey:()=>On});var On={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jh(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=wt.get();e*=8;async function c(u,h){let y=a.getRandomValues(new Uint8Array(o)),b=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:b};typeof h=="string"&&(h=H(h));let d;if(h.length===0){d=await a.subtle.importKey("jwk",On,{name:"AES-GCM"},!0,["encrypt"]);try{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",On,{name:"AES-GCM"},!0,["encrypt"])}}else{let B={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},p=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(B,p,{name:t,length:e},!0,["encrypt"])}let w=await a.subtle.encrypt(m,d,u);return Je([y,m.iv,new Uint8Array(w)])}async function f(u,h){let y=u.subarray(0,o),b=u.subarray(o,o+n),m=u.subarray(o+n),d={name:t,iv:b};typeof h=="string"&&(h=H(h));let w;if(h.length===0)try{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",On,{name:"AES-GCM"},!0,["decrypt"])}else{let p={name:"PBKDF2",salt:y,iterations:i,hash:{name:s}},S=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(p,S,{name:t,length:e},!0,["decrypt"])}let B=await a.subtle.decrypt(d,w,m);return new Uint8Array(B)}return{encrypt:c,decrypt:f}}var M=Us(Cc());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 Ee(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let f=new Uint8Array(c);for(let l=a-1;l>=0;l--){let u=Math.pow(2,l*t);f[o-l-1]=Math.floor(s/u),s-=f[o-l-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Pn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function ei(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=He(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,He(o,8)-n}function Nc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=Ee(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ee(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Tc(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 i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Jm=Math.log(2);function Mn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ri(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function se(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var $r=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ri(this.items)}},jr=[new Uint8Array([1])],Uc="0123456789";var pr="",Vt=new ArrayBuffer(0),ni=new Uint8Array(0),Gr="EndOfContent",Rc="OCTET STRING",_c="BIT STRING";function oe(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?M.BufferSourceConverter.toUint8Array(o.valueHex):ni}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!se(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Vt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:M.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var te=class{constructor({blockLength:t=0,error:e=pr,warnings:n=[],valueBeforeDecode:s=ni}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=M.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:M.Convert.ToHex(this.valueBeforeDecodeView)}}};te.NAME="baseBlock";var ht=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'")}};ht.NAME="valueBlock";var Fn=class extends oe(te){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?M.BufferSourceConverter.toUint8Array(t.valueHex):ni,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Vt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=Ee(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),l=255;for(;o[c]&128;){if(f[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let y=0;y<f.length;y++)h[y]=f[y];f=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,f[c-1]=o[c]&127;let u=new Uint8Array(c);for(let h=0;h<c;h++)u[h]=f[h];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}}};Fn.NAME="identificationBlock";var qn=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=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=He(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=Ee(this.length,8);if(s.byteLength>127)return this.error="Too big length",Vt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};qn.NAME="lengthBlock";var A={},at=class extends te{constructor({name:t=pr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Fn(s),this.lenBlock=new qn(s),this.valueBlock=o?new o(s):new ht(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 $r;e||Dc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Vt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():M.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Tc(e,n)}};at.NAME="BaseBlock";function Dc(r){if(r instanceof A.Constructed)for(let t of r.valueBlock.value)Dc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var jn=class extends at{constructor({value:t=pr,...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}'`}};jn.NAME="BaseStringBlock";var $n=class extends oe(ht){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};$n.NAME="PrimitiveValueBlock";var Kc,Gn=class extends at{constructor(t={}){super(t,$n),this.idBlock.isConstructed=!1}};Kc=Gn;A.Primitive=Kc;Gn.NAME="PRIMITIVE";function od(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 ks(r,t=0,e=r.length){let n=t,s=new at({},ht),o=new te;if(!se(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=at;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=A.EndOfContent;break;case 1:c=A.Boolean;break;case 2:c=A.Integer;break;case 3:c=A.BitString;break;case 4:c=A.OctetString;break;case 5:c=A.Null;break;case 6:c=A.ObjectIdentifier;break;case 10:c=A.Enumerated;break;case 12:c=A.Utf8String;break;case 13:c=A.RelativeObjectIdentifier;break;case 14:c=A.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=A.Sequence;break;case 17:c=A.Set;break;case 18:c=A.NumericString;break;case 19:c=A.PrintableString;break;case 20:c=A.TeletexString;break;case 21:c=A.VideotexString;break;case 22:c=A.IA5String;break;case 23:c=A.UTCTime;break;case 24:c=A.GeneralizedTime;break;case 25:c=A.GraphicString;break;case 26:c=A.VisibleString;break;case 27:c=A.GeneralString;break;case 28:c=A.UniversalString;break;case 29:c=A.CharacterString;break;case 30:c=A.BmpString;break;case 31:c=A.DATE;break;case 32:c=A.TimeOfDay;break;case 33:c=A.DateTime;break;case 34:c=A.Duration;break;default:{let f=s.idBlock.isConstructed?new A.Constructed:new A.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?A.Constructed:A.Primitive}return s=od(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 Is(r){if(!r.byteLength){let t=new at({},ht);return t.error="Input buffer has zero length",{offset:-1,result:t}}return ks(M.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function id(r,t){return r?1:t}var Mt=class extends ht{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;id(this.isIndefiniteForm,n)>0;){let i=ks(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Gr)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Gr?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new $r;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Vt: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 Oc,Ae=class extends at{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} :`}};bc=Be;A.Constructed=bc;Be.NAME="CONSTRUCTED";var Fn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Vt}};Fn.override="EndOfContentValueBlock";var wc,qn=class extends at{constructor(t={}){super(t,Fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};wc=qn;A.EndOfContent=wc;qn.NAME=Mr;var xc,He=class extends at{constructor(t={}){super(t,ht),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}`}};xc=He;A.Null=xc;He.NAME="NULL";var jn=class extends ne(ht){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return re(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,Fo.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};jn.NAME="BooleanValueBlock";var vc,$n=class extends at{constructor(t={}){super(t,jn),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}`}};vc=$n;A.Boolean=vc;$n.NAME="BOOLEAN";var zn=class extends ne(Dt){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=Dt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Mr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==pc)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?Dt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};zn.NAME="OctetStringValueBlock";var Bc,Qt=class r extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=vs(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Be.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};Bc=Qt;A.OctetString=Bc;Qt.NAME=pc;var Gn=class extends ne(Dt){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=Dt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Mr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==gc)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 o=M.BufferSourceConverter.toUint8Array(t);if(!re(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=vs(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Dt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Vt;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}}};Gn.NAME="BitStringValueBlock";var Ec,Zn=class extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Gn),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Be.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Ec=Zn;A.BitString=Ec;Zn.NAME=gc;var Ac;function Rh(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=On(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=On(e,o)),o}function dc(r){if(r>=Dr.length)for(let t=Dr.length;t<=r;t++){let e=new Uint8Array([0]),n=Dr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=On(e,n)),Dr.push(n)}return Dr[r]}function Vh(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var Pr=class extends ne(ht){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=Fo.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(uc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=Vh(dc(n),e),i="-";break;default:e=Rh(e,dc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=hc.charAt(e[c]));return a===!1&&(i+=hc.charAt(0)),i}};Ac=Pr;Pr.NAME="IntegerValueBlock";Object.defineProperty(Ac.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Sc,te=class r extends at{constructor(t={}){super(t,Pr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Hn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Hn();let e=BigInt(t),n=new Kr,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Sc=te;A.Integer=Sc;te.NAME="INTEGER";var kc,Wn=class extends te{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};kc=Wn;A.Enumerated=kc;Wn.NAME="ENUMERATED";var Fr=class extends ne(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Oe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Hn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ve(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Fr.NAME="sidBlock";var Jn=class extends ht{constructor({value:t=cr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Fr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Vt;e.push(s)}return qo(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new Fr;if(s>Number.MAX_SAFE_INTEGER){Hn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Jn.NAME="ObjectIdentifierValueBlock";var Ic,Kt=class extends at{constructor(t={}){super(t,Jn),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()}}};Ic=Kt;A.ObjectIdentifier=Ic;Kt.NAME="OBJECT IDENTIFIER";var qr=class extends ne(Xt){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!re(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Oe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=ve(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};qr.NAME="relativeSidBlock";var Yn=class extends ht{constructor({value:t=cr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new qr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Vt;n.push(o)}return qo(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new qr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Yn.NAME="RelativeObjectIdentifierValueBlock";var Nc,Xn=class extends at{constructor(t={}){super(t,Yn),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()}}};Nc=Xn;A.RelativeObjectIdentifier=Nc;Xn.NAME="RelativeObjectIdentifier";var Cc,vt=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Cc=vt;A.Sequence=Cc;vt.NAME="SEQUENCE";var Uc,Qn=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Uc=Qn;A.Set=Uc;Qn.NAME="SET";var ts=class extends ne(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=cr}toJSON(){return{...super.toJSON(),value:this.value}}};ts.NAME="StringValueBlock";var es=class extends ts{};es.NAME="SimpleStringValueBlock";var gt=class extends Kn{constructor({...t}={}){super(t,es)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};gt.NAME="SIMPLE STRING";var rs=class extends gt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};rs.NAME="Utf8StringValueBlock";var Tc,ee=class extends rs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Tc=ee;A.Utf8String=Tc;ee.NAME="UTF8String";var ns=class extends gt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};ns.NAME="BmpStringValueBlock";var Lc,ss=class extends ns{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Lc=ss;A.BmpString=Lc;ss.NAME="BMPString";var os=class extends gt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=ve(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};os.NAME="UniversalStringValueBlock";var Rc,is=class extends os{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Rc=is;A.UniversalString=Rc;is.NAME="UniversalString";var Vc,as=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Vc=as;A.NumericString=Vc;as.NAME="NumericString";var Oc,cs=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Oc=cs;A.PrintableString=Oc;cs.NAME="PrintableString";var Hc,ls=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Hc=ls;A.TeletexString=Hc;ls.NAME="TeletexString";var _c,us=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};_c=us;A.VideotexString=_c;us.NAME="VideotexString";var Dc,fs=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Dc=fs;A.IA5String=Dc;fs.NAME="IA5String";var Kc,hs=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Kc=hs;A.GraphicString=Kc;hs.NAME="GraphicString";var Mc,jr=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Mc=jr;A.VisibleString=Mc;jr.NAME="VisibleString";var Pc,ds=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Pc=ds;A.GeneralString=Pc;ds.NAME="GeneralString";var Fc,ps=class extends gt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Fc=ps;A.CharacterString=Fc;ps.NAME="CharacterString";var qc,$r=class extends jr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=xt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=xt(this.month,2),e[2]=xt(this.day,2),e[3]=xt(this.hour,2),e[4]=xt(this.minute,2),e[5]=xt(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}}};qc=$r;A.UTCTime=qc;$r.NAME="UTCTime";var jc,gs=class extends $r{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let 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,h=n.indexOf("+"),m="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(m=n.substring(h+1),n=n.substring(0,h),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let b=parseInt(m.substring(0,2),10);if(isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*b,m.length===4){if(b=parseInt(m.substring(2,4),10),isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");c=u*b}}}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");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;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(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let 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(xt(this.year,4)),e.push(xt(this.month,2)),e.push(xt(this.day,2)),e.push(xt(this.hour,2)),e.push(xt(this.minute,2)),e.push(xt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(xt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};jc=gs;A.GeneralizedTime=jc;gs.NAME="GeneralizedTime";var $c,ms=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};$c=ms;A.DATE=$c;ms.NAME="DATE";var zc,ys=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};zc=ys;A.TimeOfDay=zc;ys.NAME="TimeOfDay";var Gc,bs=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Gc=bs;A.DateTime=Gc;bs.NAME="DateTime";var Zc,ws=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Zc=ws;A.Duration=Zc;ws.NAME="Duration";var Wc,xs=class extends ee{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Wc=xs;A.TIME=Wc;xs.NAME="TIME";async function $o(r,t){let n=await ir.create().encrypt(r,t);return Le.encode(n)}async function zo(r,t,e){if(r.type==="RSA")return _h(r,t,e);if(r.type==="Ed25519")return Oh(r,t,e);if(r.type==="secp256k1")return Hh(r,t,e);throw new Me}async function Oh(r,t,e="libp2p-key"){if(e==="libp2p-key")return $o(nr(r),t);throw new O(`export format '${e}' is not supported`)}async function Hh(r,t,e="libp2p-key"){if(e==="libp2p-key")return $o(nr(r),t);throw new O("Export format is not supported")}async function _h(r,t,e="pkcs-8"){if(e==="pkcs-8")return Dh(r,t);if(e==="libp2p-key")return $o(nr(r),t);throw new O("Export format is not supported")}async function Dh(r,t){let e=yt.get(),s=new vt({value:[new te({value:0}),new vt({value:[new Kt({value:"1.2.840.113549.1.1.1"}),new He]}),new Qt({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Ve(16),a=await Nn(le,t,i,{c:1e4,dkLen:32}),c=Ve(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new vt({value:[new Qt({valueHex:i}),new te({value:1e4}),new te({value:32}),new vt({value:[new Kt({value:"1.2.840.113549.2.11"}),new He]})]}),h=new vt({value:[new Kt({value:"1.2.840.113549.1.5.13"}),new vt({value:[new vt({value:[new Kt({value:"1.2.840.113549.1.5.12"}),u]}),new vt({value:[new Kt({value:"2.16.840.1.101.3.4.1.42"}),new Qt({valueHex:c})]})]})]}),b=new vt({value:[h,new Qt({valueHex:l})]}).toBER(),y=new Uint8Array(b,0,b.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...Y(y,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function
|
|
6
|
+
`)}`:`${e} :`}};Oc=Ae;A.Constructed=Oc;Ae.NAME="CONSTRUCTED";var zn=class extends ht{fromBER(t,e,n){return e}toBER(t){return Vt}};zn.override="EndOfContentValueBlock";var Vc,Wn=class extends at{constructor(t={}){super(t,zn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Vc=Wn;A.EndOfContent=Vc;Wn.NAME=Gr;var Hc,Pe=class extends at{constructor(t={}){super(t,ht),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}`}};Hc=Pe;A.Null=Hc;Pe.NAME="NULL";var Zn=class extends oe(ht){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=M.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=M.BufferSourceConverter.toUint8Array(t);return se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,ei.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Zn.NAME="BooleanValueBlock";var Pc,Jn=class extends at{constructor(t={}){super(t,Zn),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}`}};Pc=Jn;A.Boolean=Pc;Jn.NAME="BOOLEAN";var Yn=class extends oe(Mt){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===Gr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Rc)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}}};Yn.NAME="OctetStringValueBlock";var Mc,ee=class r extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Yn),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=ks(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ae.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${M.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return M.BufferSourceConverter.concat(t)}};Mc=ee;A.OctetString=Mc;ee.NAME=Rc;var Xn=class extends oe(Mt){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=Mt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===Gr){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==_c)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 o=M.BufferSourceConverter.toUint8Array(t);if(!se(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=ks(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Mt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Vt;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}}};Xn.NAME="BitStringValueBlock";var Fc,Qn=class extends at{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Xn),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 Ae.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)}`}}};Fc=Qn;A.BitString=Fc;Qn.NAME=_c;var qc;function ad(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f=0,l=c<i?i:c,u=0;for(let h=l;h>=0;h--,u++){switch(!0){case u<a.length:f=o[i-u]+a[c-u]+e[0];break;default:f=o[i-u]+e[0]}switch(e[0]=f/10,!0){case u>=o.length:o=Pn(new Uint8Array([f%10]),o);break;default:o[i-u]=f%10}}return e[0]>0&&(o=Pn(e,o)),o}function Lc(r){if(r>=jr.length)for(let t=jr.length;t<=r;t++){let e=new Uint8Array([0]),n=jr[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Pn(e,n)),jr.push(n)}return jr[r]}function cd(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,f,l=0;for(let u=c;u>=0;u--,l++)switch(f=o[i-l]-a[c-l]-e,!0){case f<0:e=1,o[i-l]=f+10;break;default:e=0,o[i-l]=f}if(e>0)for(let u=i-c+1;u>=0;u--,l++)if(f=o[i-l]-e,f<0)e=1,o[i-l]=f+10;else{e=0,o[i-l]=f;break}return o.slice()}var zr=class extends oe(ht){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=ei.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Nc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&(i[1]&128)!==0?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let f=0;f<8;f++){if((s&1)===1)switch(n){case t:e=cd(Lc(n),e),i="-";break;default:e=ad(e,Lc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Uc.charAt(e[c]));return a===!1&&(i+=Uc.charAt(0)),i}};qc=zr;zr.NAME="IntegerValueBlock";Object.defineProperty(qc.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var jc,re=class r extends at{constructor(t={}){super(t,zr),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Mn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Mn();let e=BigInt(t),n=new $r,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(M.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${M.Convert.ToHex(a)}`)+e,l=M.BufferSourceConverter.toUint8Array(M.Convert.FromHex(f.toString(16)));l[0]|=128,n.write(l)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};jc=re;A.Integer=jc;re.NAME="INTEGER";var $c,ts=class extends re{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};$c=ts;A.Enumerated=$c;ts.NAME="ENUMERATED";var Wr=class extends oe(ht){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Mn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Ee(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=M.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Wr.NAME="sidBlock";var es=class extends ht{constructor({value:t=pr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Wr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Vt;e.push(s)}return ri(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new Wr;if(s>Number.MAX_SAFE_INTEGER){Mn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};es.NAME="ObjectIdentifierValueBlock";var Gc,Ft=class extends at{constructor(t={}){super(t,es),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()}}};Gc=Ft;A.ObjectIdentifier=Gc;Ft.NAME="OBJECT IDENTIFIER";var Zr=class extends oe(te){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=M.BufferSourceConverter.toUint8Array(t);if(!se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,(o[a]&128)!==0);a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,(o[this.blockLength-1]&128)!==0?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=He(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Ee(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Vt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=M.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Zr.NAME="relativeSidBlock";var rs=class extends ht{constructor({value:t=pr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new Zr;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Vt;n.push(o)}return ri(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new Zr;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};rs.NAME="RelativeObjectIdentifierValueBlock";var zc,ns=class extends at{constructor(t={}){super(t,rs),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()}}};zc=ns;A.RelativeObjectIdentifier=zc;ns.NAME="RelativeObjectIdentifier";var Wc,At=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Wc=At;A.Sequence=Wc;At.NAME="SEQUENCE";var Zc,ss=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Zc=ss;A.Set=Zc;ss.NAME="SET";var os=class extends oe(ht){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=pr}toJSON(){return{...super.toJSON(),value:this.value}}};os.NAME="StringValueBlock";var is=class extends os{};is.NAME="SimpleStringValueBlock";var mt=class extends jn{constructor({...t}={}){super(t,is)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};mt.NAME="SIMPLE STRING";var as=class extends mt{fromBuffer(t){this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=M.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=M.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf8String(t)),this.valueBlock.value=t}};as.NAME="Utf8StringValueBlock";var Jc,ne=class extends as{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Jc=ne;A.Utf8String=Jc;ne.NAME="UTF8String";var cs=class extends mt{fromBuffer(t){this.valueBlock.value=M.Convert.ToUtf16String(t),this.valueBlock.valueHexView=M.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(M.Convert.FromUtf16String(t))}};cs.NAME="BmpStringValueBlock";var Yc,ls=class extends cs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Yc=ls;A.BmpString=Yc;ls.NAME="BMPString";var us=class extends mt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=Ee(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};us.NAME="UniversalStringValueBlock";var Xc,fs=class extends us{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Xc=fs;A.UniversalString=Xc;fs.NAME="UniversalString";var Qc,hs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Qc=hs;A.NumericString=Qc;hs.NAME="NumericString";var tl,ds=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};tl=ds;A.PrintableString=tl;ds.NAME="PrintableString";var el,ps=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};el=ps;A.TeletexString=el;ps.NAME="TeletexString";var rl,gs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};rl=gs;A.VideotexString=rl;gs.NAME="VideotexString";var nl,ys=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};nl=ys;A.IA5String=nl;ys.NAME="IA5String";var sl,ms=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};sl=ms;A.GraphicString=sl;ms.NAME="GraphicString";var ol,Jr=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ol=Jr;A.VisibleString=ol;Jr.NAME="VisibleString";var il,bs=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};il=bs;A.GeneralString=il;bs.NAME="GeneralString";var al,ws=class extends mt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};al=ws;A.CharacterString=al;ws.NAME="CharacterString";var cl,Yr=class extends Jr{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,M.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=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}}};cl=Yr;A.UTCTime=cl;Yr.NAME="UTCTime";var ll,xs=class extends Yr{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let 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,h=n.indexOf("+"),y="";if(h===-1&&(h=n.indexOf("-"),u=-1),h!==-1){if(y=n.substring(h+1),n=n.substring(0,h),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let b=parseInt(y.substring(0,2),10);if(isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*b,y.length===4){if(b=parseInt(y.substring(2,4),10),isNaN(b.valueOf()))throw new Error("Wrong input string for conversion");c=u*b}}}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");o=u.valueOf(),s=n.substring(0,f)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;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(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(s);if(l===null)throw new Error("Wrong input string for conversion");for(let 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}}};ll=xs;A.GeneralizedTime=ll;xs.NAME="GeneralizedTime";var ul,vs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ul=vs;A.DATE=ul;vs.NAME="DATE";var fl,Bs=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};fl=Bs;A.TimeOfDay=fl;Bs.NAME="TimeOfDay";var hl,Es=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};hl=Es;A.DateTime=hl;Es.NAME="DateTime";var dl,As=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};dl=As;A.Duration=dl;As.NAME="Duration";var pl,Ss=class extends ne{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};pl=Ss;A.TIME=pl;Ss.NAME="TIME";async function Cs(r,t){let n=await hr.create().encrypt(r,t);return Ie.encode(n)}async function si(r,t,e){if(r.type==="RSA")return hd(r,t,e);if(r.type==="Ed25519")return ld(r,t,e);if(r.type==="secp256k1")return ud(r,t,e);if(r.type==="ECDSA")return fd(r,t,e);throw new je}async function ld(r,t,e="libp2p-key"){if(e==="libp2p-key")return Cs(Ve(r),t);throw new L(`export format '${e}' is not supported`)}async function ud(r,t,e="libp2p-key"){if(e==="libp2p-key")return Cs(Ve(r),t);throw new L("Export format is not supported")}async function fd(r,t,e="libp2p-key"){if(e==="libp2p-key")return Cs(Ve(r),t);throw new L(`export format '${e}' is not supported`)}async function hd(r,t,e="pkcs-8"){if(e==="pkcs-8")return dd(r,t);if(e==="libp2p-key")return Cs(Ve(r),t);throw new L("Export format is not supported")}async function dd(r,t){let e=wt.get(),s=new At({value:[new re({value:0}),new At({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Pe]}),new ee({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=Oe(16),a=await Rn(fe,t,i,{c:1e4,dkLen:32}),c=Oe(16),f=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},f,o),u=new At({value:[new ee({valueHex:i}),new re({value:1e4}),new re({value:32}),new At({value:[new Ft({value:"1.2.840.113549.2.11"}),new Pe]})]}),h=new At({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new At({value:[new At({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new At({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new ee({valueHex:c})]})]})]}),b=new At({value:[h,new ee({valueHex:l})]}).toBER(),m=new Uint8Array(b,0,b.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function oi(r,t){try{let e=await pd(r,t);return ec(e)}catch{}if(!r.includes("BEGIN"))throw new L("Encrypted key was not a libp2p-key or a PEM file");return gd(r,t)}async function pd(r,t){let e=Ie.decode(r);return hr.create().decrypt(e,t)}async function gd(r,t){let e=wt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=H(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Is(o),{iv:a,salt:c,iterations:f,keySize:l,cipherText:u}=yd(i),h=await Rn(fe,t,c,{c:f,dkLen:l}),y=await e.subtle.importKey("raw",h,"AES-CBC",!1,["decrypt"]),b=Xr(await e.subtle.decrypt({name:"AES-CBC",iv:a},y,u)),{result:m}=Is(b);n=bl(m)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=H(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Is(o);n=bl(i)}else throw new L("Could not parse private key from PEM data");let s=rc(n);if(s.type!=="RSA")throw new L("Could not parse RSA private key from PEM data");return s}function yd(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new L("Only pkcs5PBES2 encrypted private keys are supported");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new L("Only pkcs5PBKDF2 key derivation functions are supported");let o=n.valueBlock.value[1],i=Xr(o.valueBlock.value[0].getValue()),a=1e4,c=32;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new L("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key");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 L("Only AES-CBC encryption schemes are supported")}}}}let u=Xr(f.valueBlock.value[1].getValue());return{cipherText:Xr(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function bl(r){return Xr(r.valueBlock.value[2].getValue())}function Xr(r){return new Uint8Array(r,0,r.byteLength)}var md="/pkcs8/",ai="/info/",Qr=new WeakMap,Me={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3},ii={dek:{keyLength:512/8,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"}};function gr(r){return r==null||typeof r!="string"?!1:r===(0,wl.default)(r.trim())&&r.length>0}async function ct(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function Fe(r){return new qr(md+r)}function yr(r){return new qr(ai+r)}async function bd(r){let t=Ve(r),e=await Ye.digest(t);return Q.encode(e.bytes).substring(1)}var Ns=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init=bc(ii,e),this.self=e.selfKey??"self",this.init.pass!=null&&this.init.pass?.length<20)throw new Error("pass must be least 20 characters");if(this.init.dek?.keyLength!=null&&this.init.dek.keyLength<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?Fr(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Qr.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[mi]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},ii),e=Math.ceil(Me.minSaltLength/3)*3;return t.dek.salt=j(Oe(e),"base64"),t}static get options(){return ii}async findKeyByName(t){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);let e=yr(t);try{let n=await this.components.datastore.get(e);return JSON.parse(j(n))}catch(n){throw await ct(),this.log.error(n),new rn(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:ai};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(j(n.value));if(s.id===t)return s}throw new L(`Key with id '${t}' does not exist.`)}catch(e){throw await ct(),e}}async importKey(t,e){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);if(e==null)throw await ct(),new L("Key is required");let n=Fe(t);if(await this.components.datastore.has(n))throw await ct(),new L(`Key '${t}' already exists`);let o,i;try{o=await bd(e);let f=Qr.get(this);if(f==null)throw new L("dek missing");let l=f.dek;i=await si(e,l,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(f){throw await ct(),f}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,H(i)),c.put(yr(t),H(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!gr(t))throw await ct(),new L(`Invalid key name '${t}'`);let e=Fe(t);try{let n=await this.components.datastore.get(e),s=j(n),o=Qr.get(this);if(o==null)throw new L("dek missing");let i=o.dek;return await oi(s,i)}catch(n){throw await ct(),n}}async removeKey(t){if(!gr(t)||t===this.self)throw await ct(),new L(`Invalid key name '${t}'`);let e=Fe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(yr(t)),await s.commit(),n}async listKeys(){let t={prefix:ai},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(j(n.value)));return e}async renameKey(t,e){if(!gr(t)||t===this.self)throw await ct(),new L(`Invalid old key name '${t}'`);if(!gr(e)||e===this.self)throw await ct(),new L(`Invalid new key name '${e}'`);let n=Fe(t),s=Fe(e),o=yr(t),i=yr(e);if(await this.components.datastore.has(s))throw await ct(),new L(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),f=await this.components.datastore.get(o),l=JSON.parse(j(f));l.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,H(JSON.stringify(l))),u.delete(n),u.delete(o),await u.commit(),l}catch(c){throw await ct(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await ct(),new L(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await ct(),new L(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await ct(),new L(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=Qr.get(this);if(n==null)throw new L("dek missing");let s=n.dek;this.init.pass=e;let o=e!=null&&this.init.dek?.salt!=null?Fr(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";Qr.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(Fe(a.name)),f=j(c),l=await oi(f,s),u=o.toString(),h=await si(l,u,l.type==="RSA"?"pkcs-8":"libp2p-key"),y=this.components.datastore.batch(),b={name:a.name,id:a.id};y.put(Fe(a.name),H(h)),y.put(yr(a.name),H(JSON.stringify(b))),await y.commit()}this.log("keychain reconstructed")}};function wd(r={}){return t=>new Ns(t,r)}return Rl(xd);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Ed25519PrivateKey, PrivateKey, RSAPrivateKey, Secp256k1PrivateKey } from '@libp2p/interface';
|
|
1
|
+
import type { ECDSAPrivateKey, Ed25519PrivateKey, PrivateKey, RSAPrivateKey, Secp256k1PrivateKey } from '@libp2p/interface';
|
|
2
2
|
import type { Multibase } from 'multiformats/bases/interface';
|
|
3
3
|
/**
|
|
4
4
|
* Exports the given PrivateKey as a base64 encoded string.
|
|
@@ -21,6 +21,10 @@ export declare function exportEd25519PrivateKey(key: Ed25519PrivateKey, password
|
|
|
21
21
|
* Exports the key into a password protected `format`
|
|
22
22
|
*/
|
|
23
23
|
export declare function exportSecp256k1PrivateKey(key: Secp256k1PrivateKey, password: string, format?: ExportFormat): Promise<Multibase<'m'>>;
|
|
24
|
+
/**
|
|
25
|
+
* Exports the key into a password protected `format`
|
|
26
|
+
*/
|
|
27
|
+
export declare function exportECDSAPrivateKey(key: ECDSAPrivateKey, password: string, format?: ExportFormat): Promise<Multibase<'m'>>;
|
|
24
28
|
/**
|
|
25
29
|
* Exports the key as libp2p-key - a aes-gcm encrypted value with the key
|
|
26
30
|
* derived from the password.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../../src/utils/export.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,iBAAiB,EAAE,UAAU,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../../src/utils/export.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,eAAe,EAAE,iBAAiB,EAAE,UAAU,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAC3H,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAA;AAE7D;;;;GAIG;AACH,wBAAsB,QAAQ,CAAE,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAIjG;AAED,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,YAAY,CAAA;AAElD;;;;GAIG;AACH,wBAAsB,gBAAgB,CAAE,GAAG,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAkBzH;AAED;;GAEG;AACH,wBAAsB,uBAAuB,CAAE,GAAG,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,YAA2B,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAMrJ;AAED;;GAEG;AACH,wBAAsB,yBAAyB,CAAE,GAAG,EAAE,mBAAmB,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,YAA2B,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAMzJ;AAED;;GAEG;AACH,wBAAsB,qBAAqB,CAAE,GAAG,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,YAA2B,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAMjJ;AAED;;;;;;GAMG;AACH,wBAAsB,mBAAmB,CAAE,GAAG,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,YAAuB,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAQzI;AAED,wBAAsB,WAAW,CAAE,UAAU,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CA0H/F"}
|
package/dist/src/utils/export.js
CHANGED
|
@@ -34,6 +34,9 @@ export async function exportPrivateKey(key, password, format) {
|
|
|
34
34
|
if (key.type === 'secp256k1') {
|
|
35
35
|
return exportSecp256k1PrivateKey(key, password, format);
|
|
36
36
|
}
|
|
37
|
+
if (key.type === 'ECDSA') {
|
|
38
|
+
return exportECDSAPrivateKey(key, password, format);
|
|
39
|
+
}
|
|
37
40
|
throw new UnsupportedKeyTypeError();
|
|
38
41
|
}
|
|
39
42
|
/**
|
|
@@ -58,6 +61,17 @@ export async function exportSecp256k1PrivateKey(key, password, format = 'libp2p-
|
|
|
58
61
|
throw new InvalidParametersError('Export format is not supported');
|
|
59
62
|
}
|
|
60
63
|
}
|
|
64
|
+
/**
|
|
65
|
+
* Exports the key into a password protected `format`
|
|
66
|
+
*/
|
|
67
|
+
export async function exportECDSAPrivateKey(key, password, format = 'libp2p-key') {
|
|
68
|
+
if (format === 'libp2p-key') {
|
|
69
|
+
return exporter(privateKeyToProtobuf(key), password);
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
throw new InvalidParametersError(`export format '${format}' is not supported`);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
61
75
|
/**
|
|
62
76
|
* Exports the key as libp2p-key - a aes-gcm encrypted value with the key
|
|
63
77
|
* derived from the password.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../../src/utils/export.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAC1D,OAAO,SAAS,MAAM,0BAA0B,CAAA;AAChD,OAAO,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAA;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAA;AAC7C,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAA;AAClD,OAAO,EAAE,QAAQ,IAAI,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AACtE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAIlE;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAE,UAAsB,EAAE,QAAgB;IACtE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAA;IAC/B,MAAM,YAAY,GAAG,MAAM,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IAC/D,OAAO,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;AACpC,CAAC;AAID;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAE,GAAe,EAAE,QAAgB,EAAE,MAAqB;IAC9F,IAAI,GAAG,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;QACvB,OAAO,mBAAmB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACnD,CAAC;IAED,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC3B,OAAO,uBAAuB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACvD,CAAC;IAED,IAAI,GAAG,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;QAC7B,OAAO,yBAAyB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACzD,CAAC;IAED,MAAM,IAAI,uBAAuB,EAAE,CAAA;AACrC,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAE,GAAsB,EAAE,QAAgB,EAAE,SAAuB,YAAY;IAC1H,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QAC5B,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,kBAAkB,MAAM,oBAAoB,CAAC,CAAA;IAChF,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAAE,GAAwB,EAAE,QAAgB,EAAE,SAAuB,YAAY;IAC9H,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QAC5B,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,gCAAgC,CAAC,CAAA;IACpE,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAE,GAAkB,EAAE,QAAgB,EAAE,SAAuB,QAAQ;IAC9G,IAAI,MAAM,KAAK,QAAQ,EAAE,CAAC;QACxB,OAAO,WAAW,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;IACnC,CAAC;SAAM,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QACnC,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,gCAAgC,CAAC,CAAA;IACpE,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAE,UAAyB,EAAE,QAAgB;IAC5E,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,EAAE,CAAA;IAE9B,iBAAiB;IACjB,MAAM,UAAU,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QACrC,KAAK,EAAE;YACL,cAAc;YACd,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;YAEhC,sBAAsB;YACtB,IAAI,MAAM,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE;oBACP,oBAAoB;oBAClB,IAAI,MAAM,CAAC,gBAAgB,CAAC;wBAC1B,KAAK,EAAE,sBAAsB;qBAC9B,CAAC;oBACF,IAAI,MAAM,CAAC,IAAI,EAAE;iBAClB;aACF,CAAC;YAEF,aAAa;YACb,IAAI,MAAM,CAAC,WAAW,CAAC;gBACrB,QAAQ,EAAE,UAAU,CAAC,GAAG;aACzB,CAAC;SACH;KACF,CAAC,CAAA;IAEF,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,EAAE,CAAA;IACjC,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;IAC3D,MAAM,IAAI,GAAG,WAAW,CAAC,WAAW,CAAC,CAAA;IAErC,MAAM,aAAa,GAAG,MAAM,WAAW,CACrC,MAAM,EACN,QAAQ,EACR,IAAI,EAAE;QACJ,CAAC,EAAE,UAAU;QACb,KAAK,EAAE,QAAQ;KAChB,CACF,CAAA;IAED,MAAM,EAAE,GAAG,WAAW,CAAC,EAAE,CAAC,CAAA;IAC1B,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IACpG,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;QAC5C,IAAI,EAAE,SAAS;QACf,EAAE;KACH,EAAE,SAAS,EAAE,MAAM,CAAC,CAAA;IAErB,MAAM,YAAY,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QACvC,KAAK,EAAE;YACL,OAAO;YACP,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAE1C,kBAAkB;YAClB,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;YAEzC,aAAa;YACb,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;YAEvC,sBAAsB;YACtB,IAAI,MAAM,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE;oBACL,iBAAiB;oBACjB,IAAI,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,CAAC;oBAC7D,IAAI,MAAM,CAAC,IAAI,EAAE;iBAClB;aACF,CAAC;SACH;KACF,CAAC,CAAA;IAEF,MAAM,mBAAmB,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QAC9C,KAAK,EAAE;YACL,aAAa;YACb,IAAI,MAAM,CAAC,gBAAgB,CAAC;gBAC1B,KAAK,EAAE,uBAAuB;aAC/B,CAAC;YACF,IAAI,MAAM,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE;oBACL,oBAAoB;oBACpB,IAAI,MAAM,CAAC,QAAQ,CAAC;wBAClB,KAAK,EAAE;4BACL,cAAc;4BACd,IAAI,MAAM,CAAC,gBAAgB,CAAC;gCAC1B,KAAK,EAAE,uBAAuB;6BAC/B,CAAC;4BACF,gBAAgB;4BAChB,YAAY;yBACb;qBACF,CAAC;oBAEF,mBAAmB;oBACnB,IAAI,MAAM,CAAC,QAAQ,CAAC;wBAClB,KAAK,EAAE;4BACL,aAAa;4BACb,IAAI,MAAM,CAAC,gBAAgB,CAAC;gCAC1B,KAAK,EAAE,yBAAyB;6BACjC,CAAC;4BACF,KAAK;4BACL,IAAI,MAAM,CAAC,WAAW,CAAC;gCACrB,QAAQ,EAAE,EAAE;6BACb,CAAC;yBACH;qBACF,CAAC;iBACH;aACF,CAAC;SACH;KACF,CAAC,CAAA;IAEF,MAAM,YAAY,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QACvC,KAAK,EAAE;YACL,mBAAmB;YACnB,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;SAChD;KACF,CAAC,CAAA;IAEF,MAAM,eAAe,GAAG,YAAY,CAAC,KAAK,EAAE,CAAA;IAC5C,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,eAAe,EAAE,CAAC,EAAE,eAAe,CAAC,UAAU,CAAC,CAAA;IAEtF,OAAO;QACL,uCAAuC;QACvC,GAAG,kBAAkB,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;QACpF,qCAAqC;KACtC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACd,CAAC"}
|
|
1
|
+
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../../src/utils/export.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAC1D,OAAO,SAAS,MAAM,0BAA0B,CAAA;AAChD,OAAO,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAA;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAA;AAC7C,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAA;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAA;AAClD,OAAO,EAAE,QAAQ,IAAI,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AACtE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAIlE;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAE,UAAsB,EAAE,QAAgB;IACtE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAA;IAC/B,MAAM,YAAY,GAAG,MAAM,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IAC/D,OAAO,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;AACpC,CAAC;AAID;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAE,GAAe,EAAE,QAAgB,EAAE,MAAqB;IAC9F,IAAI,GAAG,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;QACvB,OAAO,mBAAmB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACnD,CAAC;IAED,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC3B,OAAO,uBAAuB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACvD,CAAC;IAED,IAAI,GAAG,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;QAC7B,OAAO,yBAAyB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACzD,CAAC;IAED,IAAI,GAAG,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;QACzB,OAAO,qBAAqB,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IACrD,CAAC;IAED,MAAM,IAAI,uBAAuB,EAAE,CAAA;AACrC,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAE,GAAsB,EAAE,QAAgB,EAAE,SAAuB,YAAY;IAC1H,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QAC5B,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,kBAAkB,MAAM,oBAAoB,CAAC,CAAA;IAChF,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,yBAAyB,CAAE,GAAwB,EAAE,QAAgB,EAAE,SAAuB,YAAY;IAC9H,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QAC5B,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,gCAAgC,CAAC,CAAA;IACpE,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAE,GAAoB,EAAE,QAAgB,EAAE,SAAuB,YAAY;IACtH,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QAC5B,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,kBAAkB,MAAM,oBAAoB,CAAC,CAAA;IAChF,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAE,GAAkB,EAAE,QAAgB,EAAE,SAAuB,QAAQ;IAC9G,IAAI,MAAM,KAAK,QAAQ,EAAE,CAAC;QACxB,OAAO,WAAW,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAA;IACnC,CAAC;SAAM,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;QACnC,OAAO,QAAQ,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAA;IACtD,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,sBAAsB,CAAC,gCAAgC,CAAC,CAAA;IACpE,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAAE,UAAyB,EAAE,QAAgB;IAC5E,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,EAAE,CAAA;IAE9B,iBAAiB;IACjB,MAAM,UAAU,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QACrC,KAAK,EAAE;YACL,cAAc;YACd,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;YAEhC,sBAAsB;YACtB,IAAI,MAAM,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE;oBACP,oBAAoB;oBAClB,IAAI,MAAM,CAAC,gBAAgB,CAAC;wBAC1B,KAAK,EAAE,sBAAsB;qBAC9B,CAAC;oBACF,IAAI,MAAM,CAAC,IAAI,EAAE;iBAClB;aACF,CAAC;YAEF,aAAa;YACb,IAAI,MAAM,CAAC,WAAW,CAAC;gBACrB,QAAQ,EAAE,UAAU,CAAC,GAAG;aACzB,CAAC;SACH;KACF,CAAC,CAAA;IAEF,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,EAAE,CAAA;IACjC,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;IAC3D,MAAM,IAAI,GAAG,WAAW,CAAC,WAAW,CAAC,CAAA;IAErC,MAAM,aAAa,GAAG,MAAM,WAAW,CACrC,MAAM,EACN,QAAQ,EACR,IAAI,EAAE;QACJ,CAAC,EAAE,UAAU;QACb,KAAK,EAAE,QAAQ;KAChB,CACF,CAAA;IAED,MAAM,EAAE,GAAG,WAAW,CAAC,EAAE,CAAC,CAAA;IAC1B,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IACpG,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;QAC5C,IAAI,EAAE,SAAS;QACf,EAAE;KACH,EAAE,SAAS,EAAE,MAAM,CAAC,CAAA;IAErB,MAAM,YAAY,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QACvC,KAAK,EAAE;YACL,OAAO;YACP,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAE1C,kBAAkB;YAClB,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;YAEzC,aAAa;YACb,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;YAEvC,sBAAsB;YACtB,IAAI,MAAM,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE;oBACL,iBAAiB;oBACjB,IAAI,MAAM,CAAC,gBAAgB,CAAC,EAAE,KAAK,EAAE,qBAAqB,EAAE,CAAC;oBAC7D,IAAI,MAAM,CAAC,IAAI,EAAE;iBAClB;aACF,CAAC;SACH;KACF,CAAC,CAAA;IAEF,MAAM,mBAAmB,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QAC9C,KAAK,EAAE;YACL,aAAa;YACb,IAAI,MAAM,CAAC,gBAAgB,CAAC;gBAC1B,KAAK,EAAE,uBAAuB;aAC/B,CAAC;YACF,IAAI,MAAM,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE;oBACL,oBAAoB;oBACpB,IAAI,MAAM,CAAC,QAAQ,CAAC;wBAClB,KAAK,EAAE;4BACL,cAAc;4BACd,IAAI,MAAM,CAAC,gBAAgB,CAAC;gCAC1B,KAAK,EAAE,uBAAuB;6BAC/B,CAAC;4BACF,gBAAgB;4BAChB,YAAY;yBACb;qBACF,CAAC;oBAEF,mBAAmB;oBACnB,IAAI,MAAM,CAAC,QAAQ,CAAC;wBAClB,KAAK,EAAE;4BACL,aAAa;4BACb,IAAI,MAAM,CAAC,gBAAgB,CAAC;gCAC1B,KAAK,EAAE,yBAAyB;6BACjC,CAAC;4BACF,KAAK;4BACL,IAAI,MAAM,CAAC,WAAW,CAAC;gCACrB,QAAQ,EAAE,EAAE;6BACb,CAAC;yBACH;qBACF,CAAC;iBACH;aACF,CAAC;SACH;KACF,CAAC,CAAA;IAEF,MAAM,YAAY,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC;QACvC,KAAK,EAAE;YACL,mBAAmB;YACnB,IAAI,MAAM,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;SAChD;KACF,CAAC,CAAA;IAEF,MAAM,eAAe,GAAG,YAAY,CAAC,KAAK,EAAE,CAAA;IAC5C,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,eAAe,EAAE,CAAC,EAAE,eAAe,CAAC,UAAU,CAAC,CAAA;IAEtF,OAAO;QACL,uCAAuC;QACvC,GAAG,kBAAkB,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;QACpF,qCAAqC;KACtC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACd,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/keychain",
|
|
3
|
-
"version": "5.1.
|
|
3
|
+
"version": "5.1.4-0b9090aea",
|
|
4
4
|
"description": "Key management and cryptographically protected messages",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/keychain#readme",
|
|
@@ -59,8 +59,8 @@
|
|
|
59
59
|
"test:electron-main": "aegir test -t electron-main"
|
|
60
60
|
},
|
|
61
61
|
"dependencies": {
|
|
62
|
-
"@libp2p/crypto": "
|
|
63
|
-
"@libp2p/interface": "
|
|
62
|
+
"@libp2p/crypto": "5.0.15-0b9090aea",
|
|
63
|
+
"@libp2p/interface": "2.7.0-0b9090aea",
|
|
64
64
|
"@noble/hashes": "^1.6.1",
|
|
65
65
|
"asn1js": "^3.0.5",
|
|
66
66
|
"interface-datastore": "^8.3.1",
|
|
@@ -70,7 +70,7 @@
|
|
|
70
70
|
"uint8arrays": "^5.1.0"
|
|
71
71
|
},
|
|
72
72
|
"devDependencies": {
|
|
73
|
-
"@libp2p/logger": "
|
|
73
|
+
"@libp2p/logger": "5.1.13-0b9090aea",
|
|
74
74
|
"aegir": "^45.1.1",
|
|
75
75
|
"datastore-core": "^10.0.2"
|
|
76
76
|
},
|
package/src/utils/export.ts
CHANGED
|
@@ -9,7 +9,7 @@ import * as asn1js from 'asn1js'
|
|
|
9
9
|
import { base64 } from 'multiformats/bases/base64'
|
|
10
10
|
import { toString as uint8ArrayToString } from 'uint8arrays/to-string'
|
|
11
11
|
import { ITERATIONS, KEY_SIZE, SALT_LENGTH } from './constants.js'
|
|
12
|
-
import type { Ed25519PrivateKey, PrivateKey, RSAPrivateKey, Secp256k1PrivateKey } from '@libp2p/interface'
|
|
12
|
+
import type { ECDSAPrivateKey, Ed25519PrivateKey, PrivateKey, RSAPrivateKey, Secp256k1PrivateKey } from '@libp2p/interface'
|
|
13
13
|
import type { Multibase } from 'multiformats/bases/interface'
|
|
14
14
|
|
|
15
15
|
/**
|
|
@@ -43,6 +43,10 @@ export async function exportPrivateKey (key: PrivateKey, password: string, forma
|
|
|
43
43
|
return exportSecp256k1PrivateKey(key, password, format)
|
|
44
44
|
}
|
|
45
45
|
|
|
46
|
+
if (key.type === 'ECDSA') {
|
|
47
|
+
return exportECDSAPrivateKey(key, password, format)
|
|
48
|
+
}
|
|
49
|
+
|
|
46
50
|
throw new UnsupportedKeyTypeError()
|
|
47
51
|
}
|
|
48
52
|
|
|
@@ -68,6 +72,17 @@ export async function exportSecp256k1PrivateKey (key: Secp256k1PrivateKey, passw
|
|
|
68
72
|
}
|
|
69
73
|
}
|
|
70
74
|
|
|
75
|
+
/**
|
|
76
|
+
* Exports the key into a password protected `format`
|
|
77
|
+
*/
|
|
78
|
+
export async function exportECDSAPrivateKey (key: ECDSAPrivateKey, password: string, format: ExportFormat = 'libp2p-key'): Promise<Multibase<'m'>> {
|
|
79
|
+
if (format === 'libp2p-key') {
|
|
80
|
+
return exporter(privateKeyToProtobuf(key), password)
|
|
81
|
+
} else {
|
|
82
|
+
throw new InvalidParametersError(`export format '${format}' is not supported`)
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
71
86
|
/**
|
|
72
87
|
* Exports the key as libp2p-key - a aes-gcm encrypted value with the key
|
|
73
88
|
* derived from the password.
|
package/dist/typedoc-urls.json
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
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
|
-
}
|