@libp2p/keychain 5.2.9-da78fa851 → 5.2.9-e8398d97e
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/index.min.js.map +4 -4
- package/dist/src/constants.d.ts +12 -0
- package/dist/src/constants.d.ts.map +1 -0
- package/dist/src/constants.js +12 -0
- package/dist/src/constants.js.map +1 -0
- package/dist/src/keychain.d.ts +1 -10
- package/dist/src/keychain.d.ts.map +1 -1
- package/dist/src/keychain.js +17 -14
- package/dist/src/keychain.js.map +1 -1
- package/package.json +4 -5
- package/src/constants.ts +11 -0
- package/src/keychain.ts +20 -16
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PKeychain = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PKeychain=(()=>{var Xu=Object.create;var wn=Object.defineProperty;var Qu=Object.getOwnPropertyDescriptor;var tl=Object.getOwnPropertyNames;var el=Object.getPrototypeOf,rl=Object.prototype.hasOwnProperty;var Ir=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ft=(r,t)=>{for(var e in t)wn(r,e,{get:t[e],enumerable:!0})},Ti=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of tl(t))!rl.call(r,s)&&s!==e&&wn(r,s,{get:()=>t[s],enumerable:!(n=Qu(t,s))||n.enumerable});return r};var _i=(r,t,e)=>(e=r!=null?Xu(el(r)):{},Ti(t||!r||!r.__esModule?wn(e,"default",{value:r,enumerable:!0}):e,r)),nl=r=>Ti(wn({},"__esModule",{value:!0}),r);var tu=Ir((lb,Qc)=>{"use strict";function Zh(r){return r>=55296&&r<=56319}function zh(r){return r>=56320&&r<=57343}Qc.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],Zh(i)&&zh(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 ru=Ir((fb,eu)=>{"use strict";function Yh(r){return r>=55296&&r<=56319}function Wh(r){return r>=56320&&r<=57343}eu.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),Wh(s)?o!=null&&Yh(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 su=Ir((hb,nu)=>{"use strict";var Jh=tu(),Xh=ru();nu.exports=Jh.bind(null,Xh)});var au=Ir((db,iu)=>{"use strict";var Qh=su(),td=/[\/\?<>\\:\*\|"]/g,ed=/[\x00-\x1f\x80-\x9f]/g,rd=/^\.+$/,nd=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,sd=/[\. ]+$/;function ou(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(td,t).replace(ed,t).replace(rd,t).replace(nd,t).replace(sd,t);return Qh(e,255)}iu.exports=function(r,t){var e=t&&t.replacement||"",n=ou(r,e);return e===""?n:ou(n,"")}});var cu=Ir(Br=>{"use strict";var id="[object ArrayBuffer]",se=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===id}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}},xi="string",ad=/^[0-9a-f\s]+$/i,cd=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,ud=/^[a-zA-Z0-9-_]+$/,ss=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=se.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Tt=class{static toString(t,e=!1){let n=se.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}},os=class r{static isHex(t){return typeof t===xi&&ad.test(t)}static isBase64(t){return typeof t===xi&&cd.test(t)}static isBase64Url(t){return typeof t===xi&&ud.test(t)}static ToString(t,e="utf8"){let n=se.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 Tt.toString(n,!0);case"utf16":case"utf16be":return Tt.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 Tt.fromString(t,!0);case"utf16":case"utf16be":return Tt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=se.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 ss.fromString(t);case"utf16":case"utf16be":return Tt.fromString(t);case"utf16le":case"usc2":return Tt.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 ss.toString(t);case"utf16":case"utf16be":return Tt.toString(t);case"utf16le":case"usc2":return Tt.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=se.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=se.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 Tt.toString(t,e)}static FromUtf16String(t,e=!1){return Tt.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,"")||""}};os.DEFAULT_UTF8_ENCODING="utf8";function ld(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 fd(...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 hd(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}Br.BufferSourceConverter=se;Br.Convert=os;Br.assign=ld;Br.combine=fd;Br.isEqual=hd});var Nd={};ft(Nd,{keychain:()=>Cd});var Cr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},Nr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},xn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Li={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new xn("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 Q=Li;var L=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},je=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},Ur=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var vn=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var $e=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ri=Symbol.for("@libp2p/service-capabilities"),Vd=Symbol.for("@libp2p/service-dependencies");var to={};ft(to,{base58btc:()=>tt,base58flickr:()=>ll});var l0=new Uint8Array(0);function Di(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function qt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Ki(r){return new TextEncoder().encode(r)}function Vi(r){return new TextDecoder().decode(r)}function sl(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),l=Math.log(a)/Math.log(256),h=Math.log(256)/Math.log(a);function u(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var w=0,E=0,y=0,A=p.length;y!==A&&p[y]===0;)y++,w++;for(var x=(A-y)*h+1>>>0,I=new Uint8Array(x);y!==A;){for(var D=p[y],P=0,O=x-1;(D!==0||P<E)&&O!==-1;O--,P++)D+=256*I[O]>>>0,I[O]=D%a>>>0,D=D/a>>>0;if(D!==0)throw new Error("Non-zero carry");E=P,y++}for(var K=x-E;K!==x&&I[K]===0;)K++;for(var v=c.repeat(w);K<x;++K)v+=r.charAt(I[K]);return v}function f(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var w=0;if(p[w]!==" "){for(var E=0,y=0;p[w]===c;)E++,w++;for(var A=(p.length-w)*l+1>>>0,x=new Uint8Array(A);p[w];){var I=e[p.charCodeAt(w)];if(I===255)return;for(var D=0,P=A-1;(I!==0||D<y)&&P!==-1;P--,D++)I+=a*x[P]>>>0,x[P]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");y=D,w++}if(p[w]!==" "){for(var O=A-y;O!==A&&x[O]===0;)O++;for(var K=new Uint8Array(E+(A-O)),v=E;O!==A;)K[v++]=x[O++];return K}}}function d(p){var w=f(p);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:f,decode:d}}var ol=sl,il=ol,Oi=il;var Ws=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Js=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 Pi(this,t)}},Xs=class{decoders;constructor(t){this.decoders=t}or(t){return Pi(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 Pi(r,t){return new Xs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Qs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Ws(t,e,n),this.decoder=new Js(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new Qs(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Oi(e,r);return Ge({prefix:t,name:r,encode:n,decode:o=>qt(s(o))})}function al(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,a=0,c=0;for(let l=0;l<s;++l){let h=t[r[l]];if(h===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|h,i+=e,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function cl(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 ul(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let s=ul(n);return Ge({prefix:t,name:r,encode(o){return cl(o,n,e)},decode(o){return al(o,s,e,r)}})}var tt=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ll=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var eo={};ft(eo,{base32:()=>Ze,base32hex:()=>pl,base32hexpad:()=>gl,base32hexpadupper:()=>ml,base32hexupper:()=>yl,base32pad:()=>hl,base32padupper:()=>dl,base32upper:()=>fl,base32z:()=>bl});var Ze=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),fl=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),hl=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),dl=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),pl=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),yl=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),gl=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ml=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),bl=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ro={};ft(ro,{base36:()=>Tr,base36upper:()=>wl});var Tr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),wl=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var xl=qi,Mi=128,vl=127,El=~vl,Bl=Math.pow(2,31);function qi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Bl;)t[e++]=r&255|Mi,r/=128;for(;r&El;)t[e++]=r&255|Mi,r>>>=7;return t[e]=r|0,qi.bytes=e-n+1,t}var Al=no,Sl=128,Fi=127;function no(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw no.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Fi)<<s:(i&Fi)*Math.pow(2,s),s+=7}while(i>=Sl);return no.bytes=o-n,e}var kl=Math.pow(2,7),Il=Math.pow(2,14),Cl=Math.pow(2,21),Nl=Math.pow(2,28),Ul=Math.pow(2,35),Tl=Math.pow(2,42),_l=Math.pow(2,49),Ll=Math.pow(2,56),Rl=Math.pow(2,63),Dl=function(r){return r<kl?1:r<Il?2:r<Cl?3:r<Nl?4:r<Ul?5:r<Tl?6:r<_l?7:r<Ll?8:r<Rl?9:10},Kl={encode:xl,decode:Al,encodingLength:Dl},Vl=Kl,_r=Vl;function Lr(r,t=0){return[_r.decode(r,t),_r.decode.bytes]}function ze(r,t,e=0){return _r.encode(r,t,e),t}function Ye(r){return _r.encodingLength(r)}function Vt(r,t){let e=t.byteLength,n=Ye(r),s=n+Ye(e),o=new Uint8Array(s+e);return ze(r,o,0),ze(e,o,n),o.set(t,s),new We(r,e,t,o)}function ji(r){let t=qt(r),[e,n]=Lr(t),[s,o]=Lr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new We(e,s,i,t)}function $i(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Di(r.bytes,e.bytes)}}var We=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Gi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ol(e,so(r),t??tt.encoder);default:return Pl(e,so(r),t??Ze.encoder)}}var Zi=new WeakMap;function so(r){let t=Zi.get(r);if(t==null){let e=new Map;return Zi.set(r,e),e}return t}var Ct=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!==Dr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ml)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Vt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&$i(t.multihash,n.multihash)}toString(t){return Gi(this,t)}toJSON(){return{"/":Gi(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??zi(n,s,o.bytes))}else if(e[Fl]===!0){let{version:n,multihash:s,code:o}=e,i=ji(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!==Dr)throw new Error(`Version 0 CID must use dag-pb (code: ${Dr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=zi(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Dr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=qt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new We(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,f]=Lr(t.subarray(e));return e+=f,u},s=n(),o=Dr;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(),l=e+c,h=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:h,size:l}}static parse(t,e){let[n,s]=Hl(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 so(o).set(n,t),o}};function Hl(r,t){switch(r[0]){case"Q":{let e=t??tt;return[tt.prefix,e.decode(`${tt.prefix}${r}`)]}case tt.prefix:{let e=t??tt;return[tt.prefix,e.decode(r)]}case Ze.prefix:{let e=t??Ze;return[Ze.prefix,e.decode(r)]}case Tr.prefix:{let e=t??Tr;return[Tr.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 Ol(r,t,e){let{prefix:n}=e;if(n!==tt.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 Pl(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 Dr=112,Ml=18;function zi(r,t,e){let n=Ye(r),s=n+Ye(t),o=new Uint8Array(s+e.byteLength);return ze(r,o,0),ze(t,o,n),o.set(e,s),o}var Fl=Symbol.for("@ipld/js-cid/CID");var oo={};ft(oo,{identity:()=>ke});var Yi=0,ql="identity",Wi=qt;function jl(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return Vt(Yi,Wi(r))}var ke={code:Yi,name:ql,encode:Wi,digest:jl};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 jt(r=0){return new Uint8Array(r)}function At(r=0){return new Uint8Array(r)}function Je(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=At(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Xi=Symbol.for("@achingbrain/uint8arraylist");function Ji(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 Bn(r){return!!r?.[Xi]}var ht=class r{bufs;length;[Xi]=!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(Bn(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(Bn(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=Ji(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ji(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(Bn(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 l=t>=a&&t<c,h=e>a&&e<=c;if(l&&h){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(h){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(!Bn(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,l=n.byteLength-1,h;for(let u=e;u<=c;u+=h){h=0;for(let f=l;f>=0;f--){let d=this.get(u+f);if(n[f]!==d){h=Math.max(1,f-a[d]);break}}if(h===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=At(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=jt(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=jt(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=jt(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=At(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=jt(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=jt(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=jt(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=jt(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=jt(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 io={};ft(io,{base10:()=>$l});var $l=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var ao={};ft(ao,{base16:()=>Gl,base16upper:()=>Zl});var Gl=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Zl=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var co={};ft(co,{base2:()=>zl});var zl=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var uo={};ft(uo,{base256emoji:()=>Ql});var Qi=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Yl=Qi.reduce((r,t,e)=>(r[e]=t,r),[]),Wl=Qi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Jl(r){return r.reduce((t,e)=>(t+=Yl[e],t),"")}function Xl(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Wl[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var Ql=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:Jl,decode:Xl});var lo={};ft(lo,{base64:()=>Ie,base64pad:()=>tf,base64url:()=>ef,base64urlpad:()=>rf});var Ie=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),tf=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),ef=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),rf=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var fo={};ft(fo,{base8:()=>nf});var nf=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ho={};ft(ho,{identity:()=>sf});var sf=Ge({prefix:"\0",name:"identity",encode:r=>Vi(r),decode:r=>Ki(r)});var Z0=new TextEncoder,z0=new TextDecoder;var go={};ft(go,{sha256:()=>Xe,sha512:()=>uf});var cf=20;function yo({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:s}){return new po(r,t,e,n,s)}var po=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,s,o){this.name=t,this.code=e,this.encode=n,this.minDigestLength=s??cf,this.maxDigestLength=o}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?ta(n,this.code,e?.truncate):n.then(s=>ta(s,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function ta(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return Vt(t,r)}function ra(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Xe=yo({name:"sha2-256",code:18,encode:ra("SHA-256")}),uf=yo({name:"sha2-512",code:19,encode:ra("SHA-512")});var mo={...ho,...co,...fo,...io,...ao,...eo,...ro,...to,...lo,...uo},ip={...go,...oo};function sa(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var na=sa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),bo=sa("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=At(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),lf={utf8:na,"utf-8":na,hex:mo.base16,latin1:bo,ascii:bo,binary:bo,...mo},An=lf;function M(r,t="utf8"){let e=An[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=An[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var ff=parseInt("11111",2),wo=parseInt("10000000",2),hf=parseInt("01111111",2),oa={0:Kr,1:Kr,2:df,3:gf,4:mf,5:yf,6:pf,16:Kr,22:Kr,48:Kr};function _t(r,t={offset:0}){let e=r[t.offset]&ff;if(t.offset++,oa[e]!=null)return oa[e](r,t);throw new Error("No decoder for tag "+e)}function Vr(r,t){let e=0;if((r[t.offset]&wo)===wo){let n=r[t.offset]&hf,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){Vr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=_t(r,t);if(n===null)break;e.push(n)}return e}function df(r,t){let e=Vr(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 pf(r,t){let e=Vr(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 l=r[t.offset];if(t.offset++,c.push(l&127),l<128){c.reverse();let h=0;for(let u=0;u<c.length;u++)h+=c[u]<<u*7;a+=`.${h}`,c=[]}}return a}function yf(r,t){return t.offset++,null}function gf(r,t){let e=Vr(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 mf(r,t){let e=Vr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function bf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new ht;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Sn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=bf(r.byteLength);return new ht(Uint8Array.from([t.byteLength|wo]),t)}function dt(r){let t=new ht,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new ht(Uint8Array.from([2]),Sn(t),t)}function Hr(r){let t=Uint8Array.from([0]),e=new ht(t,r);return new ht(Uint8Array.from([3]),Sn(e),e)}function ia(r){return new ht(Uint8Array.from([4]),Sn(r),r)}function Lt(r,t=48){let e=new ht;for(let n of r)e.append(n);return new ht(Uint8Array.from([t]),Sn(e),e)}var aa="1.2.840.10045.3.1.7",ca="1.3.132.0.34",ua="1.3.132.0.35";async function la(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function fa(r,t,e,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,t,e.subarray());return n?.signal?.throwIfAborted(),o}var wf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),xf=Uint8Array.from([6,5,43,129,4,0,34]),vf=Uint8Array.from([6,5,43,129,4,0,35]),Ef={ext:!0,kty:"EC",crv:"P-256"},Bf={ext:!0,kty:"EC",crv:"P-384"},Af={ext:!0,kty:"EC",crv:"P-521"},xo=32,vo=48,Eo=66;function ha(r){let t=_t(r);return Bo(t)}function Bo(r){let t=r[1],e=q(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===xo)return o=q(n.subarray(s,s+xo),"base64url"),i=q(n.subarray(s+xo),"base64url"),new Qe({...Ef,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===vo)return o=q(n.subarray(s,s+vo),"base64url"),i=q(n.subarray(s+vo),"base64url"),new Qe({...Bf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===Eo)return o=q(n.subarray(s,s+Eo),"base64url"),i=q(n.subarray(s+Eo),"base64url"),new Qe({...Af,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 da(r){return Lt([dt(Uint8Array.from([1])),ia(M(r.d??"","base64url")),Lt([ya(r.crv)],160),Lt([Hr(new ht(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function pa(r){return Lt([dt(Uint8Array.from([1])),Lt([ya(r.crv)],160),Lt([Hr(new ht(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function ya(r){if(r==="P-256")return wf;if(r==="P-384")return xf;if(r==="P-521")return vf;throw new L(`Invalid curve ${r}`)}var kn=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=pa(this.jwk)),this._raw}toMultihash(){return ke.digest(tr(this))}toCID(){return Ct.createV1(114,this.toMultihash())}toString(){return tt.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,n){return fa(this.jwk,e,t,n)}},Qe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new kn({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=da(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async sign(t,e){return la(this.jwk,t,e)}};var Ce=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Zt(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Gt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function pt(r,...t){if(!Zt(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 rr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Gt(r.outputLen),Gt(r.blockLen)}function nr(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 ma(r,t){pt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function vt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Ne(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Rt(r,t){return r<<32-t|r>>>t}function In(r,t){return r<<t|r>>>32-t>>>0}var ba=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Sf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Nt(r){if(pt(r),ba)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Sf[r[e]];return t}var $t={_0:48,_9:57,A:65,F:70,a:97,f:102};function ga(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t.A&&r<=$t.F)return r-($t.A-10);if(r>=$t.a&&r<=$t.f)return r-($t.a-10)}function Ue(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ba)return Uint8Array.fromHex(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=ga(r.charCodeAt(o)),a=ga(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}var kf=async()=>{};async function wa(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 kf(),n+=o)}}function Cn(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Or(r){return typeof r=="string"&&(r=Cn(r)),pt(r),r}function Ao(r){return typeof r=="string"&&(r=Cn(r)),pt(r),r}function yt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];pt(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 xa(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)}var er=class{};function Pr(r){let t=n=>r().update(Or(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function he(r=32){if(Ce&&typeof Ce.getRandomValues=="function")return Ce.getRandomValues(new Uint8Array(r));if(Ce&&typeof Ce.randomBytes=="function")return Uint8Array.from(Ce.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function If(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,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Nn(r,t,e){return r&t^~r&e}function Un(r,t,e){return r&t^r&e^t&e}var Te=class extends er{constructor(t,e,n,s){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=Ne(this.buffer)}update(t){nr(this),t=Or(t),pt(t);let{view:e,buffer:n,blockLen:s}=this,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){nr(this),ma(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,vt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;If(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 l=c/4,h=this.get();if(l>h.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,h[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.destroyed=i,t.finished=o,t.length=s,t.pos=a,s%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},zt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ot=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Tn=BigInt(4294967295),va=BigInt(32);function Cf(r,t=!1){return t?{h:Number(r&Tn),l:Number(r>>va&Tn)}:{h:Number(r>>va&Tn)|0,l:Number(r&Tn)|0}}function Ea(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:a}=Cf(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var So=(r,t,e)=>r>>>e,ko=(r,t,e)=>r<<32-e|t>>>e,_e=(r,t,e)=>r>>>e|t<<32-e,Le=(r,t,e)=>r<<32-e|t>>>e,Mr=(r,t,e)=>r<<64-e|t>>>e-32,Fr=(r,t,e)=>r>>>e-32|t<<64-e;function Ht(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Ba=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Aa=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Sa=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ka=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Ia=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Ca=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Uf=Uint32Array.from([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]),de=new Uint32Array(64),_n=class extends Te{constructor(t=32){super(64,t,8,!1),this.A=zt[0]|0,this.B=zt[1]|0,this.C=zt[2]|0,this.D=zt[3]|0,this.E=zt[4]|0,this.F=zt[5]|0,this.G=zt[6]|0,this.H=zt[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)de[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let f=de[u-15],d=de[u-2],p=Rt(f,7)^Rt(f,18)^f>>>3,w=Rt(d,17)^Rt(d,19)^d>>>10;de[u]=w+de[u-7]+p+de[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:h}=this;for(let u=0;u<64;u++){let f=Rt(a,6)^Rt(a,11)^Rt(a,25),d=h+f+Nn(a,c,l)+Uf[u]+de[u]|0,w=(Rt(n,2)^Rt(n,13)^Rt(n,22))+Un(n,s,o)|0;h=l,l=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+w|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,l=l+this.G|0,h=h+this.H|0,this.set(n,s,o,i,a,c,l,h)}roundClean(){vt(de)}destroy(){this.set(0,0,0,0,0,0,0,0),vt(this.buffer)}};var Na=Ea(["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))),Tf=Na[0],_f=Na[1],pe=new Uint32Array(80),ye=new Uint32Array(80),Ln=class extends Te{constructor(t=64){super(128,t,16,!1),this.Ah=ot[0]|0,this.Al=ot[1]|0,this.Bh=ot[2]|0,this.Bl=ot[3]|0,this.Ch=ot[4]|0,this.Cl=ot[5]|0,this.Dh=ot[6]|0,this.Dl=ot[7]|0,this.Eh=ot[8]|0,this.El=ot[9]|0,this.Fh=ot[10]|0,this.Fl=ot[11]|0,this.Gh=ot[12]|0,this.Gl=ot[13]|0,this.Hh=ot[14]|0,this.Hl=ot[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:l,El:h,Fh:u,Fl:f,Gh:d,Gl:p,Hh:w,Hl:E}=this;return[t,e,n,s,o,i,a,c,l,h,u,f,d,p,w,E]}set(t,e,n,s,o,i,a,c,l,h,u,f,d,p,w,E){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=l|0,this.El=h|0,this.Fh=u|0,this.Fl=f|0,this.Gh=d|0,this.Gl=p|0,this.Hh=w|0,this.Hl=E|0}process(t,e){for(let x=0;x<16;x++,e+=4)pe[x]=t.getUint32(e),ye[x]=t.getUint32(e+=4);for(let x=16;x<80;x++){let I=pe[x-15]|0,D=ye[x-15]|0,P=_e(I,D,1)^_e(I,D,8)^So(I,D,7),O=Le(I,D,1)^Le(I,D,8)^ko(I,D,7),K=pe[x-2]|0,v=ye[x-2]|0,U=_e(K,v,19)^Mr(K,v,61)^So(K,v,6),V=Le(K,v,19)^Fr(K,v,61)^ko(K,v,6),T=Sa(O,V,ye[x-7],ye[x-16]),b=ka(T,P,U,pe[x-7],pe[x-16]);pe[x]=b|0,ye[x]=T|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:h,Eh:u,El:f,Fh:d,Fl:p,Gh:w,Gl:E,Hh:y,Hl:A}=this;for(let x=0;x<80;x++){let I=_e(u,f,14)^_e(u,f,18)^Mr(u,f,41),D=Le(u,f,14)^Le(u,f,18)^Fr(u,f,41),P=u&d^~u&w,O=f&p^~f&E,K=Ia(A,D,O,_f[x],ye[x]),v=Ca(K,y,I,P,Tf[x],pe[x]),U=K|0,V=_e(n,s,28)^Mr(n,s,34)^Mr(n,s,39),T=Le(n,s,28)^Fr(n,s,34)^Fr(n,s,39),b=n&o^n&a^o&a,g=s&i^s&c^i&c;y=w|0,A=E|0,w=d|0,E=p|0,d=u|0,p=f|0,{h:u,l:f}=Ht(l|0,h|0,v|0,U|0),l=a|0,h=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let m=Ba(U,T,g);n=Aa(m,v,V,b),s=m|0}({h:n,l:s}=Ht(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Ht(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Ht(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:h}=Ht(this.Dh|0,this.Dl|0,l|0,h|0),{h:u,l:f}=Ht(this.Eh|0,this.El|0,u|0,f|0),{h:d,l:p}=Ht(this.Fh|0,this.Fl|0,d|0,p|0),{h:w,l:E}=Ht(this.Gh|0,this.Gl|0,w|0,E|0),{h:y,l:A}=Ht(this.Hh|0,this.Hl|0,y|0,A|0),this.set(n,s,o,i,a,c,l,h,u,f,d,p,w,E,y,A)}roundClean(){vt(pe,ye)}destroy(){vt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Rn=Pr(()=>new _n);var Dn=Pr(()=>new Ln);var No=BigInt(0),Co=BigInt(1);function Yt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}"`;throw new Error(e+"expected boolean, got type="+typeof r)}return r}function St(r,t,e=""){let n=Zt(r),s=r?.length,o=t!==void 0;if(!n||o&&s!==t){let i=e&&`"${e}" `,a=o?` of length ${t}`:"",c=n?`length=${s}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function qr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ua(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?No:BigInt("0x"+r)}function sr(r){return Ua(Nt(r))}function Wt(r){return pt(r),Ua(Nt(Uint8Array.from(r).reverse()))}function Kn(r,t){return Ue(r.toString(16).padStart(t*2,"0"))}function Uo(r,t){return Kn(r,t).reverse()}function $(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(Zt(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 Ta(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 To(r){return Uint8Array.from(r)}var Io=r=>typeof r=="bigint"&&No<=r;function _a(r,t,e){return Io(r)&&Io(t)&&Io(e)&&t<=r&&r<e}function jr(r,t,e,n){if(!_a(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Vn(r){let t;for(t=0;r>No;r>>=Co,t+=1);return t}var ge=r=>(Co<<BigInt(r))-Co;function La(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=d=>new Uint8Array(d),s=d=>Uint8Array.of(d),o=n(r),i=n(r),a=0,c=()=>{o.fill(1),i.fill(0),a=0},l=(...d)=>e(i,o,...d),h=(d=n(0))=>{i=l(s(0),d),o=l(),d.length!==0&&(i=l(s(1),d),o=l())},u=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let d=0,p=[];for(;d<t;){o=l();let w=o.slice();p.push(w),d+=o.length}return yt(...p)};return(d,p)=>{c(),h(d);let w;for(;!(w=p(u()));)h();return c(),w}}function me(r,t,e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(s,o,i){let a=r[s];if(i&&a===void 0)return;let c=typeof a;if(c!==o||a===null)throw new Error(`param "${s}" is invalid: expected ${o}, got ${c}`)}Object.entries(t).forEach(([s,o])=>n(s,o,!1)),Object.entries(e).forEach(([s,o])=>n(s,o,!0))}var _o=()=>{throw new Error("not implemented")};function or(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 gt=BigInt(0),nt=BigInt(1),Re=BigInt(2),Ka=BigInt(3),Va=BigInt(4),Ha=BigInt(5),Lf=BigInt(7),Oa=BigInt(8),Rf=BigInt(9),Pa=BigInt(16);function X(r,t){let e=r%t;return e>=gt?e:t+e}function Z(r,t,e){let n=r;for(;t-- >gt;)n*=n,n%=e;return n}function Ra(r,t){if(r===gt)throw new Error("invert: expected non-zero number");if(t<=gt)throw new Error("invert: expected positive modulus, got "+t);let e=X(r,t),n=t,s=gt,o=nt,i=nt,a=gt;for(;e!==gt;){let l=n/e,h=n%e,u=s-i*l,f=o-a*l;n=e,e=h,s=i,o=a,i=u,a=f}if(n!==nt)throw new Error("invert: does not exist");return X(s,t)}function Lo(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function Ma(r,t){let e=(r.ORDER+nt)/Va,n=r.pow(t,e);return Lo(r,n,t),n}function Df(r,t){let e=(r.ORDER-Ha)/Oa,n=r.mul(t,Re),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Re),s),a=r.mul(o,r.sub(i,r.ONE));return Lo(r,a,t),a}function Kf(r){let t=kt(r),e=Fa(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+Lf)/Pa;return(a,c)=>{let l=a.pow(c,i),h=a.mul(l,n),u=a.mul(l,s),f=a.mul(l,o),d=a.eql(a.sqr(h),c),p=a.eql(a.sqr(u),c);l=a.cmov(l,h,d),h=a.cmov(f,u,p);let w=a.eql(a.sqr(h),c),E=a.cmov(l,h,w);return Lo(a,E,c),E}}function Fa(r){if(r<Ka)throw new Error("sqrt is not defined for small field");let t=r-nt,e=0;for(;t%Re===gt;)t/=Re,e++;let n=Re,s=kt(r);for(;Da(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Ma;let o=s.pow(n,t),i=(t+nt)/Re;return function(c,l){if(c.is0(l))return l;if(Da(c,l)!==1)throw new Error("Cannot find square root");let h=e,u=c.mul(c.ONE,o),f=c.pow(l,t),d=c.pow(l,i);for(;!c.eql(f,c.ONE);){if(c.is0(f))return c.ZERO;let p=1,w=c.sqr(f);for(;!c.eql(w,c.ONE);)if(p++,w=c.sqr(w),p===h)throw new Error("Cannot find square root");let E=nt<<BigInt(h-p-1),y=c.pow(u,E);h=p,u=c.sqr(y),f=c.mul(f,u),d=c.mul(d,y)}return d}}function Vf(r){return r%Va===Ka?Ma:r%Oa===Ha?Df:r%Pa===Rf?Kf(r):Fa(r)}var Jt=(r,t)=>(X(r,t)&nt)===nt,Hf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ro(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},e=Hf.reduce((n,s)=>(n[s]="function",n),t);return me(r,e),r}function Of(r,t,e){if(e<gt)throw new Error("invalid exponent, negatives unsupported");if(e===gt)return r.ONE;if(e===nt)return t;let n=r.ONE,s=t;for(;e>gt;)e&nt&&(n=r.mul(n,s)),s=r.sqr(s),e>>=nt;return n}function $r(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),s=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),o=r.inv(s);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),o),n}function Da(r,t){let e=(r.ORDER-nt)/Re,n=r.pow(t,e),s=r.eql(n,r.ONE),o=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!s&&!o&&!i)throw new Error("invalid Legendre symbol result");return s?1:o?0:-1}function Hn(r,t){t!==void 0&&Gt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function kt(r,t,e=!1,n={}){if(r<=gt)throw new Error("invalid field: expected ORDER > 0, got "+r);let s,o,i=!1,a;if(typeof t=="object"&&t!=null){if(n.sqrt||e)throw new Error("cannot specify opts in two arguments");let f=t;f.BITS&&(s=f.BITS),f.sqrt&&(o=f.sqrt),typeof f.isLE=="boolean"&&(e=f.isLE),typeof f.modFromBytes=="boolean"&&(i=f.modFromBytes),a=f.allowedLengths}else typeof t=="number"&&(s=t),n.sqrt&&(o=n.sqrt);let{nBitLength:c,nByteLength:l}=Hn(r,s);if(l>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let h,u=Object.freeze({ORDER:r,isLE:e,BITS:c,BYTES:l,MASK:ge(c),ZERO:gt,ONE:nt,allowedLengths:a,create:f=>X(f,r),isValid:f=>{if(typeof f!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof f);return gt<=f&&f<r},is0:f=>f===gt,isValidNot0:f=>!u.is0(f)&&u.isValid(f),isOdd:f=>(f&nt)===nt,neg:f=>X(-f,r),eql:(f,d)=>f===d,sqr:f=>X(f*f,r),add:(f,d)=>X(f+d,r),sub:(f,d)=>X(f-d,r),mul:(f,d)=>X(f*d,r),pow:(f,d)=>Of(u,f,d),div:(f,d)=>X(f*Ra(d,r),r),sqrN:f=>f*f,addN:(f,d)=>f+d,subN:(f,d)=>f-d,mulN:(f,d)=>f*d,inv:f=>Ra(f,r),sqrt:o||(f=>(h||(h=Vf(r)),h(u,f))),toBytes:f=>e?Uo(f,l):Kn(f,l),fromBytes:(f,d=!0)=>{if(a){if(!a.includes(f.length)||f.length>l)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+f.length);let w=new Uint8Array(l);w.set(f,e?0:w.length-f.length),f=w}if(f.length!==l)throw new Error("Field.fromBytes: expected "+l+" bytes, got "+f.length);let p=e?Wt(f):sr(f);if(i&&(p=X(p,r)),!d&&!u.isValid(p))throw new Error("invalid field element: outside of range 0..ORDER");return p},invertBatch:f=>$r(u,f),cmov:(f,d,p)=>p?d:f});return Object.freeze(u)}function qa(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 Do(r){let t=qa(r);return t+Math.ceil(t/2)}function Ko(r,t,e=!1){let n=r.length,s=qa(t),o=Do(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Wt(r):sr(r),a=X(i,t-nt)+nt;return e?Uo(a,s):Kn(a,s)}var ir=BigInt(0),De=BigInt(1);function Gr(r,t){let e=t.negate();return r?e:t}function Xt(r,t){let e=$r(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}function Za(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Vo(r,t){Za(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=ge(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function ja(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=De);let l=t*n,h=l+Math.abs(a)-1,u=a===0,f=a<0,d=t%2!==0;return{nextN:c,offset:h,isZero:u,isNeg:f,isNegF:d,offsetF:l}}function Pf(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 Mf(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 Ho=new WeakMap,za=new WeakMap;function Oo(r){return za.get(r)||1}function $a(r){if(r!==ir)throw new Error("invalid wNAF")}var ar=class{constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let s=t;for(;e>ir;)e&De&&(n=n.add(s)),s=s.double(),e>>=De;return n}precomputeWindow(t,e){let{windows:n,windowSize:s}=Vo(e,this.bits),o=[],i=t,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let l=1;l<s;l++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=Vo(t,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:l,isZero:h,isNeg:u,isNegF:f,offsetF:d}=ja(n,a,i);n=c,h?o=o.add(Gr(f,e[d])):s=s.add(Gr(u,e[l]))}return $a(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=Vo(t,this.bits);for(let i=0;i<o.windows&&n!==ir;i++){let{nextN:a,offset:c,isZero:l,isNeg:h}=ja(n,i,o);if(n=a,!l){let u=e[c];s=s.add(h?u.negate():u)}}return $a(n),s}getPrecomputes(t,e,n){let s=Ho.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),Ho.set(e,s))),s}cached(t,e,n){let s=Oo(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=Oo(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){Za(e,this.bits),za.set(t,e),Ho.delete(t)}hasCache(t){return Oo(t)!==1}};function Ya(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>ir||n>ir;)e&De&&(o=o.add(s)),n&De&&(i=i.add(s)),s=s.double(),e>>=De,n>>=De;return{p1:o,p2:i}}function cr(r,t,e,n){Pf(e,r),Mf(n,t);let s=e.length,o=n.length;if(s!==o)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=Vn(BigInt(s)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let l=ge(c),h=new Array(Number(l)+1).fill(i),u=Math.floor((t.BITS-1)/c)*c,f=i;for(let d=u;d>=0;d-=c){h.fill(i);for(let w=0;w<o;w++){let E=n[w],y=Number(E>>BigInt(d)&l);h[y]=h[y].add(e[w])}let p=i;for(let w=h.length-1,E=i;w>0;w--)E=E.add(h[w]),p=p.add(E);if(f=f.add(p),d!==0)for(let w=0;w<c;w++)f=f.double()}return f}function Ga(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Ro(t),t}else return kt(r,{isLE:e})}function On(r,t,e={},n){if(n===void 0&&(n=r==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let l=t[c];if(!(typeof l=="bigint"&&l>ir))throw new Error(`CURVE.${c} must be positive bigint`)}let s=Ga(t.p,e.Fp,n),o=Ga(t.n,e.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!s.isValid(t[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:s,Fn:o}}var be=BigInt(0),st=BigInt(1),Po=BigInt(2),Ff=BigInt(8);function qf(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),a=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,a)}function jf(r,t={}){let e=On("edwards",r,t,t.FpFnLE),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i}=o;me(t,{},{uvRatio:"function"});let a=Po<<BigInt(s.BYTES*8)-st,c=E=>n.create(E),l=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:n.sqrt(n.div(E,y))}}catch{return{isValid:!1,value:be}}});if(!qf(n,o,o.Gx,o.Gy))throw new Error("bad curve params: generator point");function h(E,y,A=!1){let x=A?st:be;return jr("coordinate "+E,y,x,a),y}function u(E){if(!(E instanceof p))throw new Error("ExtendedPoint expected")}let f=or((E,y)=>{let{X:A,Y:x,Z:I}=E,D=E.is0();y==null&&(y=D?Ff:n.inv(I));let P=c(A*y),O=c(x*y),K=n.mul(I,y);if(D)return{x:be,y:st};if(K!==st)throw new Error("invZ was invalid");return{x:P,y:O}}),d=or(E=>{let{a:y,d:A}=o;if(E.is0())throw new Error("bad point: ZERO");let{X:x,Y:I,Z:D,T:P}=E,O=c(x*x),K=c(I*I),v=c(D*D),U=c(v*v),V=c(O*y),T=c(v*c(V+K)),b=c(U+c(A*c(O*K)));if(T!==b)throw new Error("bad point: equation left != right (1)");let g=c(x*I),m=c(D*P);if(g!==m)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,A,x,I){this.X=h("x",y),this.Y=h("y",A),this.Z=h("z",x,!0),this.T=h("t",I),Object.freeze(this)}static CURVE(){return o}static fromAffine(y){if(y instanceof p)throw new Error("extended point not allowed");let{x:A,y:x}=y||{};return h("x",A),h("y",x),new p(A,x,st,c(A*x))}static fromBytes(y,A=!1){let x=n.BYTES,{a:I,d:D}=o;y=To(St(y,x,"point")),Yt(A,"zip215");let P=To(y),O=y[x-1];P[x-1]=O&-129;let K=Wt(P),v=A?a:n.ORDER;jr("point.y",K,be,v);let U=c(K*K),V=c(U-st),T=c(D*U-I),{isValid:b,value:g}=l(V,T);if(!b)throw new Error("bad point: invalid y coordinate");let m=(g&st)===st,B=(O&128)!==0;if(!A&&g===be&&B)throw new Error("bad point: x=0 and x_0=1");return B!==m&&(g=c(-g)),p.fromAffine({x:g,y:K})}static fromHex(y,A=!1){return p.fromBytes($("point",y),A)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,A=!0){return w.createCache(this,y),A||this.multiply(Po),this}assertValidity(){d(this)}equals(y){u(y);let{X:A,Y:x,Z:I}=this,{X:D,Y:P,Z:O}=y,K=c(A*O),v=c(D*I),U=c(x*O),V=c(P*I);return K===v&&U===V}is0(){return this.equals(p.ZERO)}negate(){return new p(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:y}=o,{X:A,Y:x,Z:I}=this,D=c(A*A),P=c(x*x),O=c(Po*c(I*I)),K=c(y*D),v=A+x,U=c(c(v*v)-D-P),V=K+P,T=V-O,b=K-P,g=c(U*T),m=c(V*b),B=c(U*b),k=c(T*V);return new p(g,m,k,B)}add(y){u(y);let{a:A,d:x}=o,{X:I,Y:D,Z:P,T:O}=this,{X:K,Y:v,Z:U,T:V}=y,T=c(I*K),b=c(D*v),g=c(O*x*V),m=c(P*U),B=c((I+D)*(K+v)-T-b),k=m-g,_=m+g,C=c(b-A*T),N=c(B*k),R=c(_*C),H=c(B*C),z=c(k*_);return new p(N,R,z,H)}subtract(y){return this.add(y.negate())}multiply(y){if(!s.isValidNot0(y))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:A,f:x}=w.cached(this,y,I=>Xt(p,I));return Xt(p,[A,x])[0]}multiplyUnsafe(y,A=p.ZERO){if(!s.isValid(y))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return y===be?p.ZERO:this.is0()||y===st?this:w.unsafe(this,y,x=>Xt(p,x),A)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return w.unsafe(this,o.n).is0()}toAffine(y){return f(this,y)}clearCofactor(){return i===st?this:this.multiplyUnsafe(i)}toBytes(){let{x:y,y:A}=this.toAffine(),x=n.toBytes(A);return x[x.length-1]|=y&st?128:0,x}toHex(){return Nt(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get ex(){return this.X}get ey(){return this.Y}get ez(){return this.Z}get et(){return this.T}static normalizeZ(y){return Xt(p,y)}static msm(y,A){return cr(p,s,y,A)}_setWindowSize(y){this.precompute(y)}toRawBytes(){return this.toBytes()}}p.BASE=new p(o.Gx,o.Gy,st,c(o.Gx*o.Gy)),p.ZERO=new p(be,st,st,be),p.Fp=n,p.Fn=s;let w=new ar(p,s.BITS);return p.BASE.precompute(8),p}var Pn=class{constructor(t){this.ep=t}static fromBytes(t){_o()}static fromHex(t){_o()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(t){return this.ep.toAffine(t)}toHex(){return Nt(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(t){return this.assertSame(t),this.init(this.ep.add(t.ep))}subtract(t){return this.assertSame(t),this.init(this.ep.subtract(t.ep))}multiply(t){return this.init(this.ep.multiply(t))}multiplyUnsafe(t){return this.init(this.ep.multiplyUnsafe(t))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(t,e){return this.init(this.ep.precompute(t,e))}toRawBytes(){return this.toBytes()}};function $f(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');me(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:s,Fp:o,Fn:i}=r,a=e.randomBytes||he,c=e.adjustScalarBytes||(v=>v),l=e.domain||((v,U,V)=>{if(Yt(V,"phflag"),U.length||V)throw new Error("Contexts/pre-hash are not supported");return v});function h(v){return i.create(Wt(v))}function u(v){let U=x.secretKey;v=$("private key",v,U);let V=$("hashed private key",t(v),2*U),T=c(V.slice(0,U)),b=V.slice(U,2*U),g=h(T);return{head:T,prefix:b,scalar:g}}function f(v){let{head:U,prefix:V,scalar:T}=u(v),b=s.multiply(T),g=b.toBytes();return{head:U,prefix:V,scalar:T,point:b,pointBytes:g}}function d(v){return f(v).pointBytes}function p(v=Uint8Array.of(),...U){let V=yt(...U);return h(t(l(V,$("context",v),!!n)))}function w(v,U,V={}){v=$("message",v),n&&(v=n(v));let{prefix:T,scalar:b,pointBytes:g}=f(U),m=p(V.context,T,v),B=s.multiply(m).toBytes(),k=p(V.context,B,g,v),_=i.create(m+k*b);if(!i.isValid(_))throw new Error("sign failed: invalid s");let C=yt(B,i.toBytes(_));return St(C,x.signature,"result")}let E={zip215:!0};function y(v,U,V,T=E){let{context:b,zip215:g}=T,m=x.signature;v=$("signature",v,m),U=$("message",U),V=$("publicKey",V,x.publicKey),g!==void 0&&Yt(g,"zip215"),n&&(U=n(U));let B=m/2,k=v.subarray(0,B),_=Wt(v.subarray(B,m)),C,N,R;try{C=r.fromBytes(V,g),N=r.fromBytes(k,g),R=s.multiplyUnsafe(_)}catch{return!1}if(!g&&C.isSmallOrder())return!1;let H=p(b,N.toBytes(),C.toBytes(),U);return N.add(C.multiplyUnsafe(H)).subtract(R).clearCofactor().is0()}let A=o.BYTES,x={secretKey:A,publicKey:A,signature:2*A,seed:A};function I(v=a(x.seed)){return St(v,x.seed,"seed")}function D(v){let U=K.randomSecretKey(v);return{secretKey:U,publicKey:d(U)}}function P(v){return Zt(v)&&v.length===i.BYTES}function O(v,U){try{return!!r.fromBytes(v,U)}catch{return!1}}let K={getExtendedPublicKey:f,randomSecretKey:I,isValidSecretKey:P,isValidPublicKey:O,toMontgomery(v){let{y:U}=r.fromBytes(v),V=x.publicKey,T=V===32;if(!T&&V!==57)throw new Error("only defined for 25519 and 448");let b=T?o.div(st+U,st-U):o.div(U-st,U+st);return o.toBytes(b)},toMontgomerySecret(v){let U=x.secretKey;St(v,U);let V=t(v.subarray(0,U));return c(V).subarray(0,U)},randomPrivateKey:I,precompute(v=8,U=r.BASE){return U.precompute(v,!1)}};return Object.freeze({keygen:D,getPublicKey:d,sign:w,verify:y,utils:K,Point:r,lengths:x})}function Gf(r){let t={a:r.a,d:r.d,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=kt(t.n,r.nBitLength,!0),s={Fp:e,Fn:n,uvRatio:r.uvRatio},o={randomBytes:r.randomBytes,adjustScalarBytes:r.adjustScalarBytes,domain:r.domain,prehash:r.prehash,mapToCurve:r.mapToCurve};return{CURVE:t,curveOpts:s,hash:r.hash,eddsaOpts:o}}function Zf(r,t){let e=t.Point;return Object.assign({},t,{ExtendedPoint:e,CURVE:r,nBitLength:e.Fn.BITS,nByteLength:e.Fn.BYTES})}function Wa(r){let{CURVE:t,curveOpts:e,hash:n,eddsaOpts:s}=Gf(r),o=jf(t,e),i=$f(o,n,s);return Zf(r,i)}var zf=BigInt(0),Qt=BigInt(1),Ja=BigInt(2),ly=BigInt(3),Yf=BigInt(5),Wf=BigInt(8),ur=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Zr={p:ur,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Wf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Jf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=ur,a=r*r%o*r%o,c=Z(a,Ja,o)*a%o,l=Z(c,Qt,o)*r%o,h=Z(l,Yf,o)*l%o,u=Z(h,t,o)*h%o,f=Z(u,e,o)*u%o,d=Z(f,n,o)*f%o,p=Z(d,s,o)*d%o,w=Z(p,s,o)*d%o,E=Z(w,t,o)*h%o;return{pow_p_5_8:Z(E,Ja,o)*r%o,b2:a}}function Xf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Mo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function jo(r,t){let e=ur,n=X(t*t*t,e),s=X(n*n*t,e),o=Jf(r*s).pow_p_5_8,i=X(r*n*o,e),a=X(t*i*i,e),c=i,l=X(i*Mo,e),h=a===r,u=a===X(-r,e),f=a===X(-r*Mo,e);return h&&(i=c),(u||f)&&(i=l),Jt(i,e)&&(i=X(-i,e)),{isValid:h||u,value:i}}var we=kt(Zr.p,{isLE:!0}),Qf=kt(Zr.n,{isLE:!0}),th={...Zr,Fp:we,hash:Dn,adjustScalarBytes:Xf,uvRatio:jo},Ot=Wa(th);var Fo=Mo,eh=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),rh=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),nh=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),sh=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),Xa=r=>jo(Qt,r),oh=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),qo=r=>Ot.Point.Fp.create(Wt(r)&oh);function Qa(r){let{d:t}=Zr,e=ur,n=y=>we.create(y),s=n(Fo*r*r),o=n((s+Qt)*nh),i=BigInt(-1),a=n((i-t*s)*n(s+t)),{isValid:c,value:l}=jo(o,a),h=n(l*r);Jt(h,e)||(h=n(-h)),c||(l=h),c||(i=s);let u=n(i*(s-Qt)*sh-a),f=l*l,d=n((l+l)*a),p=n(u*eh),w=n(Qt-f),E=n(Qt+f);return new Ot.Point(n(d*E),n(w*p),n(p*E),n(d*w))}function ih(r){pt(r,64);let t=qo(r.subarray(0,32)),e=Qa(t),n=qo(r.subarray(32,64)),s=Qa(n);return new te(e.add(s))}var te=class r extends Pn{constructor(t){super(t)}static fromAffine(t){return new r(Ot.Point.fromAffine(t))}assertSame(t){if(!(t instanceof r))throw new Error("RistrettoPoint expected")}init(t){return new r(t)}static hashToCurve(t){return ih($("ristrettoHash",t,64))}static fromBytes(t){pt(t,32);let{a:e,d:n}=Zr,s=ur,o=I=>we.create(I),i=qo(t);if(!Ta(we.toBytes(i),t)||Jt(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(Qt+e*a),l=o(Qt-e*a),h=o(c*c),u=o(l*l),f=o(e*n*h-u),{isValid:d,value:p}=Xa(o(f*u)),w=o(p*l),E=o(p*w*f),y=o((i+i)*w);Jt(y,s)&&(y=o(-y));let A=o(c*E),x=o(y*A);if(!d||Jt(x,s)||A===zf)throw new Error("invalid ristretto255 encoding 2");return new r(new Ot.Point(y,A,Qt,x))}static fromHex(t){return r.fromBytes($("ristrettoHex",t,32))}static msm(t,e){return cr(r,Ot.Point.Fn,t,e)}toBytes(){let{X:t,Y:e,Z:n,T:s}=this.ep,o=ur,i=E=>we.create(E),a=i(i(n+e)*i(n-e)),c=i(t*e),l=i(c*c),{value:h}=Xa(i(a*l)),u=i(h*a),f=i(h*c),d=i(u*f*s),p;if(Jt(s*d,o)){let E=i(e*Fo),y=i(t*Fo);t=E,e=y,p=i(u*rh)}else p=f;Jt(t*d,o)&&(e=i(-e));let w=i((n-e)*p);return Jt(w,o)&&(w=i(-w)),we.toBytes(w)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:s,Y:o}=t.ep,i=l=>we.create(l),a=i(e*o)===i(n*s),c=i(n*o)===i(e*s);return a||c}is0(){return this.equals(r.ZERO)}};te.BASE=new te(Ot.Point.BASE);te.ZERO=new te(Ot.Point.ZERO);te.Fp=we;te.Fn=Qf;var fr=32,Ut=64,ah=32;var lr,tc=(async()=>{try{return await Q.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function ch(r,t){let e;r.length===Ut?e=r.subarray(0,32):e=r;let n={crv:"Ed25519",kty:"OKP",x:q(r.subarray(32),"base64url"),d:q(e,"base64url"),ext:!0,key_ops:["sign"]},s=await Q.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await Q.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function uh(r,t){let e=r.subarray(0,ah);return Ot.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function ec(r,t){return lr==null&&(lr=await tc),lr?ch(r,t):uh(r,t)}async function lh(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Q.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Q.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function fh(r,t,e){return Ot.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function rc(r,t,e){return lr==null&&(lr=await tc),lr?lh(r,t,e):fh(r,t,e)}function hr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Mn=class{type="Ed25519";raw;constructor(t){this.raw=Yr(t,fr)}toMultihash(){return ke.digest(tr(this))}toCID(){return Ct.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let s=rc(this.raw,e,t);return hr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},zr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Yr(t,Ut),this.publicKey=new Mn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=ec(this.raw,t);return hr(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function $o(r){if(r.length>Ut){r=Yr(r,Ut+fr);let n=r.subarray(0,Ut),s=r.subarray(Ut,r.length);return new zr(n,s)}r=Yr(r,Ut);let t=r.subarray(0,Ut),e=r.subarray(fr);return new zr(t,e)}function Yr(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 hh=Math.pow(2,7),dh=Math.pow(2,14),ph=Math.pow(2,21),sc=Math.pow(2,28),oc=Math.pow(2,35),ic=Math.pow(2,42),ac=Math.pow(2,49),mt=128,xe=127;function Wr(r){if(r<hh)return 1;if(r<dh)return 2;if(r<ph)return 3;if(r<sc)return 4;if(r<oc)return 5;if(r<ic)return 6;if(r<ac)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function cc(r,t,e=0){switch(Wr(r)){case 8:t[e++]=r&255|mt,r/=128;case 7:t[e++]=r&255|mt,r/=128;case 6:t[e++]=r&255|mt,r/=128;case 5:t[e++]=r&255|mt,r/=128;case 4:t[e++]=r&255|mt,r>>>=7;case 3:t[e++]=r&255|mt,r>>>=7;case 2:t[e++]=r&255|mt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function uc(r,t){let e=r[t],n=0;if(n+=e&xe,e<mt||(e=r[t+1],n+=(e&xe)<<7,e<mt)||(e=r[t+2],n+=(e&xe)<<14,e<mt)||(e=r[t+3],n+=(e&xe)<<21,e<mt)||(e=r[t+4],n+=(e&xe)*sc,e<mt)||(e=r[t+5],n+=(e&xe)*oc,e<mt)||(e=r[t+6],n+=(e&xe)*ic,e<mt)||(e=r[t+7],n+=(e&xe)*ac,e<mt))return n;throw new RangeError("Could not decode varint")}var Go=new Float32Array([-0]),ve=new Uint8Array(Go.buffer);function lc(r,t,e){Go[0]=r,t[e]=ve[0],t[e+1]=ve[1],t[e+2]=ve[2],t[e+3]=ve[3]}function fc(r,t){return ve[0]=r[t],ve[1]=r[t+1],ve[2]=r[t+2],ve[3]=r[t+3],Go[0]}var Zo=new Float64Array([-0]),ut=new Uint8Array(Zo.buffer);function hc(r,t,e){Zo[0]=r,t[e]=ut[0],t[e+1]=ut[1],t[e+2]=ut[2],t[e+3]=ut[3],t[e+4]=ut[4],t[e+5]=ut[5],t[e+6]=ut[6],t[e+7]=ut[7]}function dc(r,t){return ut[0]=r[t],ut[1]=r[t+1],ut[2]=r[t+2],ut[3]=r[t+3],ut[4]=r[t+4],ut[5]=r[t+5],ut[6]=r[t+6],ut[7]=r[t+7],Zo[0]}var yh=BigInt(Number.MAX_SAFE_INTEGER),gh=BigInt(Number.MIN_SAFE_INTEGER),It=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 Ke;if(t<yh&&t>gh)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>pc&&(s=0n,++n>pc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ke;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):Ke}},Ke=new It(0,0);Ke.toBigInt=function(){return 0n};Ke.zzEncode=Ke.zzDecode=function(){return this};Ke.length=function(){return 1};var pc=4294967296n;function yc(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 gc(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 zo(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 Dt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Fn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Yo=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,Dt(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 Dt(this,4);return Fn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Dt(this,4);return Fn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Dt(this,4);let t=fc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Dt(this,4);let t=dc(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 Dt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return gc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Dt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Dt(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 It(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 Dt(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 Dt(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 Dt(this,8);let t=Fn(this.buf,this.pos+=4),e=Fn(this.buf,this.pos+=4);return new It(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=uc(this.buf,this.pos);return this.pos+=Wr(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 Wo(r){return new Yo(r instanceof Uint8Array?r:r.subarray())}function qn(r,t,e){let n=Wo(r);return t.decode(n,void 0,e)}function Jo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return At(i);s+i>t&&(n=At(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ve=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Xo(){}var ti=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},mh=Jo();function bh(r){return globalThis.Buffer!=null?At(r):mh(r)}var Xr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ve(Xo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ve(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ei((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(jn,10,It.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=It.fromBigInt(t);return this._push(jn,e.length(),e)}uint64Number(t){return this._push(cc,Wr(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=It.fromBigInt(t).zzEncode();return this._push(jn,e.length(),e)}sint64Number(t){let e=It.fromNumber(t).zzEncode();return this._push(jn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Qo,1,t?1:0)}fixed32(t){return this._push(Jr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=It.fromBigInt(t);return this._push(Jr,4,e.lo)._push(Jr,4,e.hi)}fixed64Number(t){let e=It.fromNumber(t);return this._push(Jr,4,e.lo)._push(Jr,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(lc,4,t)}double(t){return this._push(hc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Qo,1,0):this.uint32(e)._push(xh,e,t)}string(t){let e=yc(t);return e!==0?this.uint32(e)._push(zo,e,t):this._push(Qo,1,0)}fork(){return this.states=new ti(this),this.head=this.tail=new Ve(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 Ve(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=bh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Qo(r,t,e){t[e]=r&255}function wh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ei=class extends Ve{next;constructor(t,e){super(wh,t,e),this.next=void 0}};function jn(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 Jr(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 xh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Xr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(vh,t,r),this},Xr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Eh,t,r),this});function vh(r,t,e){t.set(r,e)}function Eh(r,t,e){r.length<40?zo(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(M(r),e)}function ri(){return new Xr}function $n(r,t){let e=ri();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var dr;(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"})(dr||(dr={}));function Gn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ni(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Gn("enum",dr.VARINT,e,n)}function Zn(r,t){return Gn("message",dr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var si;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(si||(si={}));(function(r){r.codec=()=>ni(si)})(rt||(rt={}));var Ee;(function(r){let t;r.codec=()=>(t==null&&(t=Zn((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=>$n(e,r.codec()),r.decode=(e,n)=>qn(e,r.codec(),n)})(Ee||(Ee={}));var Qr;(function(r){let t;r.codec=()=>(t==null&&(t=Zn((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=>$n(e,r.codec()),r.decode=(e,n)=>qn(e,r.codec(),n)})(Qr||(Qr={}));function He(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return he(r)}var en={};ft(en,{MAX_RSA_KEY_SIZE:()=>oi,generateRSAKeyPair:()=>Ec,jwkToJWKKeyPair:()=>Bc,jwkToPkcs1:()=>kh,jwkToPkix:()=>ui,jwkToRSAPrivateKey:()=>hi,pkcs1MessageToJwk:()=>ai,pkcs1MessageToRSAPrivateKey:()=>zn,pkcs1ToJwk:()=>Sh,pkcs1ToRSAPrivateKey:()=>li,pkixMessageToJwk:()=>ci,pkixMessageToRSAPublicKey:()=>fi,pkixToJwk:()=>Ih,pkixToRSAPublicKey:()=>vc});var pr=Rn;var yr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=en.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return Ct.createV1(114,this._multihash)}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e,n){return xc(this.jwk,e,t,n)}},tn=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=en.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t,e){return wc(this.jwk,t,e)}};var oi=8192,ii=18,Bh=1062,Ah=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Sh(r){let t=_t(r);return ai(t)}function ai(r){return{n:q(r[1],"base64url"),e:q(r[2],"base64url"),d:q(r[3],"base64url"),p:q(r[4],"base64url"),q:q(r[5],"base64url"),dp:q(r[6],"base64url"),dq:q(r[7],"base64url"),qi:q(r[8],"base64url"),kty:"RSA"}}function kh(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 Lt([dt(Uint8Array.from([0])),dt(M(r.n,"base64url")),dt(M(r.e,"base64url")),dt(M(r.d,"base64url")),dt(M(r.p,"base64url")),dt(M(r.q,"base64url")),dt(M(r.dp,"base64url")),dt(M(r.dq,"base64url")),dt(M(r.qi,"base64url"))]).subarray()}function Ih(r){let t=_t(r,{offset:0});return ci(t)}function ci(r){let t=_t(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function ui(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Lt([Ah,Hr(Lt([dt(M(r.n,"base64url")),dt(M(r.e,"base64url"))]))]).subarray()}function li(r){let t=_t(r);return zn(t)}function zn(r){let t=ai(r);return hi(t)}function vc(r,t){if(r.byteLength>=Bh)throw new je("Key size is too large");let e=_t(r,{offset:0});return fi(e,r,t)}function fi(r,t,e){let n=ci(r);if(e==null){let s=pr(Ee.encode({Type:rt.RSA,Data:t}));e=Vt(ii,s)}return new yr(n,e)}function hi(r){if(Sc(r)>oi)throw new L("Key size is too large");let t=Bc(r),e=pr(Ee.encode({Type:rt.RSA,Data:ui(t.publicKey)})),n=Vt(ii,e);return new tn(t.privateKey,new yr(t.publicKey,n))}async function Ec(r){if(r>oi)throw new L("Key size is too large");let t=await Ac(r),e=pr(Ee.encode({Type:rt.RSA,Data:ui(t.publicKey)})),n=Vt(ii,e);return new tn(t.privateKey,new yr(t.publicKey,n))}function Bc(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 Ac(r,t){let e=await Q.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await Ch(e,t);return{privateKey:n[0],publicKey:n[1]}}async function wc(r,t,e){let n=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await Q.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function xc(r,t,e,n){let s=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Q.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function Ch(r,t){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");let e=await Promise.all([Q.get().subtle.exportKey("jwk",r.privateKey),Q.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function Sc(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return M(r.n,"base64url").length*8}var Yn=class extends er{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,rr(t);let n=Or(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),vt(o)}update(t){return nr(this),this.iHash.update(t),this}digestInto(t){nr(this),pt(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}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},rn=(r,t,e)=>new Yn(r,t).update(e).digest();rn.create=(r,t)=>new Yn(r,t);var kc=(r,t)=>(r+(r>=0?t:-t)/Ic)/t;function Nh(r,t,e){let[[n,s],[o,i]]=t,a=kc(i*r,e),c=kc(-s*r,e),l=r-a*n-c*o,h=-a*s-c*i,u=l<re,f=h<re;u&&(l=-l),f&&(h=-h);let d=ge(Math.ceil(Vn(e)/2))+mr;if(l<re||l>=d||h<re||h>=d)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:f,k2:h}}function pi(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function di(r,t){let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return Yt(e.lowS,"lowS"),Yt(e.prehash,"prehash"),e.format!==void 0&&pi(e.format),e}var yi=class extends Error{constructor(t=""){super(t)}},ee={Err:yi,_tlv:{encode:(r,t)=>{let{Err:e}=ee;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=qr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?qr(s.length/2|128):"";return qr(r)+o+s+t},decode(r,t){let{Err:e}=ee,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let h of l)i=i<<8|h;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=ee;if(r<re)throw new t("integer: negative integers are not allowed");let e=qr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ee;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return sr(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ee,s=$("signature",r),{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:l,l:h}=n.decode(2,c);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=ee,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},re=BigInt(0),mr=BigInt(1),Ic=BigInt(2),Wn=BigInt(3),Uh=BigInt(4);function gr(r,t){let{BYTES:e}=r,n;if(typeof t=="bigint")n=t;else{let s=$("private key",t);try{n=r.fromBytes(s)}catch{throw new Error(`invalid private key: expected ui8a of size ${e}, got ${typeof t}`)}}if(!r.isValidNot0(n))throw new Error("invalid private key: out of range [1..N-1]");return n}function Th(r,t={}){let e=On("weierstrass",r,t),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i,n:a}=o;me(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:c}=t;if(c&&(!n.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=Nc(n,s);function h(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(T,b,g){let{x:m,y:B}=b.toAffine(),k=n.toBytes(m);if(Yt(g,"isCompressed"),g){h();let _=!n.isOdd(B);return yt(Cc(_),k)}else return yt(Uint8Array.of(4),k,n.toBytes(B))}function f(T){St(T,void 0,"Point");let{publicKey:b,publicKeyUncompressed:g}=l,m=T.length,B=T[0],k=T.subarray(1);if(m===b&&(B===2||B===3)){let _=n.fromBytes(k);if(!n.isValid(_))throw new Error("bad point: is not on curve, wrong x");let C=w(_),N;try{N=n.sqrt(C)}catch(z){let G=z instanceof Error?": "+z.message:"";throw new Error("bad point: is not on curve, sqrt error"+G)}h();let R=n.isOdd(N);return(B&1)===1!==R&&(N=n.neg(N)),{x:_,y:N}}else if(m===g&&B===4){let _=n.BYTES,C=n.fromBytes(k.subarray(0,_)),N=n.fromBytes(k.subarray(_,_*2));if(!E(C,N))throw new Error("bad point: is not on curve");return{x:C,y:N}}else throw new Error(`bad point: got length ${m}, expected compressed=${b} or uncompressed=${g}`)}let d=t.toBytes||u,p=t.fromBytes||f;function w(T){let b=n.sqr(T),g=n.mul(b,T);return n.add(n.add(g,n.mul(T,o.a)),o.b)}function E(T,b){let g=n.sqr(b),m=w(T);return n.eql(g,m)}if(!E(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let y=n.mul(n.pow(o.a,Wn),Uh),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(y,A)))throw new Error("bad curve params: a or b");function x(T,b,g=!1){if(!n.isValid(b)||g&&n.is0(b))throw new Error(`bad point coordinate ${T}`);return b}function I(T){if(!(T instanceof v))throw new Error("ProjectivePoint expected")}function D(T){if(!c||!c.basises)throw new Error("no endo");return Nh(T,c.basises,s.ORDER)}let P=or((T,b)=>{let{X:g,Y:m,Z:B}=T;if(n.eql(B,n.ONE))return{x:g,y:m};let k=T.is0();b==null&&(b=k?n.ONE:n.inv(B));let _=n.mul(g,b),C=n.mul(m,b),N=n.mul(B,b);if(k)return{x:n.ZERO,y:n.ZERO};if(!n.eql(N,n.ONE))throw new Error("invZ was invalid");return{x:_,y:C}}),O=or(T=>{if(T.is0()){if(t.allowInfinityPoint&&!n.is0(T.Y))return;throw new Error("bad point: ZERO")}let{x:b,y:g}=T.toAffine();if(!n.isValid(b)||!n.isValid(g))throw new Error("bad point: x or y not field elements");if(!E(b,g))throw new Error("bad point: equation left != right");if(!T.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function K(T,b,g,m,B){return g=new v(n.mul(g.X,T),g.Y,g.Z),b=Gr(m,b),g=Gr(B,g),b.add(g)}class v{constructor(b,g,m){this.X=x("x",b),this.Y=x("y",g,!0),this.Z=x("z",m),Object.freeze(this)}static CURVE(){return o}static fromAffine(b){let{x:g,y:m}=b||{};if(!b||!n.isValid(g)||!n.isValid(m))throw new Error("invalid affine point");if(b instanceof v)throw new Error("projective point not allowed");return n.is0(g)&&n.is0(m)?v.ZERO:new v(g,m,n.ONE)}static fromBytes(b){let g=v.fromAffine(p(St(b,void 0,"point")));return g.assertValidity(),g}static fromHex(b){return v.fromBytes($("pointHex",b))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(b=8,g=!0){return V.createCache(this,b),g||this.multiply(Wn),this}assertValidity(){O(this)}hasEvenY(){let{y:b}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(b)}equals(b){I(b);let{X:g,Y:m,Z:B}=this,{X:k,Y:_,Z:C}=b,N=n.eql(n.mul(g,C),n.mul(k,B)),R=n.eql(n.mul(m,C),n.mul(_,B));return N&&R}negate(){return new v(this.X,n.neg(this.Y),this.Z)}double(){let{a:b,b:g}=o,m=n.mul(g,Wn),{X:B,Y:k,Z:_}=this,C=n.ZERO,N=n.ZERO,R=n.ZERO,H=n.mul(B,B),z=n.mul(k,k),G=n.mul(_,_),j=n.mul(B,k);return j=n.add(j,j),R=n.mul(B,_),R=n.add(R,R),C=n.mul(b,R),N=n.mul(m,G),N=n.add(C,N),C=n.sub(z,N),N=n.add(z,N),N=n.mul(C,N),C=n.mul(j,C),R=n.mul(m,R),G=n.mul(b,G),j=n.sub(H,G),j=n.mul(b,j),j=n.add(j,R),R=n.add(H,H),H=n.add(R,H),H=n.add(H,G),H=n.mul(H,j),N=n.add(N,H),G=n.mul(k,_),G=n.add(G,G),H=n.mul(G,j),C=n.sub(C,H),R=n.mul(G,z),R=n.add(R,R),R=n.add(R,R),new v(C,N,R)}add(b){I(b);let{X:g,Y:m,Z:B}=this,{X:k,Y:_,Z:C}=b,N=n.ZERO,R=n.ZERO,H=n.ZERO,z=o.a,G=n.mul(o.b,Wn),j=n.mul(g,k),Y=n.mul(m,_),et=n.mul(B,C),wt=n.add(g,m),W=n.add(k,_);wt=n.mul(wt,W),W=n.add(j,Y),wt=n.sub(wt,W),W=n.add(g,B);let ct=n.add(k,C);return W=n.mul(W,ct),ct=n.add(j,et),W=n.sub(W,ct),ct=n.add(m,B),N=n.add(_,C),ct=n.mul(ct,N),N=n.add(Y,et),ct=n.sub(ct,N),H=n.mul(z,W),N=n.mul(G,et),H=n.add(N,H),N=n.sub(Y,H),H=n.add(Y,H),R=n.mul(N,H),Y=n.add(j,j),Y=n.add(Y,j),et=n.mul(z,et),W=n.mul(G,W),Y=n.add(Y,et),et=n.sub(j,et),et=n.mul(z,et),W=n.add(W,et),j=n.mul(Y,W),R=n.add(R,j),j=n.mul(ct,W),N=n.mul(wt,N),N=n.sub(N,j),j=n.mul(wt,Y),H=n.mul(ct,H),H=n.add(H,j),new v(N,R,H)}subtract(b){return this.add(b.negate())}is0(){return this.equals(v.ZERO)}multiply(b){let{endo:g}=t;if(!s.isValidNot0(b))throw new Error("invalid scalar: out of range");let m,B,k=_=>V.cached(this,_,C=>Xt(v,C));if(g){let{k1neg:_,k1:C,k2neg:N,k2:R}=D(b),{p:H,f:z}=k(C),{p:G,f:j}=k(R);B=z.add(j),m=K(g.beta,H,G,_,N)}else{let{p:_,f:C}=k(b);m=_,B=C}return Xt(v,[m,B])[0]}multiplyUnsafe(b){let{endo:g}=t,m=this;if(!s.isValid(b))throw new Error("invalid scalar: out of range");if(b===re||m.is0())return v.ZERO;if(b===mr)return m;if(V.hasCache(this))return this.multiply(b);if(g){let{k1neg:B,k1:k,k2neg:_,k2:C}=D(b),{p1:N,p2:R}=Ya(v,m,k,C);return K(g.beta,N,R,B,_)}else return V.unsafe(m,b)}multiplyAndAddUnsafe(b,g,m){let B=this.multiplyUnsafe(g).add(b.multiplyUnsafe(m));return B.is0()?void 0:B}toAffine(b){return P(this,b)}isTorsionFree(){let{isTorsionFree:b}=t;return i===mr?!0:b?b(v,this):V.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:b}=t;return i===mr?this:b?b(v,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(b=!0){return Yt(b,"isCompressed"),this.assertValidity(),d(v,this,b)}toHex(b=!0){return Nt(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(b=!0){return this.toBytes(b)}_setWindowSize(b){this.precompute(b)}static normalizeZ(b){return Xt(v,b)}static msm(b,g){return cr(v,s,b,g)}static fromPrivateKey(b){return v.BASE.multiply(gr(s,b))}}v.BASE=new v(o.Gx,o.Gy,n.ONE),v.ZERO=new v(n.ZERO,n.ONE,n.ZERO),v.Fp=n,v.Fn=s;let U=s.BITS,V=new ar(v,t.endo?Math.ceil(U/2):U);return v.BASE.precompute(8),v}function Cc(r){return Uint8Array.of(r?2:3)}function Nc(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function _h(r,t={}){let{Fn:e}=r,n=t.randomBytes||he,s=Object.assign(Nc(r.Fp,e),{seed:Do(e.ORDER)});function o(d){try{return!!gr(e,d)}catch{return!1}}function i(d,p){let{publicKey:w,publicKeyUncompressed:E}=s;try{let y=d.length;return p===!0&&y!==w||p===!1&&y!==E?!1:!!r.fromBytes(d)}catch{return!1}}function a(d=n(s.seed)){return Ko(St(d,s.seed,"seed"),e.ORDER)}function c(d,p=!0){return r.BASE.multiply(gr(e,d)).toBytes(p)}function l(d){let p=a(d);return{secretKey:p,publicKey:c(p)}}function h(d){if(typeof d=="bigint")return!1;if(d instanceof r)return!0;let{secretKey:p,publicKey:w,publicKeyUncompressed:E}=s;if(e.allowedLengths||p===w)return;let y=$("key",d).length;return y===w||y===E}function u(d,p,w=!0){if(h(d)===!0)throw new Error("first arg must be private key");if(h(p)===!1)throw new Error("second arg must be public key");let E=gr(e,d);return r.fromHex(p).multiply(E).toBytes(w)}return Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:l,Point:r,utils:{isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a,isValidPrivateKey:o,randomPrivateKey:a,normPrivateKeyToScalar:d=>gr(e,d),precompute(d=8,p=r.BASE){return p.precompute(d,!1)}},lengths:s})}function Lh(r,t,e={}){rr(t),me(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=e.randomBytes||he,s=e.hmac||((g,...m)=>rn(t,g,yt(...m))),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:h,getSharedSecret:u,utils:f,lengths:d}=_h(r,e),p={prehash:!1,lowS:typeof e.lowS=="boolean"?e.lowS:!1,format:void 0,extraEntropy:!1},w="compact";function E(g){let m=a>>mr;return g>m}function y(g,m){if(!i.isValidNot0(m))throw new Error(`invalid signature ${g}: out of range 1..Point.Fn.ORDER`);return m}function A(g,m){pi(m);let B=d.signature,k=m==="compact"?B:m==="recovered"?B+1:void 0;return St(g,k,`${m} signature`)}class x{constructor(m,B,k){this.r=y("r",m),this.s=y("s",B),k!=null&&(this.recovery=k),Object.freeze(this)}static fromBytes(m,B=w){A(m,B);let k;if(B==="der"){let{r:R,s:H}=ee.toSig(St(m));return new x(R,H)}B==="recovered"&&(k=m[0],B="compact",m=m.subarray(1));let _=i.BYTES,C=m.subarray(0,_),N=m.subarray(_,_*2);return new x(i.fromBytes(C),i.fromBytes(N),k)}static fromHex(m,B){return this.fromBytes(Ue(m),B)}addRecoveryBit(m){return new x(this.r,this.s,m)}recoverPublicKey(m){let B=o.ORDER,{r:k,s:_,recovery:C}=this;if(C==null||![0,1,2,3].includes(C))throw new Error("recovery id invalid");if(a*Ic<B&&C>1)throw new Error("recovery id is ambiguous for h>1 curve");let R=C===2||C===3?k+a:k;if(!o.isValid(R))throw new Error("recovery id 2 or 3 invalid");let H=o.toBytes(R),z=r.fromBytes(yt(Cc((C&1)===0),H)),G=i.inv(R),j=D($("msgHash",m)),Y=i.create(-j*G),et=i.create(_*G),wt=r.BASE.multiplyUnsafe(Y).add(z.multiplyUnsafe(et));if(wt.is0())throw new Error("point at infinify");return wt.assertValidity(),wt}hasHighS(){return E(this.s)}toBytes(m=w){if(pi(m),m==="der")return Ue(ee.hexFromSig(this));let B=i.toBytes(this.r),k=i.toBytes(this.s);if(m==="recovered"){if(this.recovery==null)throw new Error("recovery bit must be present");return yt(Uint8Array.of(this.recovery),B,k)}return yt(B,k)}toHex(m){return Nt(this.toBytes(m))}assertValidity(){}static fromCompact(m){return x.fromBytes($("sig",m),"compact")}static fromDER(m){return x.fromBytes($("sig",m),"der")}normalizeS(){return this.hasHighS()?new x(this.r,i.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return Nt(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return Nt(this.toBytes("compact"))}}let I=e.bits2int||function(m){if(m.length>8192)throw new Error("input is too large");let B=sr(m),k=m.length*8-c;return k>0?B>>BigInt(k):B},D=e.bits2int_modN||function(m){return i.create(I(m))},P=ge(c);function O(g){return jr("num < 2^"+c,g,re,P),i.toBytes(g)}function K(g,m){return St(g,void 0,"message"),m?St(t(g),void 0,"prehashed message"):g}function v(g,m,B){if(["recovered","canonical"].some(Y=>Y in B))throw new Error("sign() legacy options not supported");let{lowS:k,prehash:_,extraEntropy:C}=di(B,p);g=K(g,_);let N=D(g),R=gr(i,m),H=[O(R),O(N)];if(C!=null&&C!==!1){let Y=C===!0?n(d.secretKey):C;H.push($("extraEntropy",Y))}let z=yt(...H),G=N;function j(Y){let et=I(Y);if(!i.isValidNot0(et))return;let wt=i.inv(et),W=r.BASE.multiply(et).toAffine(),ct=i.create(W.x);if(ct===re)return;let bn=i.create(wt*i.create(G+ct*R));if(bn===re)return;let Ni=(W.x===ct?0:2)|Number(W.y&mr),Ui=bn;return k&&E(bn)&&(Ui=i.neg(bn),Ni^=1),new x(ct,Ui,Ni)}return{seed:z,k2sig:j}}function U(g,m,B={}){g=$("message",g);let{seed:k,k2sig:_}=v(g,m,B);return La(t.outputLen,i.BYTES,s)(k,_)}function V(g){let m,B=typeof g=="string"||Zt(g),k=!B&&g!==null&&typeof g=="object"&&typeof g.r=="bigint"&&typeof g.s=="bigint";if(!B&&!k)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(k)m=new x(g.r,g.s);else if(B){try{m=x.fromBytes($("sig",g),"der")}catch(_){if(!(_ instanceof ee.Err))throw _}if(!m)try{m=x.fromBytes($("sig",g),"compact")}catch{return!1}}return m||!1}function T(g,m,B,k={}){let{lowS:_,prehash:C,format:N}=di(k,p);if(B=$("publicKey",B),m=K($("message",m),C),"strict"in k)throw new Error("options.strict was renamed to lowS");let R=N===void 0?V(g):x.fromBytes($("sig",g),N);if(R===!1)return!1;try{let H=r.fromBytes(B);if(_&&R.hasHighS())return!1;let{r:z,s:G}=R,j=D(m),Y=i.inv(G),et=i.create(j*Y),wt=i.create(z*Y),W=r.BASE.multiplyUnsafe(et).add(H.multiplyUnsafe(wt));return W.is0()?!1:i.create(W.x)===z}catch{return!1}}function b(g,m,B={}){let{prehash:k}=di(B,p);return m=K(m,k),x.fromBytes(g,"recovered").recoverPublicKey(m).toBytes()}return Object.freeze({keygen:l,getPublicKey:h,getSharedSecret:u,utils:f,lengths:d,Point:r,sign:U,verify:T,recoverPublicKey:b,Signature:x,hash:t})}function Rh(r){let t={a:r.a,b:r.b,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=r.allowedPrivateKeyLengths?Array.from(new Set(r.allowedPrivateKeyLengths.map(i=>Math.ceil(i/2)))):void 0,s=kt(t.n,{BITS:r.nBitLength,allowedLengths:n,modFromBytes:r.wrapPrivateKey}),o={Fp:e,Fn:s,allowInfinityPoint:r.allowInfinityPoint,endo:r.endo,isTorsionFree:r.isTorsionFree,clearCofactor:r.clearCofactor,fromBytes:r.fromBytes,toBytes:r.toBytes};return{CURVE:t,curveOpts:o}}function Dh(r){let{CURVE:t,curveOpts:e}=Rh(r),n={hmac:r.hmac,randomBytes:r.randomBytes,lowS:r.lowS,bits2int:r.bits2int,bits2int_modN:r.bits2int_modN};return{CURVE:t,curveOpts:e,hash:r.hash,ecdsaOpts:n}}function Kh(r,t){let e=t.Point;return Object.assign({},t,{ProjectivePoint:e,CURVE:Object.assign({},r,Hn(e.Fn.ORDER,e.Fn.BITS))})}function Uc(r){let{CURVE:t,curveOpts:e,hash:n,ecdsaOpts:s}=Dh(r),o=Th(t,e),i=Lh(o,n,s);return Kh(r,i)}function Tc(r,t){let e=n=>Uc({...r,hash:n});return{...e(t),create:e}}var mi={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Vh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var _c=BigInt(2);function Hh(r){let t=mi.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,h=l*l*r%t,u=Z(h,e,t)*h%t,f=Z(u,e,t)*h%t,d=Z(f,_c,t)*l%t,p=Z(d,s,t)*d%t,w=Z(p,o,t)*p%t,E=Z(w,a,t)*w%t,y=Z(E,c,t)*E%t,A=Z(y,a,t)*w%t,x=Z(A,e,t)*h%t,I=Z(x,i,t)*p%t,D=Z(I,n,t)*l%t,P=Z(D,_c,t);if(!gi.eql(gi.sqr(P),r))throw new Error("Cannot find square root");return P}var gi=kt(mi.p,{sqrt:Hh}),Pt=Tc({...mi,Fp:gi,lowS:!0,endo:Vh},Rn);var Lc=32;function Rc(r,t,e){let n=Xe.digest(t instanceof Uint8Array?t:t.subarray());if(hr(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),Pt.sign(s,r).toDERRawBytes())).catch(s=>{throw s.name==="AbortError"?s:new Cr(String(s))});try{return Pt.sign(n.digest,r).toDERRawBytes()}catch(s){throw new Cr(String(s))}}function Dc(r,t,e,n){let s=Xe.digest(e instanceof Uint8Array?e:e.subarray());if(hr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Pt.verify(t,o,r))).catch(o=>{throw o.name==="AbortError"?o:new Nr(String(o))});try{return n?.signal?.throwIfAborted(),Pt.verify(t,s.digest,r)}catch(o){throw new Nr(String(o))}}var Jn=class{type="secp256k1";raw;_key;constructor(t){this._key=Hc(t),this.raw=Kc(this._key)}toMultihash(){return ke.digest(tr(this))}toCID(){return Ct.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e,n){return Dc(this._key,e,t,n)}},Xn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=Vc(t),this.publicKey=new Jn(e??Oc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t,e){return Rc(this.raw,t,e)}};function bi(r){return new Xn(r)}function Kc(r){return Pt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Vc(r){try{return Pt.getPublicKey(r,!0),r}catch(t){throw new Ur(String(t))}}function Hc(r){try{return Pt.ProjectivePoint.fromHex(r),r}catch(t){throw new je(String(t))}}function Oc(r){try{return Pt.getPublicKey(r,!0)}catch(t){throw new Ur(String(t))}}function tr(r){return Ee.encode({Type:rt[r.type],Data:r.raw})}function Pc(r){let t=Qr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return li(e);case rt.Ed25519:return $o(e);case rt.secp256k1:return bi(e);case rt.ECDSA:return ha(e);default:throw new $e}}function Mc(r){if(r.byteLength===Ut)return $o(r);if(r.byteLength===Lc)return bi(r);let t=_t(r),e=t[2]?.[0];if(e===aa||e===ca||e===ua)return Bo(t);if(t.length>8)return zn(t);throw new L("Could not extract private key from raw bytes")}function Oe(r){return Qr.encode({Type:rt[r.type],Data:r.raw})}function Fc(r,t,e,n){rr(r);let s=xa({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Gt(o),Gt(i),Gt(a),o<1)throw new Error("iterations (c) should be >= 1");let c=Ao(t),l=Ao(e),h=new Uint8Array(i),u=rn.create(r,c),f=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:h,PRF:u,PRFSalt:f}}function qc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),vt(s),e}function jc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Fc(r,t,e,n),l,h=new Uint8Array(4),u=Ne(h),f=new Uint8Array(a.outputLen);for(let d=1,p=0;p<o;d++,p+=a.outputLen){let w=i.subarray(p,p+a.outputLen);u.setInt32(0,d,!1),(l=c._cloneInto(l)).update(h).digestInto(f),w.set(f.subarray(0,w.length));for(let E=1;E<s;E++){a._cloneInto(l).update(f).digestInto(f);for(let y=0;y<w.length;y++)w[y]^=f[y]}}return qc(a,c,i,l,f)}async function Qn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=Fc(r,t,e,n),h,u=new Uint8Array(4),f=Ne(u),d=new Uint8Array(c.outputLen);for(let p=1,w=0;w<o;p++,w+=c.outputLen){let E=a.subarray(w,w+c.outputLen);f.setInt32(0,p,!1),(h=l._cloneInto(h)).update(u).digestInto(d),E.set(d.subarray(0,E.length)),await wa(s-1,i,()=>{c._cloneInto(h).update(d).digestInto(d);for(let y=0;y<E.length;y++)E[y]^=d[y]})}return qc(c,l,a,h,d)}var nn=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),Be=new Uint32Array(80),ts=class extends Te{constructor(){super(64,20,8,!1),this.A=nn[0]|0,this.B=nn[1]|0,this.C=nn[2]|0,this.D=nn[3]|0,this.E=nn[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]=In(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 l,h;c<20?(l=Nn(s,o,i),h=1518500249):c<40?(l=s^o^i,h=1859775393):c<60?(l=Un(s,o,i),h=2400959708):(l=s^o^i,h=3395469782);let u=In(n,5)+l+a+h+Be[c]|0;a=i,i=o,o=In(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(){vt(Be)}destroy(){this.set(0,0,0,0,0),vt(this.buffer)}},$c=Pr(()=>new ts);var Gc=$c;var br=Dn;var Zc={sha1:Gc,"sha2-256":pr,"sha2-512":br};function sn(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Zc).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Zc[s],i=jc(o,r,t,{c:e,dkLen:n});return Ie.encode(i).substring(1)}function wr(r){if(typeof r!="object"||r===null)return!1;let t=Object.getPrototypeOf(r);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in r)&&!(Symbol.iterator in r)}var{hasOwnProperty:Yc}=Object.prototype,{propertyIsEnumerable:Oh}=Object,xr=(r,t,e)=>{Object.defineProperty(r,t,{value:e,writable:!0,enumerable:!0,configurable:!0})},Ph=void 0,zc={concatArrays:!1,ignoreUndefined:!1},es=r=>{let t=[];for(let e in r)Yc.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 vr(r){return Array.isArray(r)?Mh(r):wr(r)?Fh(r):r}function Mh(r){let t=r.slice(0,0);return es(r).forEach(e=>{xr(t,e,vr(r[e]))}),t}function Fh(r){let t=Object.getPrototypeOf(r)===null?Object.create(null):{};return es(r).forEach(e=>{xr(t,e,vr(r[e]))}),t}var Wc=(r,t,e,n)=>(e.forEach(s=>{typeof t[s]>"u"&&n.ignoreUndefined||(s in r&&r[s]!==Object.getPrototypeOf(r)?xr(r,s,wi(r[s],t[s],n)):xr(r,s,vr(t[s])))}),r),qh=(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++)Yc.call(o,a)&&(i.push(String(a)),o===r?xr(n,s++,o[a]):xr(n,s++,vr(o[a])));n=Wc(n,o,es(o).filter(a=>!i.includes(a)),e)}),n};function wi(r,t,e){return e.concatArrays&&Array.isArray(r)&&Array.isArray(t)?qh(r,t,e):!wr(t)||!wr(r)?vr(t):Wc(r,t,es(t),e)}function Jc(...r){let t=wi(vr(zc),this!==Ph&&this||{},zc),e={_:{}};for(let n of r)if(n!==void 0){if(!wr(n))throw new TypeError("`"+n+"` is not an Option Object");e=wi(e,{_:n},t)}return e._}var ne="/",Xc=new TextEncoder().encode(ne),rs=Xc[0],on=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=M(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]!==rs)throw new Error("Invalid key")}toString(t="utf8"){return q(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ne))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=Xc),this._buf[0]!==rs){let t=new Uint8Array(this._buf.byteLength+1);t.fill(rs,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===rs;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(ne).slice(1)}type(){return jh(this.baseNamespace())}name(){return $h(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ne)||(t+=ne),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ne):new r(t.slice(0,-1).join(ne))}child(t){return this.toString()===ne?t:t.toString()===ne?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Gh(t.map(e=>e.namespaces()))])}};function jh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function $h(r){let t=r.split(":");return t[t.length-1]}function Gh(r){return[].concat(...r)}var Ju=_i(au(),1);var Er={};ft(Er,{create:()=>od,derivedEmptyPasswordKey:()=>ns});var ns={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function od(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=Q.get();e*=8;async function c(u,f){let d=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),w={name:t,iv:p};typeof f=="string"&&(f=M(f));let E;if(f.length===0){E=await a.subtle.importKey("jwk",ns,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);E=await a.subtle.deriveKey(A,x,{name:t,length:e},!0,["encrypt"])}catch{E=await a.subtle.importKey("jwk",ns,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);E=await a.subtle.deriveKey(A,x,{name:t,length:e},!0,["encrypt"])}let y=await a.subtle.encrypt(w,E,u);return Je([d,w.iv,new Uint8Array(y)])}async function l(u,f){let d=u.subarray(0,o),p=u.subarray(o,o+n),w=u.subarray(o+n),E={name:t,iv:p};typeof f=="string"&&(f=M(f));let y;if(f.length===0)try{let x={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},I=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(x,I,{name:t,length:e},!0,["decrypt"])}catch{y=await a.subtle.importKey("jwk",ns,{name:"AES-GCM"},!0,["decrypt"])}else{let x={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},I=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);y=await a.subtle.deriveKey(x,I,{name:t,length:e},!0,["decrypt"])}let A=await a.subtle.decrypt(E,y,w);return new Uint8Array(A)}return{encrypt:c,decrypt:l}}var F=_i(cu());function Pe(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Ae(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 l=new Uint8Array(c);for(let h=a-1;h>=0;h--){let u=Math.pow(2,h*t);l[o-h-1]=Math.floor(s/u),s-=l[o-h-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function is(...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 vi(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Pe(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,Pe(o,8)-n}function uu(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=Ae(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ae(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 lu(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 wb=Math.log(2);function as(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ei(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 ue(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 un=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ei(this.items)}},an=[new Uint8Array([1])],fu="0123456789";var Ar="",Kt=new ArrayBuffer(0),Bi=new Uint8Array(0),ln="EndOfContent",du="OCTET STRING",pu="BIT STRING";function le(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}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?F.BufferSourceConverter.toUint8Array(o.valueHex):Bi}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ue(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",Kt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:F.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var oe=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=Ar,warnings:n=[],valueBeforeDecode:s=Bi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=F.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:F.Convert.ToHex(this.valueBeforeDecodeView)}}};oe.NAME="baseBlock";var lt=class extends oe{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'")}};lt.NAME="valueBlock";var cs=class extends le(oe){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?F.BufferSourceConverter.toUint8Array(t.valueHex):Bi,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",Kt}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=Ae(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=F.BufferSourceConverter.toUint8Array(t);if(!ue(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,l=this.valueHexView=new Uint8Array(255),h=255;for(;o[c]&128;){if(l[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===h){h+=255;let f=new Uint8Array(h);for(let d=0;d<l.length;d++)f[d]=l[d];l=this.valueHexView=new Uint8Array(h)}}this.blockLength=c+1,l[c-1]=o[c]&127;let u=new Uint8Array(c);for(let f=0;f<c;f++)u[f]=l[f];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=Pe(l,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}}};cs.NAME="identificationBlock";var us=class extends oe{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=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Pe(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=Ae(this.length,8);if(s.byteLength>127)return this.error="Too big length",Kt;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}}};us.NAME="lengthBlock";var S={},it=class extends oe{constructor({name:t=Ar,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new cs(s),this.lenBlock=new us(s),this.valueBlock=o?new o(s):new lt(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 un;e||yu(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?Kt: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():F.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=F.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${t} : ${e}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return lu(e,n)}};it.NAME="BaseBlock";function yu(r){var t;if(r instanceof S.Constructed)for(let e of r.valueBlock.value)yu(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var ls=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=Ar,...e}={},n){super(e,n),t&&this.fromString(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}'`}};ls.NAME="BaseStringBlock";var fs=class extends le(lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};fs.NAME="PrimitiveValueBlock";var gu,hs=class extends it{constructor(t={}){super(t,fs),this.idBlock.isConstructed=!1}};gu=hs;S.Primitive=gu;hs.NAME="PRIMITIVE";function pd(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 Gs(r,t=0,e=r.length){let n=t,s=new it({},lt),o=new oe;if(!ue(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=it;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let l=s.idBlock.isConstructed?new S.Constructed:new S.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?S.Constructed:S.Primitive}return s=pd(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 Zs(r){if(!r.byteLength){let t=new it({},lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Gs(F.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function yd(r,t){return r?1:t}var Mt=class extends lt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=F.BufferSourceConverter.toUint8Array(t);if(!ue(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(;yd(this.isIndefiniteForm,n)>0;){let i=Gs(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===ln)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===ln?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new un;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Kt: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 mu,Se=class extends it{constructor(t={}){super(t,Mt),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
|
2
|
+
"use strict";var Libp2PKeychain=(()=>{var qu=Object.create;var yn=Object.defineProperty;var $u=Object.getOwnPropertyDescriptor;var ju=Object.getOwnPropertyNames;var Gu=Object.getPrototypeOf,Zu=Object.prototype.hasOwnProperty;var Ar=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),ft=(r,t)=>{for(var e in t)yn(r,e,{get:t[e],enumerable:!0})},ki=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ju(t))!Zu.call(r,s)&&s!==e&&yn(r,s,{get:()=>t[s],enumerable:!(n=$u(t,s))||n.enumerable});return r};var Ii=(r,t,e)=>(e=r!=null?qu(Gu(r)):{},ki(t||!r||!r.__esModule?yn(e,"default",{value:r,enumerable:!0}):e,r)),zu=r=>ki(yn({},"__esModule",{value:!0}),r);var jc=Ar((Gm,$c)=>{"use strict";function Lh(r){return r>=55296&&r<=56319}function Rh(r){return r>=56320&&r<=57343}$c.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],Lh(i)&&Rh(e.charCodeAt(c+1))&&(c+=1,a+=e[c]),o+=t(a),o===n)return e.slice(0,c+1);if(o>n)return e.slice(0,c-a.length+1)}return e}});var Zc=Ar((Zm,Gc)=>{"use strict";function Dh(r){return r>=55296&&r<=56319}function Kh(r){return r>=56320&&r<=57343}Gc.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),Kh(s)?o!=null&&Dh(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 Yc=Ar((zm,zc)=>{"use strict";var Vh=jc(),Hh=Zc();zc.exports=Vh.bind(null,Hh)});var Xc=Ar((Ym,Jc)=>{"use strict";var Oh=Yc(),Mh=/[\/\?<>\\:\*\|"]/g,Ph=/[\x00-\x1f\x80-\x9f]/g,Fh=/^\.+$/,qh=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,$h=/[\. ]+$/;function Wc(r,t){if(typeof r!="string")throw new Error("Input must be string");var e=r.replace(Mh,t).replace(Ph,t).replace(Fh,t).replace(qh,t).replace($h,t);return Oh(e,255)}Jc.exports=function(r,t){var e=t&&t.replacement||"",n=Wc(r,e);return e===""?n:Wc(n,"")}});var Qc=Ar(xr=>{"use strict";var Gh="[object ArrayBuffer]",se=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Gh}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}},yi="string",Zh=/^[0-9a-f\s]+$/i,zh=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Yh=/^[a-zA-Z0-9-_]+$/,ts=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=se.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Tt=class{static toString(t,e=!1){let n=se.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}},es=class r{static isHex(t){return typeof t===yi&&Zh.test(t)}static isBase64(t){return typeof t===yi&&zh.test(t)}static isBase64Url(t){return typeof t===yi&&Yh.test(t)}static ToString(t,e="utf8"){let n=se.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 Tt.toString(n,!0);case"utf16":case"utf16be":return Tt.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 Tt.fromString(t,!0);case"utf16":case"utf16be":return Tt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=se.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 ts.fromString(t);case"utf16":case"utf16be":return Tt.fromString(t);case"utf16le":case"usc2":return Tt.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 ts.toString(t);case"utf16":case"utf16be":return Tt.toString(t);case"utf16le":case"usc2":return Tt.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=se.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=se.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 Tt.toString(t,e)}static FromUtf16String(t,e=!1){return Tt.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,"")||""}};es.DEFAULT_UTF8_ENCODING="utf8";function Wh(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 Jh(...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 Xh(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}xr.BufferSourceConverter=se;xr.Convert=es;xr.assign=Wh;xr.combine=Jh;xr.isEqual=Xh});var gd={};ft(gd,{keychain:()=>pd});var Sr=class extends Error{constructor(t="An error occurred while signing a message"){super(t),this.name="SigningError"}},kr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},mn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Ci={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new mn("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 Q=Ci;var L=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},$e=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}},Ir=class extends Error{static name="InvalidPrivateKeyError";constructor(t="Invalid private key"){super(t),this.name="InvalidPrivateKeyError"}};var bn=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 Ni=Symbol.for("@libp2p/service-capabilities"),Ed=Symbol.for("@libp2p/service-dependencies");var Ws={};ft(Ws,{base58btc:()=>tt,base58flickr:()=>el});var Yd=new Uint8Array(0);function Ui(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function qt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Ti(r){return new TextEncoder().encode(r)}function _i(r){return new TextDecoder().decode(r)}function Yu(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),l=Math.log(a)/Math.log(256),h=Math.log(256)/Math.log(a);function u(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var w=0,B=0,g=0,A=p.length;g!==A&&p[g]===0;)g++,w++;for(var x=(A-g)*h+1>>>0,I=new Uint8Array(x);g!==A;){for(var D=p[g],M=0,O=x-1;(D!==0||M<B)&&O!==-1;O--,M++)D+=256*I[O]>>>0,I[O]=D%a>>>0,D=D/a>>>0;if(D!==0)throw new Error("Non-zero carry");B=M,g++}for(var K=x-B;K!==x&&I[K]===0;)K++;for(var v=c.repeat(w);K<x;++K)v+=r.charAt(I[K]);return v}function f(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var w=0;if(p[w]!==" "){for(var B=0,g=0;p[w]===c;)B++,w++;for(var A=(p.length-w)*l+1>>>0,x=new Uint8Array(A);p[w];){var I=e[p.charCodeAt(w)];if(I===255)return;for(var D=0,M=A-1;(I!==0||D<g)&&M!==-1;M--,D++)I+=a*x[M]>>>0,x[M]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");g=D,w++}if(p[w]!==" "){for(var O=A-g;O!==A&&x[O]===0;)O++;for(var K=new Uint8Array(B+(A-O)),v=B;O!==A;)K[v++]=x[O++];return K}}}function d(p){var w=f(p);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:f,decode:d}}var Wu=Yu,Ju=Wu,Ri=Ju;var Gs=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Zs=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 Di(this,t)}},zs=class{decoders;constructor(t){this.decoders=t}or(t){return Di(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 Di(r,t){return new zs({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ys=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Gs(t,e,n),this.decoder=new Zs(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new Ys(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ri(e,r);return Ge({prefix:t,name:r,encode:n,decode:o=>qt(s(o))})}function Xu(r,t,e,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*e/8|0),i=0,a=0,c=0;for(let l=0;l<s;++l){let h=t[r[l]];if(h===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|h,i+=e,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function Qu(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 tl(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function J({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let s=tl(n);return Ge({prefix:t,name:r,encode(o){return Qu(o,n,e)},decode(o){return Xu(o,s,e,r)}})}var tt=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),el=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Js={};ft(Js,{base32:()=>Ze,base32hex:()=>ol,base32hexpad:()=>al,base32hexpadupper:()=>cl,base32hexupper:()=>il,base32pad:()=>nl,base32padupper:()=>sl,base32upper:()=>rl,base32z:()=>ul});var Ze=J({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),rl=J({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),nl=J({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),sl=J({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ol=J({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),il=J({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),al=J({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),cl=J({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ul=J({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xs={};ft(Xs,{base36:()=>Cr,base36upper:()=>ll});var Cr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ll=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var fl=Hi,Ki=128,hl=127,dl=~hl,pl=Math.pow(2,31);function Hi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=pl;)t[e++]=r&255|Ki,r/=128;for(;r&dl;)t[e++]=r&255|Ki,r>>>=7;return t[e]=r|0,Hi.bytes=e-n+1,t}var gl=Qs,yl=128,Vi=127;function Qs(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Qs.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Vi)<<s:(i&Vi)*Math.pow(2,s),s+=7}while(i>=yl);return Qs.bytes=o-n,e}var ml=Math.pow(2,7),bl=Math.pow(2,14),wl=Math.pow(2,21),xl=Math.pow(2,28),vl=Math.pow(2,35),Bl=Math.pow(2,42),El=Math.pow(2,49),Al=Math.pow(2,56),Sl=Math.pow(2,63),kl=function(r){return r<ml?1:r<bl?2:r<wl?3:r<xl?4:r<vl?5:r<Bl?6:r<El?7:r<Al?8:r<Sl?9:10},Il={encode:fl,decode:gl,encodingLength:kl},Cl=Il,Nr=Cl;function Ur(r,t=0){return[Nr.decode(r,t),Nr.decode.bytes]}function ze(r,t,e=0){return Nr.encode(r,t,e),t}function Ye(r){return Nr.encodingLength(r)}function Vt(r,t){let e=t.byteLength,n=Ye(r),s=n+Ye(e),o=new Uint8Array(s+e);return ze(r,o,0),ze(e,o,n),o.set(t,s),new We(r,e,t,o)}function Oi(r){let t=qt(r),[e,n]=Ur(t),[s,o]=Ur(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new We(e,s,i,t)}function Mi(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ui(r.bytes,e.bytes)}}var We=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Pi(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ul(e,to(r),t??tt.encoder);default:return Tl(e,to(r),t??Ze.encoder)}}var Fi=new WeakMap;function to(r){let t=Fi.get(r);if(t==null){let e=new Map;return Fi.set(r,e),e}return t}var Ct=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!==_r)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==_l)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Vt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Mi(t.multihash,n.multihash)}toString(t){return Pi(this,t)}toJSON(){return{"/":Pi(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??qi(n,s,o.bytes))}else if(e[Ll]===!0){let{version:n,multihash:s,code:o}=e,i=Oi(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!==_r)throw new Error(`Version 0 CID must use dag-pb (code: ${_r}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=qi(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,_r,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=qt(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new We(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,f]=Ur(t.subarray(e));return e+=f,u},s=n(),o=_r;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(),l=e+c,h=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:h,size:l}}static parse(t,e){let[n,s]=Nl(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return to(o).set(n,t),o}};function Nl(r,t){switch(r[0]){case"Q":{let e=t??tt;return[tt.prefix,e.decode(`${tt.prefix}${r}`)]}case tt.prefix:{let e=t??tt;return[tt.prefix,e.decode(r)]}case Ze.prefix:{let e=t??Ze;return[Ze.prefix,e.decode(r)]}case Cr.prefix:{let e=t??Cr;return[Cr.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 Ul(r,t,e){let{prefix:n}=e;if(n!==tt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function Tl(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var _r=112,_l=18;function qi(r,t,e){let n=Ye(r),s=n+Ye(t),o=new Uint8Array(s+e.byteLength);return ze(r,o,0),ze(t,o,n),o.set(e,s),o}var Ll=Symbol.for("@ipld/js-cid/CID");var eo={};ft(eo,{identity:()=>ke});var $i=0,Rl="identity",ji=qt;function Dl(r,t){if(t?.truncate!=null&&t.truncate!==r.byteLength){if(t.truncate<0||t.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t.truncate)}return Vt($i,ji(r))}var ke={code:$i,name:Rl,encode:ji,digest:Dl};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 At(r=0){return new Uint8Array(r)}function Je(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=At(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var Zi=Symbol.for("@achingbrain/uint8arraylist");function Gi(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 xn(r){return!!r?.[Zi]}var ht=class r{bufs;length;[Zi]=!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(xn(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(xn(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=Gi(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Gi(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(xn(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 l=t>=a&&t<c,h=e>a&&e<=c;if(l&&h){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(h){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(!xn(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,l=n.byteLength-1,h;for(let u=e;u<=c;u+=h){h=0;for(let f=l;f>=0;f--){let d=this.get(u+f);if(n[f]!==d){h=Math.max(1,f-a[d]);break}}if(h===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=At(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=At(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 ro={};ft(ro,{base10:()=>Kl});var Kl=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var no={};ft(no,{base16:()=>Vl,base16upper:()=>Hl});var Vl=J({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Hl=J({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var so={};ft(so,{base2:()=>Ol});var Ol=J({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var oo={};ft(oo,{base256emoji:()=>$l});var zi=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}"),Ml=zi.reduce((r,t,e)=>(r[e]=t,r),[]),Pl=zi.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Fl(r){return r.reduce((t,e)=>(t+=Ml[e],t),"")}function ql(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Pl[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var $l=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:Fl,decode:ql});var io={};ft(io,{base64:()=>Ie,base64pad:()=>jl,base64url:()=>Gl,base64urlpad:()=>Zl});var Ie=J({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),jl=J({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Gl=J({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Zl=J({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ao={};ft(ao,{base8:()=>zl});var zl=J({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var co={};ft(co,{identity:()=>Yl});var Yl=Ge({prefix:"\0",name:"identity",encode:r=>_i(r),decode:r=>Ti(r)});var _0=new TextEncoder,L0=new TextDecoder;var fo={};ft(fo,{sha256:()=>Xe,sha512:()=>Ql});var Xl=20;function lo({name:r,code:t,encode:e,minDigestLength:n,maxDigestLength:s}){return new uo(r,t,e,n,s)}var uo=class{name;code;encode;minDigestLength;maxDigestLength;constructor(t,e,n,s,o){this.name=t,this.code=e,this.encode=n,this.minDigestLength=s??Xl,this.maxDigestLength=o}digest(t,e){if(e?.truncate!=null){if(e.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&e.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(t instanceof Uint8Array){let n=this.encode(t);return n instanceof Uint8Array?Yi(n,this.code,e?.truncate):n.then(s=>Yi(s,this.code,e?.truncate))}else throw Error("Unknown type, must be binary type")}};function Yi(r,t,e){if(e!=null&&e!==r.byteLength){if(e>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e)}return Vt(t,r)}function Ji(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Xe=lo({name:"sha2-256",code:18,encode:Ji("SHA-256")}),Ql=lo({name:"sha2-512",code:19,encode:Ji("SHA-512")});var ho={...co,...so,...ao,...ro,...no,...Js,...Xs,...Ws,...io,...oo},j0={...fo,...eo};function Qi(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Xi=Qi("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),po=Qi("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=At(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),tf={utf8:Xi,"utf-8":Xi,hex:ho.base16,latin1:po,ascii:po,binary:po,...ho},vn=tf;function P(r,t="utf8"){let e=vn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=vn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var ef=parseInt("11111",2),go=parseInt("10000000",2),rf=parseInt("01111111",2),ta={0:Lr,1:Lr,2:nf,3:af,4:cf,5:of,6:sf,16:Lr,22:Lr,48:Lr};function _t(r,t={offset:0}){let e=r[t.offset]&ef;if(t.offset++,ta[e]!=null)return ta[e](r,t);throw new Error("No decoder for tag "+e)}function Rr(r,t){let e=0;if((r[t.offset]&go)===go){let n=r[t.offset]&rf,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 Lr(r,t){Rr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=_t(r,t);if(n===null)break;e.push(n)}return e}function nf(r,t){let e=Rr(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 sf(r,t){let e=Rr(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 l=r[t.offset];if(t.offset++,c.push(l&127),l<128){c.reverse();let h=0;for(let u=0;u<c.length;u++)h+=c[u]<<u*7;a+=`.${h}`,c=[]}}return a}function of(r,t){return t.offset++,null}function af(r,t){let e=Rr(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 cf(r,t){let e=Rr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function uf(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new ht;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Bn(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=uf(r.byteLength);return new ht(Uint8Array.from([t.byteLength|go]),t)}function dt(r){let t=new ht,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new ht(Uint8Array.from([2]),Bn(t),t)}function Dr(r){let t=Uint8Array.from([0]),e=new ht(t,r);return new ht(Uint8Array.from([3]),Bn(e),e)}function ea(r){return new ht(Uint8Array.from([4]),Bn(r),r)}function Lt(r,t=48){let e=new ht;for(let n of r)e.append(n);return new ht(Uint8Array.from([t]),Bn(e),e)}var ra="1.2.840.10045.3.1.7",na="1.3.132.0.34",sa="1.3.132.0.35";async function oa(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);e?.signal?.throwIfAborted();let s=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function ia(r,t,e,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,t,e.subarray());return n?.signal?.throwIfAborted(),o}var lf=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),ff=Uint8Array.from([6,5,43,129,4,0,34]),hf=Uint8Array.from([6,5,43,129,4,0,35]),df={ext:!0,kty:"EC",crv:"P-256"},pf={ext:!0,kty:"EC",crv:"P-384"},gf={ext:!0,kty:"EC",crv:"P-521"},yo=32,mo=48,bo=66;function aa(r){let t=_t(r);return wo(t)}function wo(r){let t=r[1],e=q(t,"base64url"),n=r[2][1][0],s=1,o,i;if(t.byteLength===yo)return o=q(n.subarray(s,s+yo),"base64url"),i=q(n.subarray(s+yo),"base64url"),new Qe({...df,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===mo)return o=q(n.subarray(s,s+mo),"base64url"),i=q(n.subarray(s+mo),"base64url"),new Qe({...pf,key_ops:["sign"],d:e,x:o,y:i});if(t.byteLength===bo)return o=q(n.subarray(s,s+bo),"base64url"),i=q(n.subarray(s+bo),"base64url"),new Qe({...gf,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 ca(r){return Lt([dt(Uint8Array.from([1])),ea(P(r.d??"","base64url")),Lt([la(r.crv)],160),Lt([Dr(new ht(Uint8Array.from([4]),P(r.x??"","base64url"),P(r.y??"","base64url")))],161)]).subarray()}function ua(r){return Lt([dt(Uint8Array.from([1])),Lt([la(r.crv)],160),Lt([Dr(new ht(Uint8Array.from([4]),P(r.x??"","base64url"),P(r.y??"","base64url")))],161)]).subarray()}function la(r){if(r==="P-256")return lf;if(r==="P-384")return ff;if(r==="P-521")return hf;throw new L(`Invalid curve ${r}`)}var En=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ua(this.jwk)),this._raw}toMultihash(){return ke.digest(tr(this))}toCID(){return Ct.createV1(114,this.toMultihash())}toString(){return tt.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,n){return ia(this.jwk,e,t,n)}},Qe=class{type="ECDSA";jwk;publicKey;_raw;constructor(t){this.jwk=t,this.publicKey=new En({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=ca(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}async sign(t,e){return oa(this.jwk,t,e)}};var Ce=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Zt(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Gt(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function pt(r,...t){if(!Zt(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 rr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Gt(r.outputLen),Gt(r.blockLen)}function nr(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 ha(r,t){pt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function vt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Ne(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Rt(r,t){return r<<32-t|r>>>t}function An(r,t){return r<<t|r>>>32-t>>>0}var da=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",yf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Nt(r){if(pt(r),da)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=yf[r[e]];return t}var jt={_0:48,_9:57,A:65,F:70,a:97,f:102};function fa(r){if(r>=jt._0&&r<=jt._9)return r-jt._0;if(r>=jt.A&&r<=jt.F)return r-(jt.A-10);if(r>=jt.a&&r<=jt.f)return r-(jt.a-10)}function Ue(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(da)return Uint8Array.fromHex(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=fa(r.charCodeAt(o)),a=fa(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}var mf=async()=>{};async function pa(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 mf(),n+=o)}}function Sn(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Kr(r){return typeof r=="string"&&(r=Sn(r)),pt(r),r}function xo(r){return typeof r=="string"&&(r=Sn(r)),pt(r),r}function gt(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];pt(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 ga(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)}var er=class{};function Vr(r){let t=n=>r().update(Kr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function he(r=32){if(Ce&&typeof Ce.getRandomValues=="function")return Ce.getRandomValues(new Uint8Array(r));if(Ce&&typeof Ce.randomBytes=="function")return Uint8Array.from(Ce.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function bf(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,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function kn(r,t,e){return r&t^~r&e}function In(r,t,e){return r&t^r&e^t&e}var Te=class extends er{constructor(t,e,n,s){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(t),this.view=Ne(this.buffer)}update(t){nr(this),t=Kr(t),pt(t);let{view:e,buffer:n,blockLen:s}=this,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){nr(this),ha(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,vt(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let u=i;u<s;u++)e[u]=0;bf(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 l=c/4,h=this.get();if(l>h.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,h[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.destroyed=i,t.finished=o,t.length=s,t.pos=a,s%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},zt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ot=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Cn=BigInt(4294967295),ya=BigInt(32);function wf(r,t=!1){return t?{h:Number(r&Cn),l:Number(r>>ya&Cn)}:{h:Number(r>>ya&Cn)|0,l:Number(r&Cn)|0}}function ma(r,t=!1){let e=r.length,n=new Uint32Array(e),s=new Uint32Array(e);for(let o=0;o<e;o++){let{h:i,l:a}=wf(r[o],t);[n[o],s[o]]=[i,a]}return[n,s]}var vo=(r,t,e)=>r>>>e,Bo=(r,t,e)=>r<<32-e|t>>>e,_e=(r,t,e)=>r>>>e|t<<32-e,Le=(r,t,e)=>r<<32-e|t>>>e,Hr=(r,t,e)=>r<<64-e|t>>>e-32,Or=(r,t,e)=>r>>>e-32|t<<64-e;function Ht(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var ba=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),wa=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,xa=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),va=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Ba=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Ea=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var vf=Uint32Array.from([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]),de=new Uint32Array(64),Nn=class extends Te{constructor(t=32){super(64,t,8,!1),this.A=zt[0]|0,this.B=zt[1]|0,this.C=zt[2]|0,this.D=zt[3]|0,this.E=zt[4]|0,this.F=zt[5]|0,this.G=zt[6]|0,this.H=zt[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)de[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let f=de[u-15],d=de[u-2],p=Rt(f,7)^Rt(f,18)^f>>>3,w=Rt(d,17)^Rt(d,19)^d>>>10;de[u]=w+de[u-7]+p+de[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:h}=this;for(let u=0;u<64;u++){let f=Rt(a,6)^Rt(a,11)^Rt(a,25),d=h+f+kn(a,c,l)+vf[u]+de[u]|0,w=(Rt(n,2)^Rt(n,13)^Rt(n,22))+In(n,s,o)|0;h=l,l=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+w|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,l=l+this.G|0,h=h+this.H|0,this.set(n,s,o,i,a,c,l,h)}roundClean(){vt(de)}destroy(){this.set(0,0,0,0,0,0,0,0),vt(this.buffer)}};var Aa=ma(["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))),Bf=Aa[0],Ef=Aa[1],pe=new Uint32Array(80),ge=new Uint32Array(80),Un=class extends Te{constructor(t=64){super(128,t,16,!1),this.Ah=ot[0]|0,this.Al=ot[1]|0,this.Bh=ot[2]|0,this.Bl=ot[3]|0,this.Ch=ot[4]|0,this.Cl=ot[5]|0,this.Dh=ot[6]|0,this.Dl=ot[7]|0,this.Eh=ot[8]|0,this.El=ot[9]|0,this.Fh=ot[10]|0,this.Fl=ot[11]|0,this.Gh=ot[12]|0,this.Gl=ot[13]|0,this.Hh=ot[14]|0,this.Hl=ot[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:l,El:h,Fh:u,Fl:f,Gh:d,Gl:p,Hh:w,Hl:B}=this;return[t,e,n,s,o,i,a,c,l,h,u,f,d,p,w,B]}set(t,e,n,s,o,i,a,c,l,h,u,f,d,p,w,B){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=l|0,this.El=h|0,this.Fh=u|0,this.Fl=f|0,this.Gh=d|0,this.Gl=p|0,this.Hh=w|0,this.Hl=B|0}process(t,e){for(let x=0;x<16;x++,e+=4)pe[x]=t.getUint32(e),ge[x]=t.getUint32(e+=4);for(let x=16;x<80;x++){let I=pe[x-15]|0,D=ge[x-15]|0,M=_e(I,D,1)^_e(I,D,8)^vo(I,D,7),O=Le(I,D,1)^Le(I,D,8)^Bo(I,D,7),K=pe[x-2]|0,v=ge[x-2]|0,U=_e(K,v,19)^Hr(K,v,61)^vo(K,v,6),V=Le(K,v,19)^Or(K,v,61)^Bo(K,v,6),T=xa(O,V,ge[x-7],ge[x-16]),b=va(T,M,U,pe[x-7],pe[x-16]);pe[x]=b|0,ge[x]=T|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:h,Eh:u,El:f,Fh:d,Fl:p,Gh:w,Gl:B,Hh:g,Hl:A}=this;for(let x=0;x<80;x++){let I=_e(u,f,14)^_e(u,f,18)^Hr(u,f,41),D=Le(u,f,14)^Le(u,f,18)^Or(u,f,41),M=u&d^~u&w,O=f&p^~f&B,K=Ba(A,D,O,Ef[x],ge[x]),v=Ea(K,g,I,M,Bf[x],pe[x]),U=K|0,V=_e(n,s,28)^Hr(n,s,34)^Hr(n,s,39),T=Le(n,s,28)^Or(n,s,34)^Or(n,s,39),b=n&o^n&a^o&a,y=s&i^s&c^i&c;g=w|0,A=B|0,w=d|0,B=p|0,d=u|0,p=f|0,{h:u,l:f}=Ht(l|0,h|0,v|0,U|0),l=a|0,h=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let m=ba(U,T,y);n=wa(m,v,V,b),s=m|0}({h:n,l:s}=Ht(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Ht(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Ht(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:h}=Ht(this.Dh|0,this.Dl|0,l|0,h|0),{h:u,l:f}=Ht(this.Eh|0,this.El|0,u|0,f|0),{h:d,l:p}=Ht(this.Fh|0,this.Fl|0,d|0,p|0),{h:w,l:B}=Ht(this.Gh|0,this.Gl|0,w|0,B|0),{h:g,l:A}=Ht(this.Hh|0,this.Hl|0,g|0,A|0),this.set(n,s,o,i,a,c,l,h,u,f,d,p,w,B,g,A)}roundClean(){vt(pe,ge)}destroy(){vt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Tn=Vr(()=>new Nn);var _n=Vr(()=>new Un);var So=BigInt(0),Ao=BigInt(1);function Yt(r,t=""){if(typeof r!="boolean"){let e=t&&`"${t}"`;throw new Error(e+"expected boolean, got type="+typeof r)}return r}function St(r,t,e=""){let n=Zt(r),s=r?.length,o=t!==void 0;if(!n||o&&s!==t){let i=e&&`"${e}" `,a=o?` of length ${t}`:"",c=n?`length=${s}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function Mr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Sa(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?So:BigInt("0x"+r)}function sr(r){return Sa(Nt(r))}function Wt(r){return pt(r),Sa(Nt(Uint8Array.from(r).reverse()))}function Ln(r,t){return Ue(r.toString(16).padStart(t*2,"0"))}function ko(r,t){return Ln(r,t).reverse()}function j(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(Zt(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 ka(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 Io(r){return Uint8Array.from(r)}var Eo=r=>typeof r=="bigint"&&So<=r;function Ia(r,t,e){return Eo(r)&&Eo(t)&&Eo(e)&&t<=r&&r<e}function Pr(r,t,e,n){if(!Ia(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Rn(r){let t;for(t=0;r>So;r>>=Ao,t+=1);return t}var ye=r=>(Ao<<BigInt(r))-Ao;function Ca(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=d=>new Uint8Array(d),s=d=>Uint8Array.of(d),o=n(r),i=n(r),a=0,c=()=>{o.fill(1),i.fill(0),a=0},l=(...d)=>e(i,o,...d),h=(d=n(0))=>{i=l(s(0),d),o=l(),d.length!==0&&(i=l(s(1),d),o=l())},u=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let d=0,p=[];for(;d<t;){o=l();let w=o.slice();p.push(w),d+=o.length}return gt(...p)};return(d,p)=>{c(),h(d);let w;for(;!(w=p(u()));)h();return c(),w}}function me(r,t,e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(s,o,i){let a=r[s];if(i&&a===void 0)return;let c=typeof a;if(c!==o||a===null)throw new Error(`param "${s}" is invalid: expected ${o}, got ${c}`)}Object.entries(t).forEach(([s,o])=>n(s,o,!1)),Object.entries(e).forEach(([s,o])=>n(s,o,!0))}var Co=()=>{throw new Error("not implemented")};function or(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 yt=BigInt(0),nt=BigInt(1),Re=BigInt(2),Ta=BigInt(3),_a=BigInt(4),La=BigInt(5),Af=BigInt(7),Ra=BigInt(8),Sf=BigInt(9),Da=BigInt(16);function X(r,t){let e=r%t;return e>=yt?e:t+e}function Z(r,t,e){let n=r;for(;t-- >yt;)n*=n,n%=e;return n}function Na(r,t){if(r===yt)throw new Error("invert: expected non-zero number");if(t<=yt)throw new Error("invert: expected positive modulus, got "+t);let e=X(r,t),n=t,s=yt,o=nt,i=nt,a=yt;for(;e!==yt;){let l=n/e,h=n%e,u=s-i*l,f=o-a*l;n=e,e=h,s=i,o=a,i=u,a=f}if(n!==nt)throw new Error("invert: does not exist");return X(s,t)}function No(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function Ka(r,t){let e=(r.ORDER+nt)/_a,n=r.pow(t,e);return No(r,n,t),n}function kf(r,t){let e=(r.ORDER-La)/Ra,n=r.mul(t,Re),s=r.pow(n,e),o=r.mul(t,s),i=r.mul(r.mul(o,Re),s),a=r.mul(o,r.sub(i,r.ONE));return No(r,a,t),a}function If(r){let t=kt(r),e=Va(r),n=e(t,t.neg(t.ONE)),s=e(t,n),o=e(t,t.neg(n)),i=(r+Af)/Da;return(a,c)=>{let l=a.pow(c,i),h=a.mul(l,n),u=a.mul(l,s),f=a.mul(l,o),d=a.eql(a.sqr(h),c),p=a.eql(a.sqr(u),c);l=a.cmov(l,h,d),h=a.cmov(f,u,p);let w=a.eql(a.sqr(h),c),B=a.cmov(l,h,w);return No(a,B,c),B}}function Va(r){if(r<Ta)throw new Error("sqrt is not defined for small field");let t=r-nt,e=0;for(;t%Re===yt;)t/=Re,e++;let n=Re,s=kt(r);for(;Ua(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Ka;let o=s.pow(n,t),i=(t+nt)/Re;return function(c,l){if(c.is0(l))return l;if(Ua(c,l)!==1)throw new Error("Cannot find square root");let h=e,u=c.mul(c.ONE,o),f=c.pow(l,t),d=c.pow(l,i);for(;!c.eql(f,c.ONE);){if(c.is0(f))return c.ZERO;let p=1,w=c.sqr(f);for(;!c.eql(w,c.ONE);)if(p++,w=c.sqr(w),p===h)throw new Error("Cannot find square root");let B=nt<<BigInt(h-p-1),g=c.pow(u,B);h=p,u=c.sqr(g),f=c.mul(f,u),d=c.mul(d,g)}return d}}function Cf(r){return r%_a===Ta?Ka:r%Ra===La?kf:r%Da===Sf?If(r):Va(r)}var Jt=(r,t)=>(X(r,t)&nt)===nt,Nf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Uo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},e=Nf.reduce((n,s)=>(n[s]="function",n),t);return me(r,e),r}function Uf(r,t,e){if(e<yt)throw new Error("invalid exponent, negatives unsupported");if(e===yt)return r.ONE;if(e===nt)return t;let n=r.ONE,s=t;for(;e>yt;)e&nt&&(n=r.mul(n,s)),s=r.sqr(s),e>>=nt;return n}function Fr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),s=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),o=r.inv(s);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),o),n}function Ua(r,t){let e=(r.ORDER-nt)/Re,n=r.pow(t,e),s=r.eql(n,r.ONE),o=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!s&&!o&&!i)throw new Error("invalid Legendre symbol result");return s?1:o?0:-1}function Dn(r,t){t!==void 0&&Gt(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function kt(r,t,e=!1,n={}){if(r<=yt)throw new Error("invalid field: expected ORDER > 0, got "+r);let s,o,i=!1,a;if(typeof t=="object"&&t!=null){if(n.sqrt||e)throw new Error("cannot specify opts in two arguments");let f=t;f.BITS&&(s=f.BITS),f.sqrt&&(o=f.sqrt),typeof f.isLE=="boolean"&&(e=f.isLE),typeof f.modFromBytes=="boolean"&&(i=f.modFromBytes),a=f.allowedLengths}else typeof t=="number"&&(s=t),n.sqrt&&(o=n.sqrt);let{nBitLength:c,nByteLength:l}=Dn(r,s);if(l>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let h,u=Object.freeze({ORDER:r,isLE:e,BITS:c,BYTES:l,MASK:ye(c),ZERO:yt,ONE:nt,allowedLengths:a,create:f=>X(f,r),isValid:f=>{if(typeof f!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof f);return yt<=f&&f<r},is0:f=>f===yt,isValidNot0:f=>!u.is0(f)&&u.isValid(f),isOdd:f=>(f&nt)===nt,neg:f=>X(-f,r),eql:(f,d)=>f===d,sqr:f=>X(f*f,r),add:(f,d)=>X(f+d,r),sub:(f,d)=>X(f-d,r),mul:(f,d)=>X(f*d,r),pow:(f,d)=>Uf(u,f,d),div:(f,d)=>X(f*Na(d,r),r),sqrN:f=>f*f,addN:(f,d)=>f+d,subN:(f,d)=>f-d,mulN:(f,d)=>f*d,inv:f=>Na(f,r),sqrt:o||(f=>(h||(h=Cf(r)),h(u,f))),toBytes:f=>e?ko(f,l):Ln(f,l),fromBytes:(f,d=!0)=>{if(a){if(!a.includes(f.length)||f.length>l)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+f.length);let w=new Uint8Array(l);w.set(f,e?0:w.length-f.length),f=w}if(f.length!==l)throw new Error("Field.fromBytes: expected "+l+" bytes, got "+f.length);let p=e?Wt(f):sr(f);if(i&&(p=X(p,r)),!d&&!u.isValid(p))throw new Error("invalid field element: outside of range 0..ORDER");return p},invertBatch:f=>Fr(u,f),cmov:(f,d,p)=>p?d:f});return Object.freeze(u)}function Ha(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 To(r){let t=Ha(r);return t+Math.ceil(t/2)}function _o(r,t,e=!1){let n=r.length,s=Ha(t),o=To(t);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=e?Wt(r):sr(r),a=X(i,t-nt)+nt;return e?ko(a,s):Ln(a,s)}var ir=BigInt(0),De=BigInt(1);function qr(r,t){let e=t.negate();return r?e:t}function Xt(r,t){let e=Fr(r.Fp,t.map(n=>n.Z));return t.map((n,s)=>r.fromAffine(n.toAffine(e[s])))}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 Lo(r,t){Fa(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),s=2**r,o=ye(r),i=BigInt(r);return{windows:e,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Oa(r,t,e){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=e,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=De);let l=t*n,h=l+Math.abs(a)-1,u=a===0,f=a<0,d=t%2!==0;return{nextN:c,offset:h,isZero:u,isNeg:f,isNegF:d,offsetF:l}}function Tf(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 Ro=new WeakMap,qa=new WeakMap;function Do(r){return qa.get(r)||1}function Ma(r){if(r!==ir)throw new Error("invalid wNAF")}var ar=class{constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let s=t;for(;e>ir;)e&De&&(n=n.add(s)),s=s.double(),e>>=De;return n}precomputeWindow(t,e){let{windows:n,windowSize:s}=Lo(e,this.bits),o=[],i=t,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let l=1;l<s;l++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=Lo(t,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:l,isZero:h,isNeg:u,isNegF:f,offsetF:d}=Oa(n,a,i);n=c,h?o=o.add(qr(f,e[d])):s=s.add(qr(u,e[l]))}return Ma(n),{p:s,f:o}}wNAFUnsafe(t,e,n,s=this.ZERO){let o=Lo(t,this.bits);for(let i=0;i<o.windows&&n!==ir;i++){let{nextN:a,offset:c,isZero:l,isNeg:h}=Oa(n,i,o);if(n=a,!l){let u=e[c];s=s.add(h?u.negate():u)}}return Ma(n),s}getPrecomputes(t,e,n){let s=Ro.get(e);return s||(s=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(s=n(s)),Ro.set(e,s))),s}cached(t,e,n){let s=Do(t);return this.wNAF(s,this.getPrecomputes(s,t,n),e)}unsafe(t,e,n,s){let o=Do(t);return o===1?this._unsafeLadder(t,e,s):this.wNAFUnsafe(o,this.getPrecomputes(o,t,n),e,s)}createCache(t,e){Fa(e,this.bits),qa.set(t,e),Ro.delete(t)}hasCache(t){return Do(t)!==1}};function $a(r,t,e,n){let s=t,o=r.ZERO,i=r.ZERO;for(;e>ir||n>ir;)e&De&&(o=o.add(s)),n&De&&(i=i.add(s)),s=s.double(),e>>=De,n>>=De;return{p1:o,p2:i}}function cr(r,t,e,n){Tf(e,r),_f(n,t);let s=e.length,o=n.length;if(s!==o)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=Rn(BigInt(s)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let l=ye(c),h=new Array(Number(l)+1).fill(i),u=Math.floor((t.BITS-1)/c)*c,f=i;for(let d=u;d>=0;d-=c){h.fill(i);for(let w=0;w<o;w++){let B=n[w],g=Number(B>>BigInt(d)&l);h[g]=h[g].add(e[w])}let p=i;for(let w=h.length-1,B=i;w>0;w--)B=B.add(h[w]),p=p.add(B);if(f=f.add(p),d!==0)for(let w=0;w<c;w++)f=f.double()}return f}function Pa(r,t,e){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Uo(t),t}else return kt(r,{isLE:e})}function Kn(r,t,e={},n){if(n===void 0&&(n=r==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let l=t[c];if(!(typeof l=="bigint"&&l>ir))throw new Error(`CURVE.${c} must be positive bigint`)}let s=Pa(t.p,e.Fp,n),o=Pa(t.n,e.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!s.isValid(t[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:s,Fn:o}}var be=BigInt(0),st=BigInt(1),Ko=BigInt(2),Lf=BigInt(8);function Rf(r,t,e,n){let s=r.sqr(e),o=r.sqr(n),i=r.add(r.mul(t.a,s),o),a=r.add(r.ONE,r.mul(t.d,r.mul(s,o)));return r.eql(i,a)}function Df(r,t={}){let e=Kn("edwards",r,t,t.FpFnLE),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i}=o;me(t,{},{uvRatio:"function"});let a=Ko<<BigInt(s.BYTES*8)-st,c=B=>n.create(B),l=t.uvRatio||((B,g)=>{try{return{isValid:!0,value:n.sqrt(n.div(B,g))}}catch{return{isValid:!1,value:be}}});if(!Rf(n,o,o.Gx,o.Gy))throw new Error("bad curve params: generator point");function h(B,g,A=!1){let x=A?st:be;return Pr("coordinate "+B,g,x,a),g}function u(B){if(!(B instanceof p))throw new Error("ExtendedPoint expected")}let f=or((B,g)=>{let{X:A,Y:x,Z:I}=B,D=B.is0();g==null&&(g=D?Lf:n.inv(I));let M=c(A*g),O=c(x*g),K=n.mul(I,g);if(D)return{x:be,y:st};if(K!==st)throw new Error("invZ was invalid");return{x:M,y:O}}),d=or(B=>{let{a:g,d:A}=o;if(B.is0())throw new Error("bad point: ZERO");let{X:x,Y:I,Z:D,T:M}=B,O=c(x*x),K=c(I*I),v=c(D*D),U=c(v*v),V=c(O*g),T=c(v*c(V+K)),b=c(U+c(A*c(O*K)));if(T!==b)throw new Error("bad point: equation left != right (1)");let y=c(x*I),m=c(D*M);if(y!==m)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(g,A,x,I){this.X=h("x",g),this.Y=h("y",A),this.Z=h("z",x,!0),this.T=h("t",I),Object.freeze(this)}static CURVE(){return o}static fromAffine(g){if(g instanceof p)throw new Error("extended point not allowed");let{x:A,y:x}=g||{};return h("x",A),h("y",x),new p(A,x,st,c(A*x))}static fromBytes(g,A=!1){let x=n.BYTES,{a:I,d:D}=o;g=Io(St(g,x,"point")),Yt(A,"zip215");let M=Io(g),O=g[x-1];M[x-1]=O&-129;let K=Wt(M),v=A?a:n.ORDER;Pr("point.y",K,be,v);let U=c(K*K),V=c(U-st),T=c(D*U-I),{isValid:b,value:y}=l(V,T);if(!b)throw new Error("bad point: invalid y coordinate");let m=(y&st)===st,E=(O&128)!==0;if(!A&&y===be&&E)throw new Error("bad point: x=0 and x_0=1");return E!==m&&(y=c(-y)),p.fromAffine({x:y,y:K})}static fromHex(g,A=!1){return p.fromBytes(j("point",g),A)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(g=8,A=!0){return w.createCache(this,g),A||this.multiply(Ko),this}assertValidity(){d(this)}equals(g){u(g);let{X:A,Y:x,Z:I}=this,{X:D,Y:M,Z:O}=g,K=c(A*O),v=c(D*I),U=c(x*O),V=c(M*I);return K===v&&U===V}is0(){return this.equals(p.ZERO)}negate(){return new p(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:g}=o,{X:A,Y:x,Z:I}=this,D=c(A*A),M=c(x*x),O=c(Ko*c(I*I)),K=c(g*D),v=A+x,U=c(c(v*v)-D-M),V=K+M,T=V-O,b=K-M,y=c(U*T),m=c(V*b),E=c(U*b),k=c(T*V);return new p(y,m,k,E)}add(g){u(g);let{a:A,d:x}=o,{X:I,Y:D,Z:M,T:O}=this,{X:K,Y:v,Z:U,T:V}=g,T=c(I*K),b=c(D*v),y=c(O*x*V),m=c(M*U),E=c((I+D)*(K+v)-T-b),k=m-y,_=m+y,C=c(b-A*T),N=c(E*k),R=c(_*C),H=c(E*C),z=c(k*_);return new p(N,R,z,H)}subtract(g){return this.add(g.negate())}multiply(g){if(!s.isValidNot0(g))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:A,f:x}=w.cached(this,g,I=>Xt(p,I));return Xt(p,[A,x])[0]}multiplyUnsafe(g,A=p.ZERO){if(!s.isValid(g))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return g===be?p.ZERO:this.is0()||g===st?this:w.unsafe(this,g,x=>Xt(p,x),A)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return w.unsafe(this,o.n).is0()}toAffine(g){return f(this,g)}clearCofactor(){return i===st?this:this.multiplyUnsafe(i)}toBytes(){let{x:g,y:A}=this.toAffine(),x=n.toBytes(A);return x[x.length-1]|=g&st?128:0,x}toHex(){return Nt(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get ex(){return this.X}get ey(){return this.Y}get ez(){return this.Z}get et(){return this.T}static normalizeZ(g){return Xt(p,g)}static msm(g,A){return cr(p,s,g,A)}_setWindowSize(g){this.precompute(g)}toRawBytes(){return this.toBytes()}}p.BASE=new p(o.Gx,o.Gy,st,c(o.Gx*o.Gy)),p.ZERO=new p(be,st,st,be),p.Fp=n,p.Fn=s;let w=new ar(p,s.BITS);return p.BASE.precompute(8),p}var Vn=class{constructor(t){this.ep=t}static fromBytes(t){Co()}static fromHex(t){Co()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(t){return this.ep.toAffine(t)}toHex(){return Nt(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(t){return this.assertSame(t),this.init(this.ep.add(t.ep))}subtract(t){return this.assertSame(t),this.init(this.ep.subtract(t.ep))}multiply(t){return this.init(this.ep.multiply(t))}multiplyUnsafe(t){return this.init(this.ep.multiplyUnsafe(t))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(t,e){return this.init(this.ep.precompute(t,e))}toRawBytes(){return this.toBytes()}};function Kf(r,t,e={}){if(typeof t!="function")throw new Error('"hash" function param is required');me(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:s,Fp:o,Fn:i}=r,a=e.randomBytes||he,c=e.adjustScalarBytes||(v=>v),l=e.domain||((v,U,V)=>{if(Yt(V,"phflag"),U.length||V)throw new Error("Contexts/pre-hash are not supported");return v});function h(v){return i.create(Wt(v))}function u(v){let U=x.secretKey;v=j("private key",v,U);let V=j("hashed private key",t(v),2*U),T=c(V.slice(0,U)),b=V.slice(U,2*U),y=h(T);return{head:T,prefix:b,scalar:y}}function f(v){let{head:U,prefix:V,scalar:T}=u(v),b=s.multiply(T),y=b.toBytes();return{head:U,prefix:V,scalar:T,point:b,pointBytes:y}}function d(v){return f(v).pointBytes}function p(v=Uint8Array.of(),...U){let V=gt(...U);return h(t(l(V,j("context",v),!!n)))}function w(v,U,V={}){v=j("message",v),n&&(v=n(v));let{prefix:T,scalar:b,pointBytes:y}=f(U),m=p(V.context,T,v),E=s.multiply(m).toBytes(),k=p(V.context,E,y,v),_=i.create(m+k*b);if(!i.isValid(_))throw new Error("sign failed: invalid s");let C=gt(E,i.toBytes(_));return St(C,x.signature,"result")}let B={zip215:!0};function g(v,U,V,T=B){let{context:b,zip215:y}=T,m=x.signature;v=j("signature",v,m),U=j("message",U),V=j("publicKey",V,x.publicKey),y!==void 0&&Yt(y,"zip215"),n&&(U=n(U));let E=m/2,k=v.subarray(0,E),_=Wt(v.subarray(E,m)),C,N,R;try{C=r.fromBytes(V,y),N=r.fromBytes(k,y),R=s.multiplyUnsafe(_)}catch{return!1}if(!y&&C.isSmallOrder())return!1;let H=p(b,N.toBytes(),C.toBytes(),U);return N.add(C.multiplyUnsafe(H)).subtract(R).clearCofactor().is0()}let A=o.BYTES,x={secretKey:A,publicKey:A,signature:2*A,seed:A};function I(v=a(x.seed)){return St(v,x.seed,"seed")}function D(v){let U=K.randomSecretKey(v);return{secretKey:U,publicKey:d(U)}}function M(v){return Zt(v)&&v.length===i.BYTES}function O(v,U){try{return!!r.fromBytes(v,U)}catch{return!1}}let K={getExtendedPublicKey:f,randomSecretKey:I,isValidSecretKey:M,isValidPublicKey:O,toMontgomery(v){let{y:U}=r.fromBytes(v),V=x.publicKey,T=V===32;if(!T&&V!==57)throw new Error("only defined for 25519 and 448");let b=T?o.div(st+U,st-U):o.div(U-st,U+st);return o.toBytes(b)},toMontgomerySecret(v){let U=x.secretKey;St(v,U);let V=t(v.subarray(0,U));return c(V).subarray(0,U)},randomPrivateKey:I,precompute(v=8,U=r.BASE){return U.precompute(v,!1)}};return Object.freeze({keygen:D,getPublicKey:d,sign:w,verify:g,utils:K,Point:r,lengths:x})}function Vf(r){let t={a:r.a,d:r.d,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=kt(t.n,r.nBitLength,!0),s={Fp:e,Fn:n,uvRatio:r.uvRatio},o={randomBytes:r.randomBytes,adjustScalarBytes:r.adjustScalarBytes,domain:r.domain,prehash:r.prehash,mapToCurve:r.mapToCurve};return{CURVE:t,curveOpts:s,hash:r.hash,eddsaOpts:o}}function Hf(r,t){let e=t.Point;return Object.assign({},t,{ExtendedPoint:e,CURVE:r,nBitLength:e.Fn.BITS,nByteLength:e.Fn.BYTES})}function ja(r){let{CURVE:t,curveOpts:e,hash:n,eddsaOpts:s}=Vf(r),o=Df(t,e),i=Kf(o,n,s);return Hf(r,i)}var Of=BigInt(0),Qt=BigInt(1),Ga=BigInt(2),Yp=BigInt(3),Mf=BigInt(5),Pf=BigInt(8),ur=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),$r={p:ur,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Pf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Ff(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=ur,a=r*r%o*r%o,c=Z(a,Ga,o)*a%o,l=Z(c,Qt,o)*r%o,h=Z(l,Mf,o)*l%o,u=Z(h,t,o)*h%o,f=Z(u,e,o)*u%o,d=Z(f,n,o)*f%o,p=Z(d,s,o)*d%o,w=Z(p,s,o)*d%o,B=Z(w,t,o)*h%o;return{pow_p_5_8:Z(B,Ga,o)*r%o,b2:a}}function qf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Vo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Mo(r,t){let e=ur,n=X(t*t*t,e),s=X(n*n*t,e),o=Ff(r*s).pow_p_5_8,i=X(r*n*o,e),a=X(t*i*i,e),c=i,l=X(i*Vo,e),h=a===r,u=a===X(-r,e),f=a===X(-r*Vo,e);return h&&(i=c),(u||f)&&(i=l),Jt(i,e)&&(i=X(-i,e)),{isValid:h||u,value:i}}var we=kt($r.p,{isLE:!0}),$f=kt($r.n,{isLE:!0}),jf={...$r,Fp:we,hash:_n,adjustScalarBytes:qf,uvRatio:Mo},Ot=ja(jf);var Ho=Vo,Gf=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Zf=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),zf=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Yf=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),Za=r=>Mo(Qt,r),Wf=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Oo=r=>Ot.Point.Fp.create(Wt(r)&Wf);function za(r){let{d:t}=$r,e=ur,n=g=>we.create(g),s=n(Ho*r*r),o=n((s+Qt)*zf),i=BigInt(-1),a=n((i-t*s)*n(s+t)),{isValid:c,value:l}=Mo(o,a),h=n(l*r);Jt(h,e)||(h=n(-h)),c||(l=h),c||(i=s);let u=n(i*(s-Qt)*Yf-a),f=l*l,d=n((l+l)*a),p=n(u*Gf),w=n(Qt-f),B=n(Qt+f);return new Ot.Point(n(d*B),n(w*p),n(p*B),n(d*w))}function Jf(r){pt(r,64);let t=Oo(r.subarray(0,32)),e=za(t),n=Oo(r.subarray(32,64)),s=za(n);return new te(e.add(s))}var te=class r extends Vn{constructor(t){super(t)}static fromAffine(t){return new r(Ot.Point.fromAffine(t))}assertSame(t){if(!(t instanceof r))throw new Error("RistrettoPoint expected")}init(t){return new r(t)}static hashToCurve(t){return Jf(j("ristrettoHash",t,64))}static fromBytes(t){pt(t,32);let{a:e,d:n}=$r,s=ur,o=I=>we.create(I),i=Oo(t);if(!ka(we.toBytes(i),t)||Jt(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(Qt+e*a),l=o(Qt-e*a),h=o(c*c),u=o(l*l),f=o(e*n*h-u),{isValid:d,value:p}=Za(o(f*u)),w=o(p*l),B=o(p*w*f),g=o((i+i)*w);Jt(g,s)&&(g=o(-g));let A=o(c*B),x=o(g*A);if(!d||Jt(x,s)||A===Of)throw new Error("invalid ristretto255 encoding 2");return new r(new Ot.Point(g,A,Qt,x))}static fromHex(t){return r.fromBytes(j("ristrettoHex",t,32))}static msm(t,e){return cr(r,Ot.Point.Fn,t,e)}toBytes(){let{X:t,Y:e,Z:n,T:s}=this.ep,o=ur,i=B=>we.create(B),a=i(i(n+e)*i(n-e)),c=i(t*e),l=i(c*c),{value:h}=Za(i(a*l)),u=i(h*a),f=i(h*c),d=i(u*f*s),p;if(Jt(s*d,o)){let B=i(e*Ho),g=i(t*Ho);t=B,e=g,p=i(u*Zf)}else p=f;Jt(t*d,o)&&(e=i(-e));let w=i((n-e)*p);return Jt(w,o)&&(w=i(-w)),we.toBytes(w)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:s,Y:o}=t.ep,i=l=>we.create(l),a=i(e*o)===i(n*s),c=i(n*o)===i(e*s);return a||c}is0(){return this.equals(r.ZERO)}};te.BASE=new te(Ot.Point.BASE);te.ZERO=new te(Ot.Point.ZERO);te.Fp=we;te.Fn=$f;var fr=32,Ut=64,Xf=32;var lr,Ya=(async()=>{try{return await Q.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Qf(r,t){let e;r.length===Ut?e=r.subarray(0,32):e=r;let n={crv:"Ed25519",kty:"OKP",x:q(r.subarray(32),"base64url"),d:q(e,"base64url"),ext:!0,key_ops:["sign"]},s=await Q.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),o=await Q.get().subtle.sign({name:"Ed25519"},s,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(o,0,o.byteLength)}function th(r,t){let e=r.subarray(0,Xf);return Ot.sign(t instanceof Uint8Array?t:t.subarray(),e)}async function Wa(r,t){return lr==null&&(lr=await Ya),lr?Qf(r,t):th(r,t)}async function eh(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Q.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Q.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function rh(r,t,e){return Ot.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function Ja(r,t,e){return lr==null&&(lr=await Ya),lr?eh(r,t,e):rh(r,t,e)}function hr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Hn=class{type="Ed25519";raw;constructor(t){this.raw=Gr(t,fr)}toMultihash(){return ke.digest(tr(this))}toCID(){return Ct.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let s=Ja(this.raw,e,t);return hr(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}},jr=class{type="Ed25519";raw;publicKey;constructor(t,e){this.raw=Gr(t,Ut),this.publicKey=new Hn(e)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t,e){e?.signal?.throwIfAborted();let n=Wa(this.raw,t);return hr(n)?n.then(s=>(e?.signal?.throwIfAborted(),s)):(e?.signal?.throwIfAborted(),n)}};function Po(r){if(r.length>Ut){r=Gr(r,Ut+fr);let n=r.subarray(0,Ut),s=r.subarray(Ut,r.length);return new jr(n,s)}r=Gr(r,Ut);let t=r.subarray(0,Ut),e=r.subarray(fr);return new jr(t,e)}function Gr(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 nh=Math.pow(2,7),sh=Math.pow(2,14),oh=Math.pow(2,21),Qa=Math.pow(2,28),tc=Math.pow(2,35),ec=Math.pow(2,42),rc=Math.pow(2,49),mt=128,xe=127;function Zr(r){if(r<nh)return 1;if(r<sh)return 2;if(r<oh)return 3;if(r<Qa)return 4;if(r<tc)return 5;if(r<ec)return 6;if(r<rc)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function nc(r,t,e=0){switch(Zr(r)){case 8:t[e++]=r&255|mt,r/=128;case 7:t[e++]=r&255|mt,r/=128;case 6:t[e++]=r&255|mt,r/=128;case 5:t[e++]=r&255|mt,r/=128;case 4:t[e++]=r&255|mt,r>>>=7;case 3:t[e++]=r&255|mt,r>>>=7;case 2:t[e++]=r&255|mt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function sc(r,t){let e=r[t],n=0;if(n+=e&xe,e<mt||(e=r[t+1],n+=(e&xe)<<7,e<mt)||(e=r[t+2],n+=(e&xe)<<14,e<mt)||(e=r[t+3],n+=(e&xe)<<21,e<mt)||(e=r[t+4],n+=(e&xe)*Qa,e<mt)||(e=r[t+5],n+=(e&xe)*tc,e<mt)||(e=r[t+6],n+=(e&xe)*ec,e<mt)||(e=r[t+7],n+=(e&xe)*rc,e<mt))return n;throw new RangeError("Could not decode varint")}var Fo=new Float32Array([-0]),ve=new Uint8Array(Fo.buffer);function oc(r,t,e){Fo[0]=r,t[e]=ve[0],t[e+1]=ve[1],t[e+2]=ve[2],t[e+3]=ve[3]}function ic(r,t){return ve[0]=r[t],ve[1]=r[t+1],ve[2]=r[t+2],ve[3]=r[t+3],Fo[0]}var qo=new Float64Array([-0]),ut=new Uint8Array(qo.buffer);function ac(r,t,e){qo[0]=r,t[e]=ut[0],t[e+1]=ut[1],t[e+2]=ut[2],t[e+3]=ut[3],t[e+4]=ut[4],t[e+5]=ut[5],t[e+6]=ut[6],t[e+7]=ut[7]}function cc(r,t){return ut[0]=r[t],ut[1]=r[t+1],ut[2]=r[t+2],ut[3]=r[t+3],ut[4]=r[t+4],ut[5]=r[t+5],ut[6]=r[t+6],ut[7]=r[t+7],qo[0]}var ih=BigInt(Number.MAX_SAFE_INTEGER),ah=BigInt(Number.MIN_SAFE_INTEGER),It=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 Ke;if(t<ih&&t>ah)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>uc&&(s=0n,++n>uc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ke;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):Ke}},Ke=new It(0,0);Ke.toBigInt=function(){return 0n};Ke.zzEncode=Ke.zzDecode=function(){return this};Ke.length=function(){return 1};var uc=4294967296n;function lc(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 fc(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 $o(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 Dt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function On(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var jo=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,Dt(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 Dt(this,4);return On(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Dt(this,4);return On(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Dt(this,4);let t=ic(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Dt(this,4);let t=cc(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 Dt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return fc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Dt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Dt(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 It(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 Dt(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 Dt(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 Dt(this,8);let t=On(this.buf,this.pos+=4),e=On(this.buf,this.pos+=4);return new It(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=sc(this.buf,this.pos);return this.pos+=Zr(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 Go(r){return new jo(r instanceof Uint8Array?r:r.subarray())}function Mn(r,t,e){let n=Go(r);return t.decode(n,void 0,e)}function Zo(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return At(i);s+i>t&&(n=At(t),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Ve=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function zo(){}var Wo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},ch=Zo();function uh(r){return globalThis.Buffer!=null?At(r):ch(r)}var Yr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ve(zo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ve(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Jo((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(Pn,10,It.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=It.fromBigInt(t);return this._push(Pn,e.length(),e)}uint64Number(t){return this._push(nc,Zr(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=It.fromBigInt(t).zzEncode();return this._push(Pn,e.length(),e)}sint64Number(t){let e=It.fromNumber(t).zzEncode();return this._push(Pn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Yo,1,t?1:0)}fixed32(t){return this._push(zr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=It.fromBigInt(t);return this._push(zr,4,e.lo)._push(zr,4,e.hi)}fixed64Number(t){let e=It.fromNumber(t);return this._push(zr,4,e.lo)._push(zr,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(oc,4,t)}double(t){return this._push(ac,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Yo,1,0):this.uint32(e)._push(fh,e,t)}string(t){let e=lc(t);return e!==0?this.uint32(e)._push($o,e,t):this._push(Yo,1,0)}fork(){return this.states=new Wo(this),this.head=this.tail=new Ve(zo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Ve(zo,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 Yo(r,t,e){t[e]=r&255}function lh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Jo=class extends Ve{next;constructor(t,e){super(lh,t,e),this.next=void 0}};function Pn(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 zr(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 fh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Yr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(hh,t,r),this},Yr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(dh,t,r),this});function hh(r,t,e){t.set(r,e)}function dh(r,t,e){r.length<40?$o(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(P(r),e)}function Xo(){return new Yr}function Fn(r,t){let e=Xo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var dr;(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"})(dr||(dr={}));function qn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Qo(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 qn("enum",dr.VARINT,e,n)}function $n(r,t){return qn("message",dr.LENGTH_DELIMITED,r,t)}var rt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(rt||(rt={}));var ti;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ti||(ti={}));(function(r){r.codec=()=>Qo(ti)})(rt||(rt={}));var Be;(function(r){let t;r.codec=()=>(t==null&&(t=$n((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=>Fn(e,r.codec()),r.decode=(e,n)=>Mn(e,r.codec(),n)})(Be||(Be={}));var Wr;(function(r){let t;r.codec=()=>(t==null&&(t=$n((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=>Fn(e,r.codec()),r.decode=(e,n)=>Mn(e,r.codec(),n)})(Wr||(Wr={}));function He(r){if(isNaN(r)||r<=0)throw new L("random bytes length must be a Number bigger than 0");return he(r)}var Xr={};ft(Xr,{MAX_RSA_KEY_SIZE:()=>ei,generateRSAKeyPair:()=>mc,jwkToJWKKeyPair:()=>bc,jwkToPkcs1:()=>mh,jwkToPkix:()=>oi,jwkToRSAPrivateKey:()=>ci,pkcs1MessageToJwk:()=>ni,pkcs1MessageToRSAPrivateKey:()=>jn,pkcs1ToJwk:()=>yh,pkcs1ToRSAPrivateKey:()=>ii,pkixMessageToJwk:()=>si,pkixMessageToRSAPublicKey:()=>ai,pkixToJwk:()=>bh,pkixToRSAPublicKey:()=>yc});var pr=Tn;var gr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Xr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return Ct.createV1(114,this._multihash)}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e,n){return gc(this.jwk,e,t,n)}},Jr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Xr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t,e){return pc(this.jwk,t,e)}};var ei=8192,ri=18,ph=1062,gh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function yh(r){let t=_t(r);return ni(t)}function ni(r){return{n:q(r[1],"base64url"),e:q(r[2],"base64url"),d:q(r[3],"base64url"),p:q(r[4],"base64url"),q:q(r[5],"base64url"),dp:q(r[6],"base64url"),dq:q(r[7],"base64url"),qi:q(r[8],"base64url"),kty:"RSA"}}function mh(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 Lt([dt(Uint8Array.from([0])),dt(P(r.n,"base64url")),dt(P(r.e,"base64url")),dt(P(r.d,"base64url")),dt(P(r.p,"base64url")),dt(P(r.q,"base64url")),dt(P(r.dp,"base64url")),dt(P(r.dq,"base64url")),dt(P(r.qi,"base64url"))]).subarray()}function bh(r){let t=_t(r,{offset:0});return si(t)}function si(r){let t=_t(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function oi(r){if(r.n==null||r.e==null)throw new L("JWK was missing components");return Lt([gh,Dr(Lt([dt(P(r.n,"base64url")),dt(P(r.e,"base64url"))]))]).subarray()}function ii(r){let t=_t(r);return jn(t)}function jn(r){let t=ni(r);return ci(t)}function yc(r,t){if(r.byteLength>=ph)throw new $e("Key size is too large");let e=_t(r,{offset:0});return ai(e,r,t)}function ai(r,t,e){let n=si(r);if(e==null){let s=pr(Be.encode({Type:rt.RSA,Data:t}));e=Vt(ri,s)}return new gr(n,e)}function ci(r){if(xc(r)>ei)throw new L("Key size is too large");let t=bc(r),e=pr(Be.encode({Type:rt.RSA,Data:oi(t.publicKey)})),n=Vt(ri,e);return new Jr(t.privateKey,new gr(t.publicKey,n))}async function mc(r){if(r>ei)throw new L("Key size is too large");let t=await wc(r),e=pr(Be.encode({Type:rt.RSA,Data:oi(t.publicKey)})),n=Vt(ri,e);return new Jr(t.privateKey,new gr(t.publicKey,n))}function bc(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 wc(r,t){let e=await Q.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await wh(e,t);return{privateKey:n[0],publicKey:n[1]}}async function pc(r,t,e){let n=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let s=await Q.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function gc(r,t,e,n){let s=await Q.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Q.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),o}async function wh(r,t){if(r.privateKey==null||r.publicKey==null)throw new L("Private and public key are required");let e=await Promise.all([Q.get().subtle.exportKey("jwk",r.privateKey),Q.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function xc(r){if(r.kty!=="RSA")throw new L("invalid key type");if(r.n==null)throw new L("invalid key modulus");return P(r.n,"base64url").length*8}var Gn=class extends er{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,rr(t);let n=Kr(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),vt(o)}update(t){return nr(this),this.iHash.update(t),this}digestInto(t){nr(this),pt(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}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Qr=(r,t,e)=>new Gn(r,t).update(e).digest();Qr.create=(r,t)=>new Gn(r,t);var vc=(r,t)=>(r+(r>=0?t:-t)/Bc)/t;function xh(r,t,e){let[[n,s],[o,i]]=t,a=vc(i*r,e),c=vc(-s*r,e),l=r-a*n-c*o,h=-a*s-c*i,u=l<re,f=h<re;u&&(l=-l),f&&(h=-h);let d=ye(Math.ceil(Rn(e)/2))+mr;if(l<re||l>=d||h<re||h>=d)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:f,k2:h}}function li(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function ui(r,t){let e={};for(let n of Object.keys(t))e[n]=r[n]===void 0?t[n]:r[n];return Yt(e.lowS,"lowS"),Yt(e.prehash,"prehash"),e.format!==void 0&&li(e.format),e}var fi=class extends Error{constructor(t=""){super(t)}},ee={Err:fi,_tlv:{encode:(r,t)=>{let{Err:e}=ee;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Mr(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Mr(s.length/2|128):"";return Mr(r)+o+s+t},decode(r,t){let{Err:e}=ee,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let h of l)i=i<<8|h;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=ee;if(r<re)throw new t("integer: negative integers are not allowed");let e=Mr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ee;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return sr(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ee,s=j("signature",r),{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:l,l:h}=n.decode(2,c);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=ee,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),o=n+s;return t.encode(48,o)}},re=BigInt(0),mr=BigInt(1),Bc=BigInt(2),Zn=BigInt(3),vh=BigInt(4);function yr(r,t){let{BYTES:e}=r,n;if(typeof t=="bigint")n=t;else{let s=j("private key",t);try{n=r.fromBytes(s)}catch{throw new Error(`invalid private key: expected ui8a of size ${e}, got ${typeof t}`)}}if(!r.isValidNot0(n))throw new Error("invalid private key: out of range [1..N-1]");return n}function Bh(r,t={}){let e=Kn("weierstrass",r,t),{Fp:n,Fn:s}=e,o=e.CURVE,{h:i,n:a}=o;me(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:c}=t;if(c&&(!n.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=Ac(n,s);function h(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(T,b,y){let{x:m,y:E}=b.toAffine(),k=n.toBytes(m);if(Yt(y,"isCompressed"),y){h();let _=!n.isOdd(E);return gt(Ec(_),k)}else return gt(Uint8Array.of(4),k,n.toBytes(E))}function f(T){St(T,void 0,"Point");let{publicKey:b,publicKeyUncompressed:y}=l,m=T.length,E=T[0],k=T.subarray(1);if(m===b&&(E===2||E===3)){let _=n.fromBytes(k);if(!n.isValid(_))throw new Error("bad point: is not on curve, wrong x");let C=w(_),N;try{N=n.sqrt(C)}catch(z){let G=z instanceof Error?": "+z.message:"";throw new Error("bad point: is not on curve, sqrt error"+G)}h();let R=n.isOdd(N);return(E&1)===1!==R&&(N=n.neg(N)),{x:_,y:N}}else if(m===y&&E===4){let _=n.BYTES,C=n.fromBytes(k.subarray(0,_)),N=n.fromBytes(k.subarray(_,_*2));if(!B(C,N))throw new Error("bad point: is not on curve");return{x:C,y:N}}else throw new Error(`bad point: got length ${m}, expected compressed=${b} or uncompressed=${y}`)}let d=t.toBytes||u,p=t.fromBytes||f;function w(T){let b=n.sqr(T),y=n.mul(b,T);return n.add(n.add(y,n.mul(T,o.a)),o.b)}function B(T,b){let y=n.sqr(b),m=w(T);return n.eql(y,m)}if(!B(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let g=n.mul(n.pow(o.a,Zn),vh),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(g,A)))throw new Error("bad curve params: a or b");function x(T,b,y=!1){if(!n.isValid(b)||y&&n.is0(b))throw new Error(`bad point coordinate ${T}`);return b}function I(T){if(!(T instanceof v))throw new Error("ProjectivePoint expected")}function D(T){if(!c||!c.basises)throw new Error("no endo");return xh(T,c.basises,s.ORDER)}let M=or((T,b)=>{let{X:y,Y:m,Z:E}=T;if(n.eql(E,n.ONE))return{x:y,y:m};let k=T.is0();b==null&&(b=k?n.ONE:n.inv(E));let _=n.mul(y,b),C=n.mul(m,b),N=n.mul(E,b);if(k)return{x:n.ZERO,y:n.ZERO};if(!n.eql(N,n.ONE))throw new Error("invZ was invalid");return{x:_,y:C}}),O=or(T=>{if(T.is0()){if(t.allowInfinityPoint&&!n.is0(T.Y))return;throw new Error("bad point: ZERO")}let{x:b,y}=T.toAffine();if(!n.isValid(b)||!n.isValid(y))throw new Error("bad point: x or y not field elements");if(!B(b,y))throw new Error("bad point: equation left != right");if(!T.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function K(T,b,y,m,E){return y=new v(n.mul(y.X,T),y.Y,y.Z),b=qr(m,b),y=qr(E,y),b.add(y)}class v{constructor(b,y,m){this.X=x("x",b),this.Y=x("y",y,!0),this.Z=x("z",m),Object.freeze(this)}static CURVE(){return o}static fromAffine(b){let{x:y,y:m}=b||{};if(!b||!n.isValid(y)||!n.isValid(m))throw new Error("invalid affine point");if(b instanceof v)throw new Error("projective point not allowed");return n.is0(y)&&n.is0(m)?v.ZERO:new v(y,m,n.ONE)}static fromBytes(b){let y=v.fromAffine(p(St(b,void 0,"point")));return y.assertValidity(),y}static fromHex(b){return v.fromBytes(j("pointHex",b))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(b=8,y=!0){return V.createCache(this,b),y||this.multiply(Zn),this}assertValidity(){O(this)}hasEvenY(){let{y:b}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(b)}equals(b){I(b);let{X:y,Y:m,Z:E}=this,{X:k,Y:_,Z:C}=b,N=n.eql(n.mul(y,C),n.mul(k,E)),R=n.eql(n.mul(m,C),n.mul(_,E));return N&&R}negate(){return new v(this.X,n.neg(this.Y),this.Z)}double(){let{a:b,b:y}=o,m=n.mul(y,Zn),{X:E,Y:k,Z:_}=this,C=n.ZERO,N=n.ZERO,R=n.ZERO,H=n.mul(E,E),z=n.mul(k,k),G=n.mul(_,_),$=n.mul(E,k);return $=n.add($,$),R=n.mul(E,_),R=n.add(R,R),C=n.mul(b,R),N=n.mul(m,G),N=n.add(C,N),C=n.sub(z,N),N=n.add(z,N),N=n.mul(C,N),C=n.mul($,C),R=n.mul(m,R),G=n.mul(b,G),$=n.sub(H,G),$=n.mul(b,$),$=n.add($,R),R=n.add(H,H),H=n.add(R,H),H=n.add(H,G),H=n.mul(H,$),N=n.add(N,H),G=n.mul(k,_),G=n.add(G,G),H=n.mul(G,$),C=n.sub(C,H),R=n.mul(G,z),R=n.add(R,R),R=n.add(R,R),new v(C,N,R)}add(b){I(b);let{X:y,Y:m,Z:E}=this,{X:k,Y:_,Z:C}=b,N=n.ZERO,R=n.ZERO,H=n.ZERO,z=o.a,G=n.mul(o.b,Zn),$=n.mul(y,k),Y=n.mul(m,_),et=n.mul(E,C),wt=n.add(y,m),W=n.add(k,_);wt=n.mul(wt,W),W=n.add($,Y),wt=n.sub(wt,W),W=n.add(y,E);let ct=n.add(k,C);return W=n.mul(W,ct),ct=n.add($,et),W=n.sub(W,ct),ct=n.add(m,E),N=n.add(_,C),ct=n.mul(ct,N),N=n.add(Y,et),ct=n.sub(ct,N),H=n.mul(z,W),N=n.mul(G,et),H=n.add(N,H),N=n.sub(Y,H),H=n.add(Y,H),R=n.mul(N,H),Y=n.add($,$),Y=n.add(Y,$),et=n.mul(z,et),W=n.mul(G,W),Y=n.add(Y,et),et=n.sub($,et),et=n.mul(z,et),W=n.add(W,et),$=n.mul(Y,W),R=n.add(R,$),$=n.mul(ct,W),N=n.mul(wt,N),N=n.sub(N,$),$=n.mul(wt,Y),H=n.mul(ct,H),H=n.add(H,$),new v(N,R,H)}subtract(b){return this.add(b.negate())}is0(){return this.equals(v.ZERO)}multiply(b){let{endo:y}=t;if(!s.isValidNot0(b))throw new Error("invalid scalar: out of range");let m,E,k=_=>V.cached(this,_,C=>Xt(v,C));if(y){let{k1neg:_,k1:C,k2neg:N,k2:R}=D(b),{p:H,f:z}=k(C),{p:G,f:$}=k(R);E=z.add($),m=K(y.beta,H,G,_,N)}else{let{p:_,f:C}=k(b);m=_,E=C}return Xt(v,[m,E])[0]}multiplyUnsafe(b){let{endo:y}=t,m=this;if(!s.isValid(b))throw new Error("invalid scalar: out of range");if(b===re||m.is0())return v.ZERO;if(b===mr)return m;if(V.hasCache(this))return this.multiply(b);if(y){let{k1neg:E,k1:k,k2neg:_,k2:C}=D(b),{p1:N,p2:R}=$a(v,m,k,C);return K(y.beta,N,R,E,_)}else return V.unsafe(m,b)}multiplyAndAddUnsafe(b,y,m){let E=this.multiplyUnsafe(y).add(b.multiplyUnsafe(m));return E.is0()?void 0:E}toAffine(b){return M(this,b)}isTorsionFree(){let{isTorsionFree:b}=t;return i===mr?!0:b?b(v,this):V.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:b}=t;return i===mr?this:b?b(v,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(b=!0){return Yt(b,"isCompressed"),this.assertValidity(),d(v,this,b)}toHex(b=!0){return Nt(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(b=!0){return this.toBytes(b)}_setWindowSize(b){this.precompute(b)}static normalizeZ(b){return Xt(v,b)}static msm(b,y){return cr(v,s,b,y)}static fromPrivateKey(b){return v.BASE.multiply(yr(s,b))}}v.BASE=new v(o.Gx,o.Gy,n.ONE),v.ZERO=new v(n.ZERO,n.ONE,n.ZERO),v.Fp=n,v.Fn=s;let U=s.BITS,V=new ar(v,t.endo?Math.ceil(U/2):U);return v.BASE.precompute(8),v}function Ec(r){return Uint8Array.of(r?2:3)}function Ac(r,t){return{secretKey:t.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function Eh(r,t={}){let{Fn:e}=r,n=t.randomBytes||he,s=Object.assign(Ac(r.Fp,e),{seed:To(e.ORDER)});function o(d){try{return!!yr(e,d)}catch{return!1}}function i(d,p){let{publicKey:w,publicKeyUncompressed:B}=s;try{let g=d.length;return p===!0&&g!==w||p===!1&&g!==B?!1:!!r.fromBytes(d)}catch{return!1}}function a(d=n(s.seed)){return _o(St(d,s.seed,"seed"),e.ORDER)}function c(d,p=!0){return r.BASE.multiply(yr(e,d)).toBytes(p)}function l(d){let p=a(d);return{secretKey:p,publicKey:c(p)}}function h(d){if(typeof d=="bigint")return!1;if(d instanceof r)return!0;let{secretKey:p,publicKey:w,publicKeyUncompressed:B}=s;if(e.allowedLengths||p===w)return;let g=j("key",d).length;return g===w||g===B}function u(d,p,w=!0){if(h(d)===!0)throw new Error("first arg must be private key");if(h(p)===!1)throw new Error("second arg must be public key");let B=yr(e,d);return r.fromHex(p).multiply(B).toBytes(w)}return Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:l,Point:r,utils:{isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a,isValidPrivateKey:o,randomPrivateKey:a,normPrivateKeyToScalar:d=>yr(e,d),precompute(d=8,p=r.BASE){return p.precompute(d,!1)}},lengths:s})}function Ah(r,t,e={}){rr(t),me(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=e.randomBytes||he,s=e.hmac||((y,...m)=>Qr(t,y,gt(...m))),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:h,getSharedSecret:u,utils:f,lengths:d}=Eh(r,e),p={prehash:!1,lowS:typeof e.lowS=="boolean"?e.lowS:!1,format:void 0,extraEntropy:!1},w="compact";function B(y){let m=a>>mr;return y>m}function g(y,m){if(!i.isValidNot0(m))throw new Error(`invalid signature ${y}: out of range 1..Point.Fn.ORDER`);return m}function A(y,m){li(m);let E=d.signature,k=m==="compact"?E:m==="recovered"?E+1:void 0;return St(y,k,`${m} signature`)}class x{constructor(m,E,k){this.r=g("r",m),this.s=g("s",E),k!=null&&(this.recovery=k),Object.freeze(this)}static fromBytes(m,E=w){A(m,E);let k;if(E==="der"){let{r:R,s:H}=ee.toSig(St(m));return new x(R,H)}E==="recovered"&&(k=m[0],E="compact",m=m.subarray(1));let _=i.BYTES,C=m.subarray(0,_),N=m.subarray(_,_*2);return new x(i.fromBytes(C),i.fromBytes(N),k)}static fromHex(m,E){return this.fromBytes(Ue(m),E)}addRecoveryBit(m){return new x(this.r,this.s,m)}recoverPublicKey(m){let E=o.ORDER,{r:k,s:_,recovery:C}=this;if(C==null||![0,1,2,3].includes(C))throw new Error("recovery id invalid");if(a*Bc<E&&C>1)throw new Error("recovery id is ambiguous for h>1 curve");let R=C===2||C===3?k+a:k;if(!o.isValid(R))throw new Error("recovery id 2 or 3 invalid");let H=o.toBytes(R),z=r.fromBytes(gt(Ec((C&1)===0),H)),G=i.inv(R),$=D(j("msgHash",m)),Y=i.create(-$*G),et=i.create(_*G),wt=r.BASE.multiplyUnsafe(Y).add(z.multiplyUnsafe(et));if(wt.is0())throw new Error("point at infinify");return wt.assertValidity(),wt}hasHighS(){return B(this.s)}toBytes(m=w){if(li(m),m==="der")return Ue(ee.hexFromSig(this));let E=i.toBytes(this.r),k=i.toBytes(this.s);if(m==="recovered"){if(this.recovery==null)throw new Error("recovery bit must be present");return gt(Uint8Array.of(this.recovery),E,k)}return gt(E,k)}toHex(m){return Nt(this.toBytes(m))}assertValidity(){}static fromCompact(m){return x.fromBytes(j("sig",m),"compact")}static fromDER(m){return x.fromBytes(j("sig",m),"der")}normalizeS(){return this.hasHighS()?new x(this.r,i.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return Nt(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return Nt(this.toBytes("compact"))}}let I=e.bits2int||function(m){if(m.length>8192)throw new Error("input is too large");let E=sr(m),k=m.length*8-c;return k>0?E>>BigInt(k):E},D=e.bits2int_modN||function(m){return i.create(I(m))},M=ye(c);function O(y){return Pr("num < 2^"+c,y,re,M),i.toBytes(y)}function K(y,m){return St(y,void 0,"message"),m?St(t(y),void 0,"prehashed message"):y}function v(y,m,E){if(["recovered","canonical"].some(Y=>Y in E))throw new Error("sign() legacy options not supported");let{lowS:k,prehash:_,extraEntropy:C}=ui(E,p);y=K(y,_);let N=D(y),R=yr(i,m),H=[O(R),O(N)];if(C!=null&&C!==!1){let Y=C===!0?n(d.secretKey):C;H.push(j("extraEntropy",Y))}let z=gt(...H),G=N;function $(Y){let et=I(Y);if(!i.isValidNot0(et))return;let wt=i.inv(et),W=r.BASE.multiply(et).toAffine(),ct=i.create(W.x);if(ct===re)return;let gn=i.create(wt*i.create(G+ct*R));if(gn===re)return;let Ai=(W.x===ct?0:2)|Number(W.y&mr),Si=gn;return k&&B(gn)&&(Si=i.neg(gn),Ai^=1),new x(ct,Si,Ai)}return{seed:z,k2sig:$}}function U(y,m,E={}){y=j("message",y);let{seed:k,k2sig:_}=v(y,m,E);return Ca(t.outputLen,i.BYTES,s)(k,_)}function V(y){let m,E=typeof y=="string"||Zt(y),k=!E&&y!==null&&typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint";if(!E&&!k)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(k)m=new x(y.r,y.s);else if(E){try{m=x.fromBytes(j("sig",y),"der")}catch(_){if(!(_ instanceof ee.Err))throw _}if(!m)try{m=x.fromBytes(j("sig",y),"compact")}catch{return!1}}return m||!1}function T(y,m,E,k={}){let{lowS:_,prehash:C,format:N}=ui(k,p);if(E=j("publicKey",E),m=K(j("message",m),C),"strict"in k)throw new Error("options.strict was renamed to lowS");let R=N===void 0?V(y):x.fromBytes(j("sig",y),N);if(R===!1)return!1;try{let H=r.fromBytes(E);if(_&&R.hasHighS())return!1;let{r:z,s:G}=R,$=D(m),Y=i.inv(G),et=i.create($*Y),wt=i.create(z*Y),W=r.BASE.multiplyUnsafe(et).add(H.multiplyUnsafe(wt));return W.is0()?!1:i.create(W.x)===z}catch{return!1}}function b(y,m,E={}){let{prehash:k}=ui(E,p);return m=K(m,k),x.fromBytes(y,"recovered").recoverPublicKey(m).toBytes()}return Object.freeze({keygen:l,getPublicKey:h,getSharedSecret:u,utils:f,lengths:d,Point:r,sign:U,verify:T,recoverPublicKey:b,Signature:x,hash:t})}function Sh(r){let t={a:r.a,b:r.b,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=r.allowedPrivateKeyLengths?Array.from(new Set(r.allowedPrivateKeyLengths.map(i=>Math.ceil(i/2)))):void 0,s=kt(t.n,{BITS:r.nBitLength,allowedLengths:n,modFromBytes:r.wrapPrivateKey}),o={Fp:e,Fn:s,allowInfinityPoint:r.allowInfinityPoint,endo:r.endo,isTorsionFree:r.isTorsionFree,clearCofactor:r.clearCofactor,fromBytes:r.fromBytes,toBytes:r.toBytes};return{CURVE:t,curveOpts:o}}function kh(r){let{CURVE:t,curveOpts:e}=Sh(r),n={hmac:r.hmac,randomBytes:r.randomBytes,lowS:r.lowS,bits2int:r.bits2int,bits2int_modN:r.bits2int_modN};return{CURVE:t,curveOpts:e,hash:r.hash,ecdsaOpts:n}}function Ih(r,t){let e=t.Point;return Object.assign({},t,{ProjectivePoint:e,CURVE:Object.assign({},r,Dn(e.Fn.ORDER,e.Fn.BITS))})}function Sc(r){let{CURVE:t,curveOpts:e,hash:n,ecdsaOpts:s}=kh(r),o=Bh(t,e),i=Ah(o,n,s);return Ih(r,i)}function kc(r,t){let e=n=>Sc({...r,hash:n});return{...e(t),create:e}}var di={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Ch={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Ic=BigInt(2);function Nh(r){let t=di.p,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,h=l*l*r%t,u=Z(h,e,t)*h%t,f=Z(u,e,t)*h%t,d=Z(f,Ic,t)*l%t,p=Z(d,s,t)*d%t,w=Z(p,o,t)*p%t,B=Z(w,a,t)*w%t,g=Z(B,c,t)*B%t,A=Z(g,a,t)*w%t,x=Z(A,e,t)*h%t,I=Z(x,i,t)*p%t,D=Z(I,n,t)*l%t,M=Z(D,Ic,t);if(!hi.eql(hi.sqr(M),r))throw new Error("Cannot find square root");return M}var hi=kt(di.p,{sqrt:Nh}),Mt=kc({...di,Fp:hi,lowS:!0,endo:Ch},Tn);var Cc=32;function Nc(r,t,e){let n=Xe.digest(t instanceof Uint8Array?t:t.subarray());if(hr(n))return n.then(({digest:s})=>(e?.signal?.throwIfAborted(),Mt.sign(s,r).toDERRawBytes())).catch(s=>{throw s.name==="AbortError"?s:new Sr(String(s))});try{return Mt.sign(n.digest,r).toDERRawBytes()}catch(s){throw new Sr(String(s))}}function Uc(r,t,e,n){let s=Xe.digest(e instanceof Uint8Array?e:e.subarray());if(hr(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Mt.verify(t,o,r))).catch(o=>{throw o.name==="AbortError"?o:new kr(String(o))});try{return n?.signal?.throwIfAborted(),Mt.verify(t,s.digest,r)}catch(o){throw new kr(String(o))}}var zn=class{type="secp256k1";raw;_key;constructor(t){this._key=Lc(t),this.raw=Tc(this._key)}toMultihash(){return ke.digest(tr(this))}toCID(){return Ct.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e,n){return Uc(this._key,e,t,n)}},Yn=class{type="secp256k1";raw;publicKey;constructor(t,e){this.raw=_c(t),this.publicKey=new zn(e??Rc(t))}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}sign(t,e){return Nc(this.raw,t,e)}};function pi(r){return new Yn(r)}function Tc(r){return Mt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function _c(r){try{return Mt.getPublicKey(r,!0),r}catch(t){throw new Ir(String(t))}}function Lc(r){try{return Mt.ProjectivePoint.fromHex(r),r}catch(t){throw new $e(String(t))}}function Rc(r){try{return Mt.getPublicKey(r,!0)}catch(t){throw new Ir(String(t))}}function tr(r){return Be.encode({Type:rt[r.type],Data:r.raw})}function Dc(r){let t=Wr.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case rt.RSA:return ii(e);case rt.Ed25519:return Po(e);case rt.secp256k1:return pi(e);case rt.ECDSA:return aa(e);default:throw new je}}function Kc(r){if(r.byteLength===Ut)return Po(r);if(r.byteLength===Cc)return pi(r);let t=_t(r),e=t[2]?.[0];if(e===ra||e===na||e===sa)return wo(t);if(t.length>8)return jn(t);throw new L("Could not extract private key from raw bytes")}function Oe(r){return Wr.encode({Type:rt[r.type],Data:r.raw})}function Vc(r,t,e,n){rr(r);let s=ga({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Gt(o),Gt(i),Gt(a),o<1)throw new Error("iterations (c) should be >= 1");let c=xo(t),l=xo(e),h=new Uint8Array(i),u=Qr.create(r,c),f=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:h,PRF:u,PRFSalt:f}}function Hc(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),vt(s),e}function Oc(r,t,e,n){let{c:s,dkLen:o,DK:i,PRF:a,PRFSalt:c}=Vc(r,t,e,n),l,h=new Uint8Array(4),u=Ne(h),f=new Uint8Array(a.outputLen);for(let d=1,p=0;p<o;d++,p+=a.outputLen){let w=i.subarray(p,p+a.outputLen);u.setInt32(0,d,!1),(l=c._cloneInto(l)).update(h).digestInto(f),w.set(f.subarray(0,w.length));for(let B=1;B<s;B++){a._cloneInto(l).update(f).digestInto(f);for(let g=0;g<w.length;g++)w[g]^=f[g]}}return Hc(a,c,i,l,f)}async function Wn(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=Vc(r,t,e,n),h,u=new Uint8Array(4),f=Ne(u),d=new Uint8Array(c.outputLen);for(let p=1,w=0;w<o;p++,w+=c.outputLen){let B=a.subarray(w,w+c.outputLen);f.setInt32(0,p,!1),(h=l._cloneInto(h)).update(u).digestInto(d),B.set(d.subarray(0,B.length)),await pa(s-1,i,()=>{c._cloneInto(h).update(d).digestInto(d);for(let g=0;g<B.length;g++)B[g]^=d[g]})}return Hc(c,l,a,h,d)}var tn=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),Ee=new Uint32Array(80),Jn=class extends Te{constructor(){super(64,20,8,!1),this.A=tn[0]|0,this.B=tn[1]|0,this.C=tn[2]|0,this.D=tn[3]|0,this.E=tn[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)Ee[c]=t.getUint32(e,!1);for(let c=16;c<80;c++)Ee[c]=An(Ee[c-3]^Ee[c-8]^Ee[c-14]^Ee[c-16],1);let{A:n,B:s,C:o,D:i,E:a}=this;for(let c=0;c<80;c++){let l,h;c<20?(l=kn(s,o,i),h=1518500249):c<40?(l=s^o^i,h=1859775393):c<60?(l=In(s,o,i),h=2400959708):(l=s^o^i,h=3395469782);let u=An(n,5)+l+a+h+Ee[c]|0;a=i,i=o,o=An(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(){vt(Ee)}destroy(){this.set(0,0,0,0,0),vt(this.buffer)}},Mc=Vr(()=>new Jn);var Pc=Mc;var br=_n;var Fc={sha1:Pc,"sha2-256":pr,"sha2-512":br};function en(r,t,e,n,s){if(s!=="sha1"&&s!=="sha2-256"&&s!=="sha2-512"){let a=Object.keys(Fc).join(" / ");throw new L(`Hash '${s}' is unknown or not supported. Must be ${a}`)}let o=Fc[s],i=Oc(o,r,t,{c:e,dkLen:n});return Ie.encode(i).substring(1)}var ne="/",qc=new TextEncoder().encode(ne),Xn=qc[0],rn=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=P(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Xn)throw new Error("Invalid key")}toString(t="utf8"){return q(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ne))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=qc),this._buf[0]!==Xn){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Xn,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Xn;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let s=0;s<e.length;s++){if(n.length<s+1)return!1;let o=e[s],i=n[s];if(o<i)return!0;if(o>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(ne).slice(1)}type(){return Uh(this.baseNamespace())}name(){return Th(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ne)||(t+=ne),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ne):new r(t.slice(0,-1).join(ne))}child(t){return this.toString()===ne?t:t.toString()===ne?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),..._h(t.map(e=>e.namespaces()))])}};function Uh(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Th(r){let t=r.split(":");return t[t.length-1]}function _h(r){return[].concat(...r)}var Fu=Ii(Xc(),1);var gi={keyLength:64,iterationCount:1e4,salt:"you should override this value with a crypto secure random number",hash:"sha2-512"};var wr={};ft(wr,{create:()=>jh,derivedEmptyPasswordKey:()=>Qn});var Qn={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=Q.get();e*=8;async function c(u,f){let d=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),w={name:t,iv:p};typeof f=="string"&&(f=P(f));let B;if(f.length===0){B=await a.subtle.importKey("jwk",Qn,{name:"AES-GCM"},!0,["encrypt"]);try{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);B=await a.subtle.deriveKey(A,x,{name:t,length:e},!0,["encrypt"])}catch{B=await a.subtle.importKey("jwk",Qn,{name:"AES-GCM"},!0,["encrypt"])}}else{let A={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);B=await a.subtle.deriveKey(A,x,{name:t,length:e},!0,["encrypt"])}let g=await a.subtle.encrypt(w,B,u);return Je([d,w.iv,new Uint8Array(g)])}async function l(u,f){let d=u.subarray(0,o),p=u.subarray(o,o+n),w=u.subarray(o+n),B={name:t,iv:p};typeof f=="string"&&(f=P(f));let g;if(f.length===0)try{let x={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},I=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(x,I,{name:t,length:e},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",Qn,{name:"AES-GCM"},!0,["decrypt"])}else{let x={name:"PBKDF2",salt:d,iterations:i,hash:{name:s}},I=await a.subtle.importKey("raw",f,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(x,I,{name:t,length:e},!0,["decrypt"])}let A=await a.subtle.decrypt(B,g,w);return new Uint8Array(A)}return{encrypt:c,decrypt:l}}var F=Ii(Qc());function Me(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 Ae(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 l=new Uint8Array(c);for(let h=a-1;h>=0;h--){let u=Math.pow(2,h*t);l[o-h-1]=Math.floor(s/u),s-=l[o-h-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function rs(...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 mi(){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=Me(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,Me(o,8)-n}function tu(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=Ae(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ae(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 eu(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Bt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var rb=Math.log(2);function ns(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function bi(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 ue(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 on=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return bi(this.items)}},nn=[new Uint8Array([1])],ru="0123456789";var vr="",Kt=new ArrayBuffer(0),wi=new Uint8Array(0),an="EndOfContent",su="OCTET STRING",ou="BIT STRING";function le(r){var t;return t=class extends r{get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}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?F.BufferSourceConverter.toUint8Array(o.valueHex):wi}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!ue(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",Kt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:F.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var oe=class{static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}constructor({blockLength:t=0,error:e=vr,warnings:n=[],valueBeforeDecode:s=wi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=F.BufferSourceConverter.toUint8Array(s)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:F.Convert.ToHex(this.valueBeforeDecodeView)}}};oe.NAME="baseBlock";var lt=class extends oe{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'")}};lt.NAME="valueBlock";var ss=class extends le(oe){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?F.BufferSourceConverter.toUint8Array(t.valueHex):wi,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",Kt}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=Ae(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=F.BufferSourceConverter.toUint8Array(t);if(!ue(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,l=this.valueHexView=new Uint8Array(255),h=255;for(;o[c]&128;){if(l[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===h){h+=255;let f=new Uint8Array(h);for(let d=0;d<l.length;d++)f[d]=l[d];l=this.valueHexView=new Uint8Array(h)}}this.blockLength=c+1,l[c-1]=o[c]&127;let u=new Uint8Array(c);for(let f=0;f<c;f++)u[f]=l[f];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=Me(l,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}}};ss.NAME="identificationBlock";var os=class extends oe{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=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Me(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=Ae(this.length,8);if(s.byteLength>127)return this.error="Too big length",Kt;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}}};os.NAME="lengthBlock";var S={},it=class extends oe{constructor({name:t=vr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new ss(s),this.lenBlock=new os(s),this.valueBlock=o?new o(s):new lt(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 on;e||iu(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?Kt: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():F.Convert.ToHex(this.toBER())}onAsciiEncoding(){let t=this.constructor.NAME,e=F.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);return`${t} : ${e}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return eu(e,n)}};it.NAME="BaseBlock";function iu(r){var t;if(r instanceof S.Constructed)for(let e of r.valueBlock.value)iu(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!(!((t=r.lenBlock)===null||t===void 0)&&t.isIndefiniteForm)}var is=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor({value:t=vr,...e}={},n){super(e,n),t&&this.fromString(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}'`}};is.NAME="BaseStringBlock";var as=class extends le(lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};as.NAME="PrimitiveValueBlock";var au,cs=class extends it{constructor(t={}){super(t,as),this.idBlock.isConstructed=!1}};au=cs;S.Primitive=au;cs.NAME="PRIMITIVE";function td(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 Fs(r,t=0,e=r.length){let n=t,s=new it({},lt),o=new oe;if(!ue(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=it;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=S.EndOfContent;break;case 1:c=S.Boolean;break;case 2:c=S.Integer;break;case 3:c=S.BitString;break;case 4:c=S.OctetString;break;case 5:c=S.Null;break;case 6:c=S.ObjectIdentifier;break;case 10:c=S.Enumerated;break;case 12:c=S.Utf8String;break;case 13:c=S.RelativeObjectIdentifier;break;case 14:c=S.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=S.Sequence;break;case 17:c=S.Set;break;case 18:c=S.NumericString;break;case 19:c=S.PrintableString;break;case 20:c=S.TeletexString;break;case 21:c=S.VideotexString;break;case 22:c=S.IA5String;break;case 23:c=S.UTCTime;break;case 24:c=S.GeneralizedTime;break;case 25:c=S.GraphicString;break;case 26:c=S.VisibleString;break;case 27:c=S.GeneralString;break;case 28:c=S.UniversalString;break;case 29:c=S.CharacterString;break;case 30:c=S.BmpString;break;case 31:c=S.DATE;break;case 32:c=S.TimeOfDay;break;case 33:c=S.DateTime;break;case 34:c=S.Duration;break;default:{let l=s.idBlock.isConstructed?new S.Constructed:new S.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?S.Constructed:S.Primitive}return s=td(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 qs(r){if(!r.byteLength){let t=new it({},lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Fs(F.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function ed(r,t){return r?1:t}var Pt=class extends lt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=F.BufferSourceConverter.toUint8Array(t);if(!ue(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(;ed(this.isIndefiniteForm,n)>0;){let i=Fs(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===an)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===an?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new on;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Kt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Pt.NAME="ConstructedValueBlock";var cu,Se=class extends it{constructor(t={}){super(t,Pt),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} :`}};mu=Se;S.Constructed=mu;Se.NAME="CONSTRUCTED";var ds=class extends lt{fromBER(t,e,n){return e}toBER(t){return Kt}};ds.override="EndOfContentValueBlock";var bu,ps=class extends it{constructor(t={}){super(t,ds),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};bu=ps;S.EndOfContent=bu;ps.NAME=ln;var wu,Me=class extends it{constructor(t={}){super(t,lt),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}`}};wu=Me;S.Null=wu;Me.NAME="NULL";var ys=class extends le(lt){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=F.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=F.BufferSourceConverter.toUint8Array(t);return ue(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,vi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ys.NAME="BooleanValueBlock";var xu,gs=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,ys),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};xu=gs;S.Boolean=xu;gs.NAME="BOOLEAN";var ms=class extends le(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===ln){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==du)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}}};ms.NAME="OctetStringValueBlock";var Ai,ie=class extends it{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},ms),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=Gs(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Se.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=F.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof Ai&&t.push(e.valueBlock.valueHexView);return F.BufferSourceConverter.concat(t)}};Ai=ie;S.OctetString=Ai;ie.NAME=du;var bs=class extends le(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===ln){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==pu)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Gs(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 Kt;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}}};bs.NAME="BitStringValueBlock";var vu,ws=class extends it{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},bs),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 Se.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};vu=ws;S.BitString=vu;ws.NAME=pu;var Eu;function gd(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,l=0,h=c<i?i:c,u=0;for(let f=h;f>=0;f--,u++){switch(!0){case u<a.length:l=o[i-u]+a[c-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=is(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=is(e,o)),o}function hu(r){if(r>=an.length)for(let t=an.length;t<=r;t++){let e=new Uint8Array([0]),n=an[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=is(e,n)),an.push(n)}return an[r]}function md(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,l,h=0;for(let u=c;u>=0;u--,h++)switch(l=o[i-h]-a[c-h]-e,!0){case l<0:e=1,o[i-h]=l+10;break;default:e=0,o[i-h]=l}if(e>0)for(let u=i-c+1;u>=0;u--,h++)if(l=o[i-h]-e,l<0)e=1,o[i-h]=l+10;else{e=0,o[i-h]=l;break}return o.slice()}var fn=class extends le(lt){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=vi.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(uu(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 l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=md(hu(n),e),i="-";break;default:e=gd(e,hu(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=fu.charAt(e[c]));return a===!1&&(i+=fu.charAt(0)),i}};Eu=fn;fn.NAME="IntegerValueBlock";Object.defineProperty(Eu.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var cn,ae=class extends it{constructor(t={}){super(t,fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return as(),BigInt(this.valueBlock.toString())}static fromBigInt(t){as();let e=BigInt(t),n=new un,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(F.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${F.Convert.ToHex(a)}`)+e,h=F.BufferSourceConverter.toUint8Array(F.Convert.FromHex(l.toString(16)));h[0]|=128,n.write(h)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new cn({valueHex:n.final()})}convertToDER(){let t=new cn({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new cn({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};cn=ae;S.Integer=cn;ae.NAME="INTEGER";var Bu,xs=class extends ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Bu=xs;S.Enumerated=Bu;xs.NAME="ENUMERATED";var hn=class extends le(lt){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=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Pe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){as();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=Ae(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Kt;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=F.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}}};hn.NAME="sidBlock";var vs=class extends lt{constructor({value:t=Ar,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new hn;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,Kt;e.push(s)}return Ei(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 hn;if(s>Number.MAX_SAFE_INTEGER){as();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}};vs.NAME="ObjectIdentifierValueBlock";var Au,Ft=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,vs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Au=Ft;S.ObjectIdentifier=Au;Ft.NAME="OBJECT IDENTIFIER";var dn=class extends le(oe){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Pe(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,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=Ae(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Kt;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=F.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};dn.NAME="relativeSidBlock";var Es=class extends lt{constructor({value:t=Ar,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new dn;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,Kt;n.push(o)}return Ei(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 dn;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}};Es.NAME="RelativeObjectIdentifierValueBlock";var Su,Bs=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,Es),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Su=Bs;S.RelativeObjectIdentifier=Su;Bs.NAME="RelativeObjectIdentifier";var ku,Bt=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ku=Bt;S.Sequence=ku;Bt.NAME="SEQUENCE";var Iu,As=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Iu=As;S.Set=Iu;As.NAME="SET";var Ss=class extends le(lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ar}toJSON(){return{...super.toJSON(),value:this.value}}};Ss.NAME="StringValueBlock";var ks=class extends Ss{};ks.NAME="SimpleStringValueBlock";var bt=class extends ls{constructor({...t}={}){super(t,ks)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,F.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}};bt.NAME="SIMPLE STRING";var Is=class extends bt{fromBuffer(t){this.valueBlock.valueHexView=F.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=F.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=F.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(F.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Is.NAME="Utf8StringValueBlock";var Cu,ce=class extends Is{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Cu=ce;S.Utf8String=Cu;ce.NAME="UTF8String";var Cs=class extends bt{fromBuffer(t){this.valueBlock.value=F.Convert.ToUtf16String(t),this.valueBlock.valueHexView=F.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(F.Convert.FromUtf16String(t))}};Cs.NAME="BmpStringValueBlock";var Nu,Ns=class extends Cs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Nu=Ns;S.BmpString=Nu;Ns.NAME="BMPString";var Us=class extends bt{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=Ae(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 Uu,Ts=class extends Us{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Uu=Ts;S.UniversalString=Uu;Ts.NAME="UniversalString";var Tu,_s=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Tu=_s;S.NumericString=Tu;_s.NAME="NumericString";var _u,Ls=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};_u=Ls;S.PrintableString=_u;Ls.NAME="PrintableString";var Lu,Rs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Lu=Rs;S.TeletexString=Lu;Rs.NAME="TeletexString";var Ru,Ds=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ru=Ds;S.VideotexString=Ru;Ds.NAME="VideotexString";var Du,Ks=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Du=Ks;S.IA5String=Du;Ks.NAME="IA5String";var Ku,Vs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ku=Vs;S.GraphicString=Ku;Vs.NAME="GraphicString";var Vu,pn=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Vu=pn;S.VisibleString=Vu;pn.NAME="VisibleString";var Hu,Hs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Hu=Hs;S.GeneralString=Hu;Hs.NAME="GeneralString";var Ou,Os=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ou=Os;S.CharacterString=Ou;Os.NAME="CharacterString";var Pu,yn=class extends pn{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,F.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}}};Pu=yn;S.UTCTime=Pu;yn.NAME="UTCTime";var Mu,Ps=class extends yn{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(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}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,f=n.indexOf("+"),d="";if(f===-1&&(f=n.indexOf("-"),u=-1),f!==-1){if(d=n.substring(f+1),n=n.substring(0,f),d.length!==2&&d.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(d.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*p,d.length===4){if(p=parseInt(d.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=u*p}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-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,l!==-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,l!==-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,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let h=i.exec(s);if(h===null)throw new Error("Wrong input string for conversion");for(let u=1;u<h.length;u++)switch(u){case 1:this.year=parseInt(h[u],10);break;case 2:this.month=parseInt(h[u],10);break;case 3:this.day=parseInt(h[u],10);break;case 4:this.hour=parseInt(h[u],10)+a;break;case 5:this.minute=parseInt(h[u],10)+c;break;case 6:this.second=parseInt(h[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}}};Mu=Ps;S.GeneralizedTime=Mu;Ps.NAME="GeneralizedTime";var Fu,Ms=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Fu=Ms;S.DATE=Fu;Ms.NAME="DATE";var qu,Fs=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};qu=Fs;S.TimeOfDay=qu;Fs.NAME="TimeOfDay";var ju,qs=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};ju=qs;S.DateTime=ju;qs.NAME="DateTime";var $u,js=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};$u=js;S.Duration=$u;js.NAME="Duration";var Gu,$s=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Gu=$s;S.TIME=Gu;$s.NAME="TIME";async function zs(r,t){let n=await Er.create().encrypt(r,t);return Ie.encode(n)}async function Si(r,t,e){if(r.type==="RSA")return vd(r,t,e);if(r.type==="Ed25519")return bd(r,t,e);if(r.type==="secp256k1")return wd(r,t,e);if(r.type==="ECDSA")return xd(r,t,e);throw new $e}async function bd(r,t,e="libp2p-key"){if(e==="libp2p-key")return zs(Oe(r),t);throw new L(`export format '${e}' is not supported`)}async function wd(r,t,e="libp2p-key"){if(e==="libp2p-key")return zs(Oe(r),t);throw new L("Export format is not supported")}async function xd(r,t,e="libp2p-key"){if(e==="libp2p-key")return zs(Oe(r),t);throw new L(`export format '${e}' is not supported`)}async function vd(r,t,e="pkcs-8"){if(e==="pkcs-8")return Ed(r,t);if(e==="libp2p-key")return zs(Oe(r),t);throw new L("Export format is not supported")}async function Ed(r,t){let e=Q.get(),s=new Bt({value:[new ae({value:0}),new Bt({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Me]}),new ie({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=He(16),a=await Qn(br,t,i,{c:1e4,dkLen:32}),c=He(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),h=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),u=new Bt({value:[new ie({valueHex:i}),new ae({value:1e4}),new ae({value:32}),new Bt({value:[new Ft({value:"1.2.840.113549.2.11"}),new Me]})]}),f=new Bt({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new Bt({value:[new Bt({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new Bt({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new ie({valueHex:c})]})]})]}),p=new Bt({value:[f,new ie({valueHex:h})]}).toBER(),w=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(w,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function
|
|
6
|
+
`)}`:`${e} :`}};cu=Se;S.Constructed=cu;Se.NAME="CONSTRUCTED";var us=class extends lt{fromBER(t,e,n){return e}toBER(t){return Kt}};us.override="EndOfContentValueBlock";var uu,ls=class extends it{constructor(t={}){super(t,us),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};uu=ls;S.EndOfContent=uu;ls.NAME=an;var lu,Pe=class extends it{constructor(t={}){super(t,lt),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}`}};lu=Pe;S.Null=lu;Pe.NAME="NULL";var fs=class extends le(lt){get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=F.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}fromBER(t,e,n){let s=F.BufferSourceConverter.toUint8Array(t);return ue(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,mi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};fs.NAME="BooleanValueBlock";var fu,hs=class extends it{getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}constructor(t={}){super(t,fs),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};fu=hs;S.Boolean=fu;hs.NAME="BOOLEAN";var ds=class extends le(Pt){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=Pt.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===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==su)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?Pt.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ds.NAME="OctetStringValueBlock";var xi,ie=class extends it{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},ds),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=Fs(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Se.prototype.onAsciiEncoding.call(this);let t=this.constructor.NAME,e=F.Convert.ToHex(this.valueBlock.valueHexView);return`${t} : ${e}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof xi&&t.push(e.valueBlock.valueHexView);return F.BufferSourceConverter.concat(t)}};xi=ie;S.OctetString=xi;ie.NAME=su;var ps=class extends le(Pt){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=Pt.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ou)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Fs(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 Pt.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Kt;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}}};ps.NAME="BitStringValueBlock";var hu,gs=class extends it{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},ps),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 Se.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let i of e)t.push(i.toString(2).padStart(8,"0"));let n=t.join(""),s=this.constructor.NAME,o=n.substring(0,n.length-this.valueBlock.unusedBits);return`${s} : ${o}`}}};hu=gs;S.BitString=hu;gs.NAME=ou;var du;function rd(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,l=0,h=c<i?i:c,u=0;for(let f=h;f>=0;f--,u++){switch(!0){case u<a.length:l=o[i-u]+a[c-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=rs(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=rs(e,o)),o}function nu(r){if(r>=nn.length)for(let t=nn.length;t<=r;t++){let e=new Uint8Array([0]),n=nn[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=rs(e,n)),nn.push(n)}return nn[r]}function nd(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,l,h=0;for(let u=c;u>=0;u--,h++)switch(l=o[i-h]-a[c-h]-e,!0){case l<0:e=1,o[i-h]=l+10;break;default:e=0,o[i-h]=l}if(e>0)for(let u=i-c+1;u>=0;u--,h++)if(l=o[i-h]-e,l<0)e=1,o[i-h]=l+10;else{e=0,o[i-h]=l;break}return o.slice()}var cn=class extends le(lt){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=mi.call(this)))}constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(tu(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 l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=nd(nu(n),e),i="-";break;default:e=rd(e,nu(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=ru.charAt(e[c]));return a===!1&&(i+=ru.charAt(0)),i}};du=cn;cn.NAME="IntegerValueBlock";Object.defineProperty(du.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var sn,ae=class extends it{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ns(),BigInt(this.valueBlock.toString())}static fromBigInt(t){ns();let e=BigInt(t),n=new on,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(F.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${F.Convert.ToHex(a)}`)+e,h=F.BufferSourceConverter.toUint8Array(F.Convert.FromHex(l.toString(16)));h[0]|=128,n.write(h)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new sn({valueHex:n.final()})}convertToDER(){let t=new sn({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new sn({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};sn=ae;S.Integer=sn;ae.NAME="INTEGER";var pu,ys=class extends ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};pu=ys;S.Enumerated=pu;ys.NAME="ENUMERATED";var un=class extends le(lt){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=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Me(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){ns();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=Ae(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Kt;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=F.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}}};un.NAME="sidBlock";var ms=class extends lt{constructor({value:t=vr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new un;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,Kt;e.push(s)}return bi(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 un;if(s>Number.MAX_SAFE_INTEGER){ns();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}};ms.NAME="ObjectIdentifierValueBlock";var gu,Ft=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,ms),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};gu=Ft;S.ObjectIdentifier=gu;Ft.NAME="OBJECT IDENTIFIER";var ln=class extends le(oe){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=F.BufferSourceConverter.toUint8Array(t);if(!ue(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=Me(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=Ae(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Kt;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=F.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};ln.NAME="relativeSidBlock";var bs=class extends lt{constructor({value:t=vr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new ln;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,Kt;n.push(o)}return bi(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 ln;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}};bs.NAME="RelativeObjectIdentifierValueBlock";var yu,ws=class extends it{getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}constructor(t={}){super(t,bs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};yu=ws;S.RelativeObjectIdentifier=yu;ws.NAME="RelativeObjectIdentifier";var mu,Et=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};mu=Et;S.Sequence=mu;Et.NAME="SEQUENCE";var bu,xs=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};bu=xs;S.Set=bu;xs.NAME="SET";var vs=class extends le(lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=vr}toJSON(){return{...super.toJSON(),value:this.value}}};vs.NAME="StringValueBlock";var Bs=class extends vs{};Bs.NAME="SimpleStringValueBlock";var bt=class extends is{constructor({...t}={}){super(t,Bs)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,F.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}};bt.NAME="SIMPLE STRING";var Es=class extends bt{fromBuffer(t){this.valueBlock.valueHexView=F.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=F.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=F.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(F.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Es.NAME="Utf8StringValueBlock";var wu,ce=class extends Es{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};wu=ce;S.Utf8String=wu;ce.NAME="UTF8String";var As=class extends bt{fromBuffer(t){this.valueBlock.value=F.Convert.ToUtf16String(t),this.valueBlock.valueHexView=F.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(F.Convert.FromUtf16String(t))}};As.NAME="BmpStringValueBlock";var xu,Ss=class extends As{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};xu=Ss;S.BmpString=xu;Ss.NAME="BMPString";var ks=class extends bt{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=Ae(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}};ks.NAME="UniversalStringValueBlock";var vu,Is=class extends ks{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};vu=Is;S.UniversalString=vu;Is.NAME="UniversalString";var Bu,Cs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Bu=Cs;S.NumericString=Bu;Cs.NAME="NumericString";var Eu,Ns=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Eu=Ns;S.PrintableString=Eu;Ns.NAME="PrintableString";var Au,Us=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Au=Us;S.TeletexString=Au;Us.NAME="TeletexString";var Su,Ts=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Su=Ts;S.VideotexString=Su;Ts.NAME="VideotexString";var ku,_s=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ku=_s;S.IA5String=ku;_s.NAME="IA5String";var Iu,Ls=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Iu=Ls;S.GraphicString=Iu;Ls.NAME="GraphicString";var Cu,fn=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Cu=fn;S.VisibleString=Cu;fn.NAME="VisibleString";var Nu,Rs=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Nu=Rs;S.GeneralString=Nu;Rs.NAME="GeneralString";var Uu,Ds=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Uu=Ds;S.CharacterString=Uu;Ds.NAME="CharacterString";var Tu,hn=class extends fn{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,F.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Bt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Bt(this.month,2),e[2]=Bt(this.day,2),e[3]=Bt(this.hour,2),e[4]=Bt(this.minute,2),e[5]=Bt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Tu=hn;S.UTCTime=Tu;hn.NAME="UTCTime";var _u,Ks=class extends hn{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(){let t=Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond);return new Date(t)}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,f=n.indexOf("+"),d="";if(f===-1&&(f=n.indexOf("-"),u=-1),f!==-1){if(d=n.substring(f+1),n=n.substring(0,f),d.length!==2&&d.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(d.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*p,d.length===4){if(p=parseInt(d.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=u*p}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-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,l!==-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,l!==-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,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let h=i.exec(s);if(h===null)throw new Error("Wrong input string for conversion");for(let u=1;u<h.length;u++)switch(u){case 1:this.year=parseInt(h[u],10);break;case 2:this.month=parseInt(h[u],10);break;case 3:this.day=parseInt(h[u],10);break;case 4:this.hour=parseInt(h[u],10)+a;break;case 5:this.minute=parseInt(h[u],10)+c;break;case 6:this.second=parseInt(h[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(Bt(this.year,4)),e.push(Bt(this.month,2)),e.push(Bt(this.day,2)),e.push(Bt(this.hour,2)),e.push(Bt(this.minute,2)),e.push(Bt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Bt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};_u=Ks;S.GeneralizedTime=_u;Ks.NAME="GeneralizedTime";var Lu,Vs=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Lu=Vs;S.DATE=Lu;Vs.NAME="DATE";var Ru,Hs=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ru=Hs;S.TimeOfDay=Ru;Hs.NAME="TimeOfDay";var Du,Os=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Du=Os;S.DateTime=Du;Os.NAME="DateTime";var Ku,Ms=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ku=Ms;S.Duration=Ku;Ms.NAME="Duration";var Vu,Ps=class extends ce{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Vu=Ps;S.TIME=Vu;Ps.NAME="TIME";async function $s(r,t){let n=await wr.create().encrypt(r,t);return Ie.encode(n)}async function vi(r,t,e){if(r.type==="RSA")return ad(r,t,e);if(r.type==="Ed25519")return sd(r,t,e);if(r.type==="secp256k1")return od(r,t,e);if(r.type==="ECDSA")return id(r,t,e);throw new je}async function sd(r,t,e="libp2p-key"){if(e==="libp2p-key")return $s(Oe(r),t);throw new L(`export format '${e}' is not supported`)}async function od(r,t,e="libp2p-key"){if(e==="libp2p-key")return $s(Oe(r),t);throw new L("Export format is not supported")}async function id(r,t,e="libp2p-key"){if(e==="libp2p-key")return $s(Oe(r),t);throw new L(`export format '${e}' is not supported`)}async function ad(r,t,e="pkcs-8"){if(e==="pkcs-8")return cd(r,t);if(e==="libp2p-key")return $s(Oe(r),t);throw new L("Export format is not supported")}async function cd(r,t){let e=Q.get(),s=new Et({value:[new ae({value:0}),new Et({value:[new Ft({value:"1.2.840.113549.1.1.1"}),new Pe]}),new ie({valueHex:r.raw})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=He(16),a=await Wn(br,t,i,{c:1e4,dkLen:32}),c=He(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),h=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),u=new Et({value:[new ie({valueHex:i}),new ae({value:1e4}),new ae({value:32}),new Et({value:[new Ft({value:"1.2.840.113549.2.11"}),new Pe]})]}),f=new Et({value:[new Ft({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Ft({value:"1.2.840.113549.1.5.12"}),u]}),new Et({value:[new Ft({value:"2.16.840.1.101.3.4.1.42"}),new ie({valueHex:c})]})]})]}),p=new Et({value:[f,new ie({valueHex:h})]}).toBER(),w=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(w,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
+
`)}async function Bi(r,t){try{let e=await ud(r,t);return Dc(e)}catch{}if(!r.includes("BEGIN"))throw new L("Encrypted key was not a libp2p-key or a PEM file");return ld(r,t)}async function ud(r,t){let e=Ie.decode(r);return wr.create().decrypt(e,t)}async function ld(r,t){let e=Q.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=P(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=qs(o),{iv:a,salt:c,iterations:l,keySize:h,cipherText:u}=fd(i),f=await Wn(br,t,c,{c:l,dkLen:h}),d=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),p=dn(await e.subtle.decrypt({name:"AES-CBC",iv:a},d,u)),{result:w}=qs(p);n=Pu(w)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=P(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=qs(o);n=Pu(i)}else throw new L("Could not parse private key from PEM data");let s=Kc(n);if(s.type!=="RSA")throw new L("Could not parse RSA private key from PEM data");return s}function fd(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=dn(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 l=t.valueBlock.value[1].valueBlock.value[1],h=l.valueBlock.value[0].toString();if(h!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(h!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(h!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(h!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(h!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new L("Only AES-CBC encryption schemes are supported")}}}}let u=dn(l.valueBlock.value[1].getValue());return{cipherText:dn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function Pu(r){return dn(r.valueBlock.value[2].getValue())}function dn(r){return new Uint8Array(r,0,r.byteLength)}var hd="/pkcs8/",Ei="/info/",pn=new WeakMap,Fe={minKeyLength:112/8,minSaltLength:128/8,minIterationCount:1e3};function Br(r){return r==null||typeof r!="string"?!1:r===(0,Fu.default)(r.trim())&&r.length>0}async function at(){let e=Math.random()*800+200;await new Promise(n=>setTimeout(n,e))}function qe(r){return new rn(hd+r)}function Er(r){return new rn(Ei+r)}async function dd(r){let t=Oe(r),e=await Xe.digest(t);return tt.encode(e.bytes).substring(1)}var js=class{components;init;log;self;constructor(t,e){if(this.components=t,this.log=t.logger.forComponent("libp2p:keychain"),this.init={...e,dek:{...gi,...e.dek}},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<Fe.minKeyLength)throw new Error(`dek.keyLength must be least ${Fe.minKeyLength} bytes`);if(this.init.dek?.salt?.length!=null&&this.init.dek.salt.length<Fe.minSaltLength)throw new Error(`dek.saltLength must be least ${Fe.minSaltLength} bytes`);if(this.init.dek?.iterationCount!=null&&this.init.dek.iterationCount<Fe.minIterationCount)throw new Error(`dek.iterationCount must be least ${Fe.minIterationCount}`);let n=this.init.pass!=null&&this.init.dek?.salt!=null?en(this.init.pass,this.init.dek?.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";pn.set(this,{dek:n})}[Symbol.toStringTag]="@libp2p/keychain";[Ni]=["@libp2p/keychain"];static generateOptions(){let t=Object.assign({},this.options),e=Math.ceil(Fe.minSaltLength/3)*3;return t.dek!=null&&(t.dek.salt=q(He(e),"base64")),t}static get options(){return{dek:{...gi}}}async findKeyByName(t){if(!Br(t))throw await at(),new L(`Invalid key name '${t}'`);let e=Er(t);try{let n=await this.components.datastore.get(e);return JSON.parse(q(n))}catch(n){throw await at(),this.log.error(n),new bn(`Key '${t}' does not exist.`)}}async findKeyById(t){try{let e={prefix:Ei};for await(let n of this.components.datastore.query(e)){let s=JSON.parse(q(n.value));if(s.id===t)return s}throw new L(`Key with id '${t}' does not exist.`)}catch(e){throw await at(),e}}async importKey(t,e){if(!Br(t))throw await at(),new L(`Invalid key name '${t}'`);if(e==null)throw await at(),new L("Key is required");let n=qe(t);if(await this.components.datastore.has(n))throw await at(),new L(`Key '${t}' already exists`);let o,i;try{o=await dd(e);let l=pn.get(this);if(l==null)throw new L("dek missing");let h=l.dek;i=await vi(e,h,e.type==="RSA"?"pkcs-8":"libp2p-key")}catch(l){throw await at(),l}let a={name:t,id:o},c=this.components.datastore.batch();return c.put(n,P(i)),c.put(Er(t),P(JSON.stringify(a))),await c.commit(),a}async exportKey(t){if(!Br(t))throw await at(),new L(`Invalid key name '${t}'`);let e=qe(t);try{let n=await this.components.datastore.get(e),s=q(n),o=pn.get(this);if(o==null)throw new L("dek missing");let i=o.dek;return await Bi(s,i)}catch(n){throw await at(),n}}async removeKey(t){if(!Br(t)||t===this.self)throw await at(),new L(`Invalid key name '${t}'`);let e=qe(t),n=await this.findKeyByName(t),s=this.components.datastore.batch();return s.delete(e),s.delete(Er(t)),await s.commit(),n}async listKeys(){let t={prefix:Ei},e=[];for await(let n of this.components.datastore.query(t))e.push(JSON.parse(q(n.value)));return e}async renameKey(t,e){if(!Br(t)||t===this.self)throw await at(),new L(`Invalid old key name '${t}'`);if(!Br(e)||e===this.self)throw await at(),new L(`Invalid new key name '${e}'`);let n=qe(t),s=qe(e),o=Er(t),i=Er(e);if(await this.components.datastore.has(s))throw await at(),new L(`Key '${e}' already exists`);try{let c=await this.components.datastore.get(n),l=await this.components.datastore.get(o),h=JSON.parse(q(l));h.name=e;let u=this.components.datastore.batch();return u.put(s,c),u.put(i,P(JSON.stringify(h))),u.delete(n),u.delete(o),await u.commit(),h}catch(c){throw await at(),c}}async rotateKeychainPass(t,e){if(typeof t!="string")throw await at(),new L(`Invalid old pass type '${typeof t}'`);if(typeof e!="string")throw await at(),new L(`Invalid new pass type '${typeof e}'`);if(e.length<20)throw await at(),new L(`Invalid pass length ${e.length}`);this.log("recreating keychain");let n=pn.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?en(e,this.init.dek.salt,this.init.dek?.iterationCount,this.init.dek?.keyLength,this.init.dek?.hash):"";pn.set(this,{dek:o});let i=await this.listKeys();for(let a of i){let c=await this.components.datastore.get(qe(a.name)),l=q(c),h=await Bi(l,s),u=o.toString(),f=await vi(h,u,h.type==="RSA"?"pkcs-8":"libp2p-key"),d=this.components.datastore.batch(),p={name:a.name,id:a.id};d.put(qe(a.name),P(f)),d.put(Er(a.name),P(JSON.stringify(p))),await d.commit()}this.log("keychain reconstructed")}};function pd(r={}){return t=>new js(t,r)}return zu(gd);})();
|
|
8
8
|
/*! Bundled license information:
|
|
9
9
|
|
|
10
10
|
pvtsutils/build/index.js:
|