window.nostr.js 0.0.2 → 0.0.3

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/README.md CHANGED
@@ -1,3 +1,7 @@
1
1
  # window.nostr.js
2
2
 
3
3
  a small `<script>` you can drop in any page that already uses [NIP-07](https://nips.nostr.com/7) and make it also work with [NIP-46](https://nips.nostr.com/46) automatically when the user doesn't have an extension installed.
4
+
5
+ ## How to use it
6
+
7
+ Include `<script src="https://cdn.jsdelivr.net/npm/window.nostr.js@latest/dist/window.nostr.js"></script>` in your HTML and proceed to use [`window.nostr`](https://nips.nostr.com/7) normally.
package/dist/index.html CHANGED
@@ -4,7 +4,7 @@
4
4
  <meta charset="UTF-8" />
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
6
  <title>dev</title>
7
- <script type="module" crossorigin src="/assets/index-D6-w3v1d.js"></script>
7
+ <script type="module" crossorigin src="/assets/index-Bbi2UCEX.js"></script>
8
8
  </head>
9
9
  <body
10
10
  style="
@@ -1,3 +1,3 @@
1
- var ui=Object.defineProperty;var fi=(le,j,ue)=>j in le?ui(le,j,{enumerable:!0,configurable:!0,writable:!0,value:ue}):le[j]=ue;var b=(le,j,ue)=>(fi(le,typeof j!="symbol"?j+"":j,ue),ue);(function(){"use strict";var le=document.createElement("style");le.textContent=`.tw-fixed{position:fixed}.tw-right-6{right:1.5rem}.tw-top-6{top:1.5rem}.tw-mx-2{margin-left:.5rem;margin-right:.5rem}.tw-my-2{margin-top:.5rem;margin-bottom:.5rem}.tw-mb-1{margin-bottom:.25rem}.tw-mt-4{margin-top:1rem}.tw-mt-6{margin-top:1.5rem}.tw-box-border{box-sizing:border-box}.tw-block{display:block}.tw-flex{display:flex}.tw-w-80{width:20rem}.tw-w-full{width:100%}.tw-cursor-pointer{cursor:pointer}.tw-break-all{word-break:break-all}.tw-rounded{border-radius:.25rem}.tw-rounded-md{border-radius:.375rem}.tw-border-0{border-width:0px}.tw-border-none{border-style:none}.tw-bg-cyan-700{--tw-bg-opacity: 1;background-color:rgb(14 116 144 / var(--tw-bg-opacity))}.tw-bg-cyan-900{--tw-bg-opacity: 1;background-color:rgb(22 78 99 / var(--tw-bg-opacity))}.tw-bg-transparent{background-color:transparent}.tw-px-2{padding-left:.5rem;padding-right:.5rem}.tw-px-4{padding-left:1rem;padding-right:1rem}.tw-px-6{padding-left:1.5rem;padding-right:1.5rem}.tw-py-1{padding-top:.25rem;padding-bottom:.25rem}.tw-py-2{padding-top:.5rem;padding-bottom:.5rem}.tw-py-6{padding-top:1.5rem;padding-bottom:1.5rem}.tw-text-center{text-align:center}.tw-font-sans{font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.tw-text-2xl{font-size:1.5rem;line-height:2rem}.tw-text-lg{font-size:1.125rem;line-height:1.75rem}.tw-text-sm{font-size:.875rem;line-height:1.25rem}.tw-text-xs{font-size:.75rem;line-height:1rem}.tw-leading-3{line-height:.75rem}.tw-text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.tw-underline{text-decoration-line:underline}.tw-no-underline{text-decoration-line:none}.tw-shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.tw-outline-none{outline:2px solid transparent;outline-offset:2px}.tw-transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.hover\\:tw-bg-cyan-800:hover{--tw-bg-opacity: 1;background-color:rgb(21 94 117 / var(--tw-bg-opacity))}.hover\\:tw-bg-cyan-950:hover{--tw-bg-opacity: 1;background-color:rgb(8 51 68 / var(--tw-bg-opacity))}.hover\\:tw-underline:hover{text-decoration-line:underline}
2
- `,document.head.appendChild(le);function j(){}function ue(t){return t()}function Zt(){return Object.create(null)}function Be(t){t.forEach(ue)}function Jt(t){return typeof t=="function"}function ar(t,e){return t!=t?e==e:t!==e||t&&typeof t=="object"||typeof t=="function"}function lr(t){return Object.keys(t).length===0}const ur=typeof window<"u"?window:typeof globalThis<"u"?globalThis:global;function M(t,e){t.appendChild(e)}function H(t,e,n){t.insertBefore(e,n||null)}function U(t){t.parentNode&&t.parentNode.removeChild(t)}function fr(t,e){for(let n=0;n<t.length;n+=1)t[n]&&t[n].d(e)}function P(t){return document.createElement(t)}function $e(t){return document.createTextNode(t)}function se(){return $e(" ")}function Ee(t,e,n,r){return t.addEventListener(e,n,r),()=>t.removeEventListener(e,n,r)}function T(t,e,n){n==null?t.removeAttribute(e):t.getAttribute(e)!==n&&t.setAttribute(e,n)}function dr(t){return Array.from(t.childNodes)}function Yt(t,e){e=""+e,t.data!==e&&(t.data=e)}function Qt(t,e){t.value=e??""}function Xt(t,e,n){for(let r=0;r<t.options.length;r+=1){const s=t.options[r];if(s.__value===e){s.selected=!0;return}}(!n||e!==void 0)&&(t.selectedIndex=-1)}function hr(t){const e=t.querySelector(":checked");return e&&e.__value}function en(t,e,n){t.classList.toggle(e,!!n)}let Me;function Ke(t){Me=t}function wr(){if(!Me)throw new Error("Function called outside component initialization");return Me}function pr(t){wr().$$.on_mount.push(t)}const Oe=[],Je=[];let Ie=[];const tn=[],yr=Promise.resolve();let dt=!1;function gr(){dt||(dt=!0,yr.then(nn))}function Ye(t){Ie.push(t)}const ht=new Set;let Te=0;function nn(){if(Te!==0)return;const t=Me;do{try{for(;Te<Oe.length;){const e=Oe[Te];Te++,Ke(e),br(e.$$)}}catch(e){throw Oe.length=0,Te=0,e}for(Ke(null),Oe.length=0,Te=0;Je.length;)Je.pop()();for(let e=0;e<Ie.length;e+=1){const n=Ie[e];ht.has(n)||(ht.add(n),n())}Ie.length=0}while(Oe.length);for(;tn.length;)tn.pop()();dt=!1,ht.clear(),Ke(t)}function br(t){if(t.fragment!==null){t.update(),Be(t.before_update);const e=t.dirty;t.dirty=[-1],t.fragment&&t.fragment.p(t.ctx,e),t.after_update.forEach(Ye)}}function mr(t){const e=[],n=[];Ie.forEach(r=>t.indexOf(r)===-1?e.push(r):n.push(r)),n.forEach(r=>r()),Ie=e}const Er=new Set;function xr(t,e){t&&t.i&&(Er.delete(t),t.i(e))}function rn(t){return(t==null?void 0:t.length)!==void 0?t:Array.from(t)}function vr(t,e,n){const{fragment:r,after_update:s}=t.$$;r&&r.m(e,n),Ye(()=>{const o=t.$$.on_mount.map(ue).filter(Jt);t.$$.on_destroy?t.$$.on_destroy.push(...o):Be(o),t.$$.on_mount=[]}),s.forEach(Ye)}function Sr(t,e){const n=t.$$;n.fragment!==null&&(mr(n.after_update),Be(n.on_destroy),n.fragment&&n.fragment.d(e),n.on_destroy=n.fragment=null,n.ctx=[])}function _r(t,e){t.$$.dirty[0]===-1&&(Oe.push(t),gr(),t.$$.dirty.fill(0)),t.$$.dirty[e/31|0]|=1<<e%31}function Ar(t,e,n,r,s,o,i=null,c=[-1]){const a=Me;Ke(t);const u=t.$$={fragment:null,ctx:[],props:o,update:j,not_equal:s,bound:Zt(),on_mount:[],on_destroy:[],on_disconnect:[],before_update:[],after_update:[],context:new Map(e.context||(a?a.$$.context:[])),callbacks:Zt(),dirty:c,skip_bound:!1,root:e.target||a.$$.root};i&&i(u.root);let f=!1;if(u.ctx=n?n(t,e.props||{},(l,h,...w)=>{const g=w.length?w[0]:h;return u.ctx&&s(u.ctx[l],u.ctx[l]=g)&&(!u.skip_bound&&u.bound[l]&&u.bound[l](g),f&&_r(t,l)),h}):[],u.update(),f=!0,Be(u.before_update),u.fragment=r?r(u.ctx):!1,e.target){if(e.hydrate){const l=dr(e.target);u.fragment&&u.fragment.l(l),l.forEach(U)}else u.fragment&&u.fragment.c();e.intro&&xr(t.$$.fragment),vr(t,e.target,e.anchor),nn()}Ke(a)}class kr{constructor(){b(this,"$$");b(this,"$$set")}$destroy(){Sr(this,1),this.$destroy=j}$on(e,n){if(!Jt(n))return j;const r=this.$$.callbacks[e]||(this.$$.callbacks[e]=[]);return r.push(n),()=>{const s=r.indexOf(n);s!==-1&&r.splice(s,1)}}$set(e){this.$$set&&!lr(e)&&(this.$$.skip_bound=!0,this.$$set(e),this.$$.skip_bound=!1)}}const Br="4";typeof window<"u"&&(window.__svelte||(window.__svelte={v:new Set})).v.add(Br);function $r(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}var wt={exports:{}};function sn(t,e=100,n={}){if(typeof t!="function")throw new TypeError(`Expected the first parameter to be a function, got \`${typeof t}\`.`);if(e<0)throw new RangeError("`wait` must not be negative.");const{immediate:r}=typeof n=="boolean"?{immediate:n}:n;let s,o,i,c,a;function u(){const l=Date.now()-c;if(l<e&&l>=0)i=setTimeout(u,e-l);else if(i=void 0,!r){const h=s,w=o;s=void 0,o=void 0,a=t.apply(h,w)}}const f=function(...l){if(s&&this!==s)throw new Error("Debounced method called with different contexts.");s=this,o=l,c=Date.now();const h=r&&!i;if(i||(i=setTimeout(u,e)),h){const w=s,g=o;s=void 0,o=void 0,a=t.apply(w,g)}return a};return f.clear=()=>{i&&(clearTimeout(i),i=void 0)},f.flush=()=>{if(!i)return;const l=s,h=o;s=void 0,o=void 0,a=t.apply(l,h),clearTimeout(i),i=void 0},f}wt.exports.debounce=sn,wt.exports=sn;var Or=wt.exports;const Ir=$r(Or),pt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */const on=t=>t instanceof Uint8Array,yt=t=>new DataView(t.buffer,t.byteOffset,t.byteLength),te=(t,e)=>t<<32-e|t>>>e;if(!(new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68))throw new Error("Non little-endian hardware is not supported");const Tr=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function V(t){if(!on(t))throw new Error("Uint8Array expected");let e="";for(let n=0;n<t.length;n++)e+=Tr[t[n]];return e}function gt(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);const e=t.length;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);const n=new Uint8Array(e/2);for(let r=0;r<n.length;r++){const s=r*2,o=t.slice(s,s+2),i=Number.parseInt(o,16);if(Number.isNaN(i)||i<0)throw new Error("Invalid byte sequence");n[r]=i}return n}function Nr(t){if(typeof t!="string")throw new Error(`utf8ToBytes expected string, got ${typeof t}`);return new Uint8Array(new TextEncoder().encode(t))}function cn(t){if(typeof t=="string"&&(t=Nr(t)),!on(t))throw new Error(`expected Uint8Array, got ${typeof t}`);return t}let Cr=class{clone(){return this._cloneInto()}};function an(t){const e=r=>t().update(cn(r)).digest(),n=t();return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=()=>t(),e}function Pr(t=32){if(pt&&typeof pt.getRandomValues=="function")return pt.getRandomValues(new Uint8Array(t));throw new Error("crypto.getRandomValues must be defined")}function ln(t){if(!Number.isSafeInteger(t)||t<0)throw new Error(`Wrong positive integer: ${t}`)}function un(t,...e){if(!(t instanceof Uint8Array))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(t.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${t.length}`)}function Rr(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ln(t.outputLen),ln(t.blockLen)}function Qe(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function Ur(t,e){un(t);const n=e.outputLen;if(t.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const bt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */const fn=t=>t instanceof Uint8Array,mt=t=>new DataView(t.buffer,t.byteOffset,t.byteLength),ne=(t,e)=>t<<32-e|t>>>e;if(!(new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68))throw new Error("Non little-endian hardware is not supported");function Hr(t){if(typeof t!="string")throw new Error(`utf8ToBytes expected string, got ${typeof t}`);return new Uint8Array(new TextEncoder().encode(t))}function Et(t){if(typeof t=="string"&&(t=Hr(t)),!fn(t))throw new Error(`expected Uint8Array, got ${typeof t}`);return t}function Lr(...t){const e=new Uint8Array(t.reduce((r,s)=>r+s.length,0));let n=0;return t.forEach(r=>{if(!fn(r))throw new Error("Uint8Array expected");e.set(r,n),n+=r.length}),e}class dn{clone(){return this._cloneInto()}}function qr(t){const e=r=>t().update(Et(r)).digest(),n=t();return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=()=>t(),e}function hn(t=32){if(bt&&typeof bt.getRandomValues=="function")return bt.getRandomValues(new Uint8Array(t));throw new Error("crypto.getRandomValues must be defined")}function Mr(t,e,n,r){if(typeof t.setBigUint64=="function")return t.setBigUint64(e,n,r);const s=BigInt(32),o=BigInt(4294967295),i=Number(n>>s&o),c=Number(n&o),a=r?4:0,u=r?0:4;t.setUint32(e+a,i,r),t.setUint32(e+u,c,r)}let Kr=class extends dn{constructor(e,n,r,s){super(),this.blockLen=e,this.outputLen=n,this.padOffset=r,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=mt(this.buffer)}update(e){Qe(this);const{view:n,buffer:r,blockLen:s}=this;e=Et(e);const o=e.length;for(let i=0;i<o;){const c=Math.min(s-this.pos,o-i);if(c===s){const a=mt(e);for(;s<=o-i;i+=s)this.process(a,i);continue}r.set(e.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===s&&(this.process(n,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Qe(this),Ur(e,this),this.finished=!0;const{buffer:n,view:r,blockLen:s,isLE:o}=this;let{pos:i}=this;n[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(r,0),i=0);for(let l=i;l<s;l++)n[l]=0;Mr(r,s-8,BigInt(this.length*8),o),this.process(r,0);const c=mt(e),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const u=a/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)c.setUint32(4*l,f[l],o)}digest(){const{buffer:e,outputLen:n}=this;this.digestInto(e);const r=e.slice(0,n);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:n,buffer:r,length:s,finished:o,destroyed:i,pos:c}=this;return e.length=s,e.pos=c,e.finished=o,e.destroyed=i,s%n&&e.buffer.set(r),e}};const jr=(t,e,n)=>t&e^~t&n,zr=(t,e,n)=>t&e^t&n^e&n,Vr=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),fe=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),de=new Uint32Array(64);let Dr=class extends Kr{constructor(){super(64,32,8,!1),this.A=fe[0]|0,this.B=fe[1]|0,this.C=fe[2]|0,this.D=fe[3]|0,this.E=fe[4]|0,this.F=fe[5]|0,this.G=fe[6]|0,this.H=fe[7]|0}get(){const{A:e,B:n,C:r,D:s,E:o,F:i,G:c,H:a}=this;return[e,n,r,s,o,i,c,a]}set(e,n,r,s,o,i,c,a){this.A=e|0,this.B=n|0,this.C=r|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=c|0,this.H=a|0}process(e,n){for(let l=0;l<16;l++,n+=4)de[l]=e.getUint32(n,!1);for(let l=16;l<64;l++){const h=de[l-15],w=de[l-2],g=ne(h,7)^ne(h,18)^h>>>3,d=ne(w,17)^ne(w,19)^w>>>10;de[l]=d+de[l-7]+g+de[l-16]|0}let{A:r,B:s,C:o,D:i,E:c,F:a,G:u,H:f}=this;for(let l=0;l<64;l++){const h=ne(c,6)^ne(c,11)^ne(c,25),w=f+h+jr(c,a,u)+Vr[l]+de[l]|0,d=(ne(r,2)^ne(r,13)^ne(r,22))+zr(r,s,o)|0;f=u,u=a,a=c,c=i+w|0,i=o,o=s,s=r,r=w+d|0}r=r+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,c=c+this.E|0,a=a+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(r,s,o,i,c,a,u,f)}roundClean(){de.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};const xt=qr(()=>new Dr);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const wn=BigInt(0),Xe=BigInt(1),Wr=BigInt(2),et=t=>t instanceof Uint8Array,Fr=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function Ne(t){if(!et(t))throw new Error("Uint8Array expected");let e="";for(let n=0;n<t.length;n++)e+=Fr[t[n]];return e}function pn(t){const e=t.toString(16);return e.length&1?`0${e}`:e}function vt(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);return BigInt(t===""?"0":`0x${t}`)}function Ce(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);const e=t.length;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);const n=new Uint8Array(e/2);for(let r=0;r<n.length;r++){const s=r*2,o=t.slice(s,s+2),i=Number.parseInt(o,16);if(Number.isNaN(i)||i<0)throw new Error("Invalid byte sequence");n[r]=i}return n}function G(t){return vt(Ne(t))}function St(t){if(!et(t))throw new Error("Uint8Array expected");return vt(Ne(Uint8Array.from(t).reverse()))}function he(t,e){return Ce(t.toString(16).padStart(e*2,"0"))}function _t(t,e){return he(t,e).reverse()}function Gr(t){return Ce(pn(t))}function z(t,e,n){let r;if(typeof e=="string")try{r=Ce(e)}catch(o){throw new Error(`${t} must be valid hex string, got "${e}". Cause: ${o}`)}else if(et(e))r=Uint8Array.from(e);else throw new Error(`${t} must be hex string or Uint8Array`);const s=r.length;if(typeof n=="number"&&s!==n)throw new Error(`${t} expected ${n} bytes, got ${s}`);return r}function xe(...t){const e=new Uint8Array(t.reduce((r,s)=>r+s.length,0));let n=0;return t.forEach(r=>{if(!et(r))throw new Error("Uint8Array expected");e.set(r,n),n+=r.length}),e}function Zr(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]!==e[n])return!1;return!0}function Jr(t){if(typeof t!="string")throw new Error(`utf8ToBytes expected string, got ${typeof t}`);return new Uint8Array(new TextEncoder().encode(t))}function Yr(t){let e;for(e=0;t>wn;t>>=Xe,e+=1);return e}function Qr(t,e){return t>>BigInt(e)&Xe}const Xr=(t,e,n)=>t|(n?Xe:wn)<<BigInt(e),At=t=>(Wr<<BigInt(t-1))-Xe,kt=t=>new Uint8Array(t),yn=t=>Uint8Array.from(t);function gn(t,e,n){if(typeof t!="number"||t<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof n!="function")throw new Error("hmacFn must be a function");let r=kt(t),s=kt(t),o=0;const i=()=>{r.fill(1),s.fill(0),o=0},c=(...l)=>n(s,r,...l),a=(l=kt())=>{s=c(yn([0]),l),r=c(),l.length!==0&&(s=c(yn([1]),l),r=c())},u=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let l=0;const h=[];for(;l<e;){r=c();const w=r.slice();h.push(w),l+=r.length}return xe(...h)};return(l,h)=>{i(),a(l);let w;for(;!(w=h(u()));)a();return i(),w}}const es={bigint:t=>typeof t=="bigint",function:t=>typeof t=="function",boolean:t=>typeof t=="boolean",string:t=>typeof t=="string",stringOrUint8Array:t=>typeof t=="string"||t instanceof Uint8Array,isSafeInteger:t=>Number.isSafeInteger(t),array:t=>Array.isArray(t),field:(t,e)=>e.Fp.isValid(t),hash:t=>typeof t=="function"&&Number.isSafeInteger(t.outputLen)};function je(t,e,n={}){const r=(s,o,i)=>{const c=es[o];if(typeof c!="function")throw new Error(`Invalid validator "${o}", expected function`);const a=t[s];if(!(i&&a===void 0)&&!c(a,t))throw new Error(`Invalid param ${String(s)}=${a} (${typeof a}), expected ${o}`)};for(const[s,o]of Object.entries(e))r(s,o,!1);for(const[s,o]of Object.entries(n))r(s,o,!0);return t}const ts=Object.freeze(Object.defineProperty({__proto__:null,bitGet:Qr,bitLen:Yr,bitMask:At,bitSet:Xr,bytesToHex:Ne,bytesToNumberBE:G,bytesToNumberLE:St,concatBytes:xe,createHmacDrbg:gn,ensureBytes:z,equalBytes:Zr,hexToBytes:Ce,hexToNumber:vt,numberToBytesBE:he,numberToBytesLE:_t,numberToHexUnpadded:pn,numberToVarBytesBE:Gr,utf8ToBytes:Jr,validateObject:je},Symbol.toStringTag,{value:"Module"}));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const L=BigInt(0),R=BigInt(1),ve=BigInt(2),ns=BigInt(3),Bt=BigInt(4),bn=BigInt(5),mn=BigInt(8);BigInt(9),BigInt(16);function K(t,e){const n=t%e;return n>=L?n:e+n}function rs(t,e,n){if(n<=L||e<L)throw new Error("Expected power/modulo > 0");if(n===R)return L;let r=R;for(;e>L;)e&R&&(r=r*t%n),t=t*t%n,e>>=R;return r}function Q(t,e,n){let r=t;for(;e-- >L;)r*=r,r%=n;return r}function $t(t,e){if(t===L||e<=L)throw new Error(`invert: expected positive integers, got n=${t} mod=${e}`);let n=K(t,e),r=e,s=L,o=R;for(;n!==L;){const c=r/n,a=r%n,u=s-o*c;r=n,n=a,s=o,o=u}if(r!==R)throw new Error("invert: does not exist");return K(s,e)}function ss(t){const e=(t-R)/ve;let n,r,s;for(n=t-R,r=0;n%ve===L;n/=ve,r++);for(s=ve;s<t&&rs(s,e,t)!==t-R;s++);if(r===1){const i=(t+R)/Bt;return function(a,u){const f=a.pow(u,i);if(!a.eql(a.sqr(f),u))throw new Error("Cannot find square root");return f}}const o=(n+R)/ve;return function(c,a){if(c.pow(a,e)===c.neg(c.ONE))throw new Error("Cannot find square root");let u=r,f=c.pow(c.mul(c.ONE,s),n),l=c.pow(a,o),h=c.pow(a,n);for(;!c.eql(h,c.ONE);){if(c.eql(h,c.ZERO))return c.ZERO;let w=1;for(let d=c.sqr(h);w<u&&!c.eql(d,c.ONE);w++)d=c.sqr(d);const g=c.pow(f,R<<BigInt(u-w-1));f=c.sqr(g),l=c.mul(l,g),h=c.mul(h,f),u=w}return l}}function os(t){if(t%Bt===ns){const e=(t+R)/Bt;return function(r,s){const o=r.pow(s,e);if(!r.eql(r.sqr(o),s))throw new Error("Cannot find square root");return o}}if(t%mn===bn){const e=(t-bn)/mn;return function(r,s){const o=r.mul(s,ve),i=r.pow(o,e),c=r.mul(s,i),a=r.mul(r.mul(c,ve),i),u=r.mul(c,r.sub(a,r.ONE));if(!r.eql(r.sqr(u),s))throw new Error("Cannot find square root");return u}}return ss(t)}const is=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function cs(t){const e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},n=is.reduce((r,s)=>(r[s]="function",r),e);return je(t,n)}function as(t,e,n){if(n<L)throw new Error("Expected power > 0");if(n===L)return t.ONE;if(n===R)return e;let r=t.ONE,s=e;for(;n>L;)n&R&&(r=t.mul(r,s)),s=t.sqr(s),n>>=R;return r}function ls(t,e){const n=new Array(e.length),r=e.reduce((o,i,c)=>t.is0(i)?o:(n[c]=o,t.mul(o,i)),t.ONE),s=t.inv(r);return e.reduceRight((o,i,c)=>t.is0(i)?o:(n[c]=t.mul(o,n[c]),t.mul(o,i)),s),n}function En(t,e){const n=e!==void 0?e:t.toString(2).length,r=Math.ceil(n/8);return{nBitLength:n,nByteLength:r}}function us(t,e,n=!1,r={}){if(t<=L)throw new Error(`Expected Field ORDER > 0, got ${t}`);const{nBitLength:s,nByteLength:o}=En(t,e);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");const i=os(t),c=Object.freeze({ORDER:t,BITS:s,BYTES:o,MASK:At(s),ZERO:L,ONE:R,create:a=>K(a,t),isValid:a=>{if(typeof a!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof a}`);return L<=a&&a<t},is0:a=>a===L,isOdd:a=>(a&R)===R,neg:a=>K(-a,t),eql:(a,u)=>a===u,sqr:a=>K(a*a,t),add:(a,u)=>K(a+u,t),sub:(a,u)=>K(a-u,t),mul:(a,u)=>K(a*u,t),pow:(a,u)=>as(c,a,u),div:(a,u)=>K(a*$t(u,t),t),sqrN:a=>a*a,addN:(a,u)=>a+u,subN:(a,u)=>a-u,mulN:(a,u)=>a*u,inv:a=>$t(a,t),sqrt:r.sqrt||(a=>i(c,a)),invertBatch:a=>ls(c,a),cmov:(a,u,f)=>f?u:a,toBytes:a=>n?_t(a,o):he(a,o),fromBytes:a=>{if(a.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${a.length}`);return n?St(a):G(a)}});return Object.freeze(c)}function xn(t){if(typeof t!="bigint")throw new Error("field order must be bigint");const e=t.toString(2).length;return Math.ceil(e/8)}function vn(t){const e=xn(t);return e+Math.ceil(e/2)}function fs(t,e,n=!1){const r=t.length,s=xn(e),o=vn(e);if(r<16||r<o||r>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${r}`);const i=n?G(t):St(t),c=K(i,e-R)+R;return n?_t(c,s):he(c,s)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ds=BigInt(0),Ot=BigInt(1);function hs(t,e){const n=(s,o)=>{const i=o.negate();return s?i:o},r=s=>{const o=Math.ceil(e/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:n,unsafeLadder(s,o){let i=t.ZERO,c=s;for(;o>ds;)o&Ot&&(i=i.add(c)),c=c.double(),o>>=Ot;return i},precomputeWindow(s,o){const{windows:i,windowSize:c}=r(o),a=[];let u=s,f=u;for(let l=0;l<i;l++){f=u,a.push(f);for(let h=1;h<c;h++)f=f.add(u),a.push(f);u=f.double()}return a},wNAF(s,o,i){const{windows:c,windowSize:a}=r(s);let u=t.ZERO,f=t.BASE;const l=BigInt(2**s-1),h=2**s,w=BigInt(s);for(let g=0;g<c;g++){const d=g*a;let p=Number(i&l);i>>=w,p>a&&(p-=h,i+=Ot);const m=d,x=d+Math.abs(p)-1,S=g%2!==0,$=p<0;p===0?f=f.add(n(S,o[m])):u=u.add(n($,o[x]))}return{p:u,f}},wNAFCached(s,o,i,c){const a=s._WINDOW_SIZE||1;let u=o.get(s);return u||(u=this.precomputeWindow(s,a),a!==1&&o.set(s,c(u))),this.wNAF(a,u,i)}}}function Sn(t){return cs(t.Fp),je(t,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...En(t.n,t.nBitLength),...t,p:t.Fp.ORDER})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function ws(t){const e=Sn(t);je(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});const{endo:n,Fp:r,a:s}=e;if(n){if(!r.eql(s,r.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof n!="object"||typeof n.beta!="bigint"||typeof n.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}const{bytesToNumberBE:ps,hexToBytes:ys}=ts,Se={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(t){const{Err:e}=Se;if(t.length<2||t[0]!==2)throw new e("Invalid signature integer tag");const n=t[1],r=t.subarray(2,n+2);if(!n||r.length!==n)throw new e("Invalid signature integer: wrong length");if(r[0]&128)throw new e("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:ps(r),l:t.subarray(n+2)}},toSig(t){const{Err:e}=Se,n=typeof t=="string"?ys(t):t;if(!(n instanceof Uint8Array))throw new Error("ui8a expected");let r=n.length;if(r<2||n[0]!=48)throw new e("Invalid signature tag");if(n[1]!==r-2)throw new e("Invalid signature: incorrect length");const{d:s,l:o}=Se._parseInt(n.subarray(2)),{d:i,l:c}=Se._parseInt(o);if(c.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(t){const e=u=>Number.parseInt(u[0],16)&8?"00"+u:u,n=u=>{const f=u.toString(16);return f.length&1?`0${f}`:f},r=e(n(t.s)),s=e(n(t.r)),o=r.length/2,i=s.length/2,c=n(o),a=n(i);return`30${n(i+o+4)}02${a}${s}02${c}${r}`}},oe=BigInt(0),X=BigInt(1);BigInt(2);const _n=BigInt(3);BigInt(4);function gs(t){const e=ws(t),{Fp:n}=e,r=e.toBytes||((g,d,p)=>{const m=d.toAffine();return xe(Uint8Array.from([4]),n.toBytes(m.x),n.toBytes(m.y))}),s=e.fromBytes||(g=>{const d=g.subarray(1),p=n.fromBytes(d.subarray(0,n.BYTES)),m=n.fromBytes(d.subarray(n.BYTES,2*n.BYTES));return{x:p,y:m}});function o(g){const{a:d,b:p}=e,m=n.sqr(g),x=n.mul(m,g);return n.add(n.add(x,n.mul(g,d)),p)}if(!n.eql(n.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return typeof g=="bigint"&&oe<g&&g<e.n}function c(g){if(!i(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function a(g){const{allowedPrivateKeyLengths:d,nByteLength:p,wrapPrivateKey:m,n:x}=e;if(d&&typeof g!="bigint"){if(g instanceof Uint8Array&&(g=Ne(g)),typeof g!="string"||!d.includes(g.length))throw new Error("Invalid key");g=g.padStart(p*2,"0")}let S;try{S=typeof g=="bigint"?g:G(z("private key",g,p))}catch{throw new Error(`private key must be ${p} bytes, hex or bigint, not ${typeof g}`)}return m&&(S=K(S,x)),c(S),S}const u=new Map;function f(g){if(!(g instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,p,m){if(this.px=d,this.py=p,this.pz=m,d==null||!n.isValid(d))throw new Error("x required");if(p==null||!n.isValid(p))throw new Error("y required");if(m==null||!n.isValid(m))throw new Error("z required")}static fromAffine(d){const{x:p,y:m}=d||{};if(!d||!n.isValid(p)||!n.isValid(m))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");const x=S=>n.eql(S,n.ZERO);return x(p)&&x(m)?l.ZERO:new l(p,m,n.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){const p=n.invertBatch(d.map(m=>m.pz));return d.map((m,x)=>m.toAffine(p[x])).map(l.fromAffine)}static fromHex(d){const p=l.fromAffine(s(z("pointHex",d)));return p.assertValidity(),p}static fromPrivateKey(d){return l.BASE.multiply(a(d))}_setWindowSize(d){this._WINDOW_SIZE=d,u.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!n.is0(this.py))return;throw new Error("bad point: ZERO")}const{x:d,y:p}=this.toAffine();if(!n.isValid(d)||!n.isValid(p))throw new Error("bad point: x or y not FE");const m=n.sqr(p),x=o(d);if(!n.eql(m,x))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){const{y:d}=this.toAffine();if(n.isOdd)return!n.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);const{px:p,py:m,pz:x}=this,{px:S,py:$,pz:B}=d,v=n.eql(n.mul(p,B),n.mul(S,x)),_=n.eql(n.mul(m,B),n.mul($,x));return v&&_}negate(){return new l(this.px,n.neg(this.py),this.pz)}double(){const{a:d,b:p}=e,m=n.mul(p,_n),{px:x,py:S,pz:$}=this;let B=n.ZERO,v=n.ZERO,_=n.ZERO,k=n.mul(x,x),Z=n.mul(S,S),C=n.mul($,$),O=n.mul(x,S);return O=n.add(O,O),_=n.mul(x,$),_=n.add(_,_),B=n.mul(d,_),v=n.mul(m,C),v=n.add(B,v),B=n.sub(Z,v),v=n.add(Z,v),v=n.mul(B,v),B=n.mul(O,B),_=n.mul(m,_),C=n.mul(d,C),O=n.sub(k,C),O=n.mul(d,O),O=n.add(O,_),_=n.add(k,k),k=n.add(_,k),k=n.add(k,C),k=n.mul(k,O),v=n.add(v,k),C=n.mul(S,$),C=n.add(C,C),k=n.mul(C,O),B=n.sub(B,k),_=n.mul(C,Z),_=n.add(_,_),_=n.add(_,_),new l(B,v,_)}add(d){f(d);const{px:p,py:m,pz:x}=this,{px:S,py:$,pz:B}=d;let v=n.ZERO,_=n.ZERO,k=n.ZERO;const Z=e.a,C=n.mul(e.b,_n);let O=n.mul(p,S),W=n.mul(m,$),F=n.mul(x,B),re=n.add(p,m),y=n.add(S,$);re=n.mul(re,y),y=n.add(O,W),re=n.sub(re,y),y=n.add(p,x);let E=n.add(S,B);return y=n.mul(y,E),E=n.add(O,F),y=n.sub(y,E),E=n.add(m,x),v=n.add($,B),E=n.mul(E,v),v=n.add(W,F),E=n.sub(E,v),k=n.mul(Z,y),v=n.mul(C,F),k=n.add(v,k),v=n.sub(W,k),k=n.add(W,k),_=n.mul(v,k),W=n.add(O,O),W=n.add(W,O),F=n.mul(Z,F),y=n.mul(C,y),W=n.add(W,F),F=n.sub(O,F),F=n.mul(Z,F),y=n.add(y,F),O=n.mul(W,y),_=n.add(_,O),O=n.mul(E,y),v=n.mul(re,v),v=n.sub(v,O),O=n.mul(re,W),k=n.mul(E,k),k=n.add(k,O),new l(v,_,k)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return w.wNAFCached(this,u,d,p=>{const m=n.invertBatch(p.map(x=>x.pz));return p.map((x,S)=>x.toAffine(m[S])).map(l.fromAffine)})}multiplyUnsafe(d){const p=l.ZERO;if(d===oe)return p;if(c(d),d===X)return this;const{endo:m}=e;if(!m)return w.unsafeLadder(this,d);let{k1neg:x,k1:S,k2neg:$,k2:B}=m.splitScalar(d),v=p,_=p,k=this;for(;S>oe||B>oe;)S&X&&(v=v.add(k)),B&X&&(_=_.add(k)),k=k.double(),S>>=X,B>>=X;return x&&(v=v.negate()),$&&(_=_.negate()),_=new l(n.mul(_.px,m.beta),_.py,_.pz),v.add(_)}multiply(d){c(d);let p=d,m,x;const{endo:S}=e;if(S){const{k1neg:$,k1:B,k2neg:v,k2:_}=S.splitScalar(p);let{p:k,f:Z}=this.wNAF(B),{p:C,f:O}=this.wNAF(_);k=w.constTimeNegate($,k),C=w.constTimeNegate(v,C),C=new l(n.mul(C.px,S.beta),C.py,C.pz),m=k.add(C),x=Z.add(O)}else{const{p:$,f:B}=this.wNAF(p);m=$,x=B}return l.normalizeZ([m,x])[0]}multiplyAndAddUnsafe(d,p,m){const x=l.BASE,S=(B,v)=>v===oe||v===X||!B.equals(x)?B.multiplyUnsafe(v):B.multiply(v),$=S(this,p).add(S(d,m));return $.is0()?void 0:$}toAffine(d){const{px:p,py:m,pz:x}=this,S=this.is0();d==null&&(d=S?n.ONE:n.inv(x));const $=n.mul(p,d),B=n.mul(m,d),v=n.mul(x,d);if(S)return{x:n.ZERO,y:n.ZERO};if(!n.eql(v,n.ONE))throw new Error("invZ was invalid");return{x:$,y:B}}isTorsionFree(){const{h:d,isTorsionFree:p}=e;if(d===X)return!0;if(p)return p(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){const{h:d,clearCofactor:p}=e;return d===X?this:p?p(l,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return this.assertValidity(),r(l,this,d)}toHex(d=!0){return Ne(this.toRawBytes(d))}}l.BASE=new l(e.Gx,e.Gy,n.ONE),l.ZERO=new l(n.ZERO,n.ONE,n.ZERO);const h=e.nBitLength,w=hs(l,e.endo?Math.ceil(h/2):h);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:a,weierstrassEquation:o,isWithinCurveOrder:i}}function bs(t){const e=Sn(t);return je(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function ms(t){const e=bs(t),{Fp:n,n:r}=e,s=n.BYTES+1,o=2*n.BYTES+1;function i(y){return oe<y&&y<n.ORDER}function c(y){return K(y,r)}function a(y){return $t(y,r)}const{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:h}=gs({...e,toBytes(y,E,A){const N=E.toAffine(),I=n.toBytes(N.x),q=xe;return A?q(Uint8Array.from([E.hasEvenY()?2:3]),I):q(Uint8Array.from([4]),I,n.toBytes(N.y))},fromBytes(y){const E=y.length,A=y[0],N=y.subarray(1);if(E===s&&(A===2||A===3)){const I=G(N);if(!i(I))throw new Error("Point is not on curve");const q=l(I);let J=n.sqrt(q);const Y=(J&X)===X;return(A&1)===1!==Y&&(J=n.neg(J)),{x:I,y:J}}else if(E===o&&A===4){const I=n.fromBytes(N.subarray(0,n.BYTES)),q=n.fromBytes(N.subarray(n.BYTES,2*n.BYTES));return{x:I,y:q}}else throw new Error(`Point of length ${E} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),w=y=>Ne(he(y,e.nByteLength));function g(y){const E=r>>X;return y>E}function d(y){return g(y)?c(-y):y}const p=(y,E,A)=>G(y.slice(E,A));class m{constructor(E,A,N){this.r=E,this.s=A,this.recovery=N,this.assertValidity()}static fromCompact(E){const A=e.nByteLength;return E=z("compactSignature",E,A*2),new m(p(E,0,A),p(E,A,2*A))}static fromDER(E){const{r:A,s:N}=Se.toSig(z("DER",E));return new m(A,N)}assertValidity(){if(!h(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!h(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(E){return new m(this.r,this.s,E)}recoverPublicKey(E){const{r:A,s:N,recovery:I}=this,q=_(z("msgHash",E));if(I==null||![0,1,2,3].includes(I))throw new Error("recovery id invalid");const J=I===2||I===3?A+e.n:A;if(J>=n.ORDER)throw new Error("recovery id 2 or 3 invalid");const Y=I&1?"03":"02",ge=u.fromHex(Y+w(J)),be=a(J),Ue=c(-q*be),Ze=c(N*be),me=u.BASE.multiplyAndAddUnsafe(ge,Ue,Ze);if(!me)throw new Error("point at infinify");return me.assertValidity(),me}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return Ce(this.toDERHex())}toDERHex(){return Se.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ce(this.toCompactHex())}toCompactHex(){return w(this.r)+w(this.s)}}const x={isValidPrivateKey(y){try{return f(y),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{const y=vn(e.n);return fs(e.randomBytes(y),e.n)},precompute(y=8,E=u.BASE){return E._setWindowSize(y),E.multiply(BigInt(3)),E}};function S(y,E=!0){return u.fromPrivateKey(y).toRawBytes(E)}function $(y){const E=y instanceof Uint8Array,A=typeof y=="string",N=(E||A)&&y.length;return E?N===s||N===o:A?N===2*s||N===2*o:y instanceof u}function B(y,E,A=!0){if($(y))throw new Error("first arg must be private key");if(!$(E))throw new Error("second arg must be public key");return u.fromHex(E).multiply(f(y)).toRawBytes(A)}const v=e.bits2int||function(y){const E=G(y),A=y.length*8-e.nBitLength;return A>0?E>>BigInt(A):E},_=e.bits2int_modN||function(y){return c(v(y))},k=At(e.nBitLength);function Z(y){if(typeof y!="bigint")throw new Error("bigint expected");if(!(oe<=y&&y<k))throw new Error(`bigint expected < 2^${e.nBitLength}`);return he(y,e.nByteLength)}function C(y,E,A=O){if(["recovered","canonical"].some(ke=>ke in A))throw new Error("sign() legacy options not supported");const{hash:N,randomBytes:I}=e;let{lowS:q,prehash:J,extraEntropy:Y}=A;q==null&&(q=!0),y=z("msgHash",y),J&&(y=z("prehashed msgHash",N(y)));const ge=_(y),be=f(E),Ue=[Z(be),Z(ge)];if(Y!=null){const ke=Y===!0?I(n.BYTES):Y;Ue.push(z("extraEntropy",ke))}const Ze=xe(...Ue),me=ge;function Gt(ke){const He=v(ke);if(!h(He))return;const or=a(He),Le=u.BASE.multiply(He).toAffine(),ee=c(Le.x);if(ee===oe)return;const qe=c(or*c(me+ee*be));if(qe===oe)return;let ir=(Le.x===ee?0:2)|Number(Le.y&X),cr=qe;return q&&g(qe)&&(cr=d(qe),ir^=1),new m(ee,cr,ir)}return{seed:Ze,k2sig:Gt}}const O={lowS:e.lowS,prehash:!1},W={lowS:e.lowS,prehash:!1};function F(y,E,A=O){const{seed:N,k2sig:I}=C(y,E,A),q=e;return gn(q.hash.outputLen,q.nByteLength,q.hmac)(N,I)}u.BASE._setWindowSize(8);function re(y,E,A,N=W){var Le;const I=y;if(E=z("msgHash",E),A=z("publicKey",A),"strict"in N)throw new Error("options.strict was renamed to lowS");const{lowS:q,prehash:J}=N;let Y,ge;try{if(typeof I=="string"||I instanceof Uint8Array)try{Y=m.fromDER(I)}catch(ee){if(!(ee instanceof Se.Err))throw ee;Y=m.fromCompact(I)}else if(typeof I=="object"&&typeof I.r=="bigint"&&typeof I.s=="bigint"){const{r:ee,s:qe}=I;Y=new m(ee,qe)}else throw new Error("PARSE");ge=u.fromHex(A)}catch(ee){if(ee.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(q&&Y.hasHighS())return!1;J&&(E=e.hash(E));const{r:be,s:Ue}=Y,Ze=_(E),me=a(Ue),Gt=c(Ze*me),ke=c(be*me),He=(Le=u.BASE.multiplyAndAddUnsafe(ge,Gt,ke))==null?void 0:Le.toAffine();return He?c(He.x)===be:!1}return{CURVE:e,getPublicKey:S,getSharedSecret:B,sign:F,verify:re,ProjectivePoint:u,Signature:m,utils:x}}class An extends dn{constructor(e,n){super(),this.finished=!1,this.destroyed=!1,Rr(e);const r=Et(n);if(this.iHash=e.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;const s=this.blockLen,o=new Uint8Array(s);o.set(r.length>s?e.create().update(r).digest():r);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=e.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(e){return Qe(this),this.iHash.update(e),this}digestInto(e){Qe(this),un(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){const e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));const{oHash:n,iHash:r,finished:s,destroyed:o,blockLen:i,outputLen:c}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=c,e.oHash=n._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}const kn=(t,e,n)=>new An(t,e).update(n).digest();kn.create=(t,e)=>new An(t,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function Es(t){return{hash:t,hmac:(e,...n)=>kn(t,e,Lr(...n)),randomBytes:hn}}function xs(t,e){const n=r=>ms({...t,...Es(r)});return Object.freeze({...n(e),create:n})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const tt=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),nt=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Bn=BigInt(1),rt=BigInt(2),$n=(t,e)=>(t+e/rt)/e;function On(t){const e=tt,n=BigInt(3),r=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),u=t*t*t%e,f=u*u*t%e,l=Q(f,n,e)*f%e,h=Q(l,n,e)*f%e,w=Q(h,rt,e)*u%e,g=Q(w,s,e)*w%e,d=Q(g,o,e)*g%e,p=Q(d,c,e)*d%e,m=Q(p,a,e)*p%e,x=Q(m,c,e)*d%e,S=Q(x,n,e)*f%e,$=Q(S,i,e)*g%e,B=Q($,r,e)*u%e,v=Q(B,rt,e);if(!It.eql(It.sqr(v),t))throw new Error("Cannot find square root");return v}const It=us(tt,void 0,void 0,{sqrt:On}),ze=xs({a:BigInt(0),b:BigInt(7),Fp:It,n:nt,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:t=>{const e=nt,n=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),r=-Bn*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=n,i=BigInt("0x100000000000000000000000000000000"),c=$n(o*t,e),a=$n(-r*t,e);let u=K(t-c*n-a*s,e),f=K(-c*r-a*o,e);const l=u>i,h=f>i;if(l&&(u=e-u),h&&(f=e-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+t);return{k1neg:l,k1:u,k2neg:h,k2:f}}}},xt),st=BigInt(0),In=t=>typeof t=="bigint"&&st<t&&t<tt,vs=t=>typeof t=="bigint"&&st<t&&t<nt,Tn={};function ot(t,...e){let n=Tn[t];if(n===void 0){const r=xt(Uint8Array.from(t,s=>s.charCodeAt(0)));n=xe(r,r),Tn[t]=n}return xt(xe(n,...e))}const Tt=t=>t.toRawBytes(!0).slice(1),Nt=t=>he(t,32),Ct=t=>K(t,tt),Ve=t=>K(t,nt),Pt=ze.ProjectivePoint,Ss=(t,e,n)=>Pt.BASE.multiplyAndAddUnsafe(t,e,n);function Rt(t){let e=ze.utils.normPrivateKeyToScalar(t),n=Pt.fromPrivateKey(e);return{scalar:n.hasEvenY()?e:Ve(-e),bytes:Tt(n)}}function Nn(t){if(!In(t))throw new Error("bad x: need 0 < x < p");const e=Ct(t*t),n=Ct(e*t+BigInt(7));let r=On(n);r%rt!==st&&(r=Ct(-r));const s=new Pt(t,r,Bn);return s.assertValidity(),s}function Cn(...t){return Ve(G(ot("BIP0340/challenge",...t)))}function _s(t){return Rt(t).bytes}function As(t,e,n=hn(32)){const r=z("message",t),{bytes:s,scalar:o}=Rt(e),i=z("auxRand",n,32),c=Nt(o^G(ot("BIP0340/aux",i))),a=ot("BIP0340/nonce",c,s,r),u=Ve(G(a));if(u===st)throw new Error("sign failed: k is zero");const{bytes:f,scalar:l}=Rt(u),h=Cn(f,s,r),w=new Uint8Array(64);if(w.set(f,0),w.set(Nt(Ve(l+h*o)),32),!Pn(w,r,s))throw new Error("sign: Invalid signature produced");return w}function Pn(t,e,n){const r=z("signature",t,64),s=z("message",e),o=z("publicKey",n,32);try{const i=Nn(G(o)),c=G(r.subarray(0,32));if(!In(c))return!1;const a=G(r.subarray(32,64));if(!vs(a))return!1;const u=Cn(Nt(c),Tt(i),s),f=Ss(i,a,Ve(-u));return!(!f||!f.hasEvenY()||f.toAffine().x!==c)}catch{return!1}}const D={getPublicKey:_s,sign:As,verify:Pn,utils:{randomPrivateKey:ze.utils.randomPrivateKey,lift_x:Nn,pointToBytes:Tt,numberToBytesBE:he,bytesToNumberBE:G,taggedHash:ot,mod:K}};function Ut(t){if(!Number.isSafeInteger(t)||t<0)throw new Error(`Wrong positive integer: ${t}`)}function ks(t){if(typeof t!="boolean")throw new Error(`Expected boolean, not ${t}`)}function Rn(t,...e){if(!(t instanceof Uint8Array))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(t.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${t.length}`)}function Bs(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Ut(t.outputLen),Ut(t.blockLen)}function $s(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function Os(t,e){Rn(t);const n=e.outputLen;if(t.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const Ht={number:Ut,bool:ks,bytes:Rn,hash:Bs,exists:$s,output:Os};function Is(t,e,n,r){if(typeof t.setBigUint64=="function")return t.setBigUint64(e,n,r);const s=BigInt(32),o=BigInt(4294967295),i=Number(n>>s&o),c=Number(n&o),a=r?4:0,u=r?0:4;t.setUint32(e+a,i,r),t.setUint32(e+u,c,r)}class Ts extends Cr{constructor(e,n,r,s){super(),this.blockLen=e,this.outputLen=n,this.padOffset=r,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=yt(this.buffer)}update(e){Ht.exists(this);const{view:n,buffer:r,blockLen:s}=this;e=cn(e);const o=e.length;for(let i=0;i<o;){const c=Math.min(s-this.pos,o-i);if(c===s){const a=yt(e);for(;s<=o-i;i+=s)this.process(a,i);continue}r.set(e.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===s&&(this.process(n,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Ht.exists(this),Ht.output(e,this),this.finished=!0;const{buffer:n,view:r,blockLen:s,isLE:o}=this;let{pos:i}=this;n[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(r,0),i=0);for(let l=i;l<s;l++)n[l]=0;Is(r,s-8,BigInt(this.length*8),o),this.process(r,0);const c=yt(e),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const u=a/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)c.setUint32(4*l,f[l],o)}digest(){const{buffer:e,outputLen:n}=this;this.digestInto(e);const r=e.slice(0,n);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:n,buffer:r,length:s,finished:o,destroyed:i,pos:c}=this;return e.length=s,e.pos=c,e.finished=o,e.destroyed=i,s%n&&e.buffer.set(r),e}}const Ns=(t,e,n)=>t&e^~t&n,Cs=(t,e,n)=>t&e^t&n^e&n,Ps=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),pe=new Uint32Array(64);class Un extends Ts{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){const{A:e,B:n,C:r,D:s,E:o,F:i,G:c,H:a}=this;return[e,n,r,s,o,i,c,a]}set(e,n,r,s,o,i,c,a){this.A=e|0,this.B=n|0,this.C=r|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=c|0,this.H=a|0}process(e,n){for(let l=0;l<16;l++,n+=4)pe[l]=e.getUint32(n,!1);for(let l=16;l<64;l++){const h=pe[l-15],w=pe[l-2],g=te(h,7)^te(h,18)^h>>>3,d=te(w,17)^te(w,19)^w>>>10;pe[l]=d+pe[l-7]+g+pe[l-16]|0}let{A:r,B:s,C:o,D:i,E:c,F:a,G:u,H:f}=this;for(let l=0;l<64;l++){const h=te(c,6)^te(c,11)^te(c,25),w=f+h+Ns(c,a,u)+Ps[l]+pe[l]|0,d=(te(r,2)^te(r,13)^te(r,22))+Cs(r,s,o)|0;f=u,u=a,a=c,c=i+w|0,i=o,o=s,s=r,r=w+d|0}r=r+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,c=c+this.E|0,a=a+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(r,s,o,i,c,a,u,f)}roundClean(){pe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}}class Rs extends Un{constructor(){super(),this.A=-1056596264,this.B=914150663,this.C=812702999,this.D=-150054599,this.E=-4191439,this.F=1750603025,this.G=1694076839,this.H=-1090891868,this.outputLen=28}}const Lt=an(()=>new Un);an(()=>new Rs);var Pe=Symbol("verified"),Us=t=>t instanceof Object;function Hs(t){if(!Us(t)||typeof t.kind!="number"||typeof t.content!="string"||typeof t.created_at!="number"||typeof t.pubkey!="string"||!t.pubkey.match(/^[a-f0-9]{64}$/)||!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){let n=t.tags[e];if(!Array.isArray(n))return!1;for(let r=0;r<n.length;r++)if(typeof n[r]=="object")return!1}return!0}new TextDecoder("utf-8");var Ls=new TextEncoder,qs=class{generateSecretKey(){return D.utils.randomPrivateKey()}getPublicKey(e){return V(D.getPublicKey(e))}finalizeEvent(e,n){const r=e;return r.pubkey=V(D.getPublicKey(n)),r.id=qt(r),r.sig=V(D.sign(qt(r),n)),r[Pe]=!0,r}verifyEvent(e){if(typeof e[Pe]=="boolean")return e[Pe];const n=qt(e);if(n!==e.id)return e[Pe]=!1,!1;try{const r=D.verify(e.sig,n,e.pubkey);return e[Pe]=r,r}catch{return e[Pe]=!1,!1}}};function Ms(t){if(!Hs(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function qt(t){let e=Lt(Ls.encode(Ms(t)));return V(e)}var it=new qs,Ks=it.generateSecretKey;it.getPublicKey,it.finalizeEvent,it.verifyEvent;var _e=Symbol("verified"),js=t=>t instanceof Object;function zs(t){if(!js(t)||typeof t.kind!="number"||typeof t.content!="string"||typeof t.created_at!="number"||typeof t.pubkey!="string"||!t.pubkey.match(/^[a-f0-9]{64}$/)||!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){let n=t.tags[e];if(!Array.isArray(n))return!1;for(let r=0;r<n.length;r++)if(typeof n[r]=="object")return!1}return!0}new TextDecoder("utf-8");var Vs=new TextEncoder;function De(t){t.indexOf("://")===-1&&(t="wss://"+t);let e=new URL(t);return e.pathname=e.pathname.replace(/\/+/g,"/"),e.pathname.endsWith("/")&&(e.pathname=e.pathname.slice(0,-1)),(e.port==="80"&&e.protocol==="ws:"||e.port==="443"&&e.protocol==="wss:")&&(e.port=""),e.searchParams.sort(),e.hash="",e.toString()}var Ds=class{constructor(e){b(this,"value");b(this,"next",null);b(this,"prev",null);this.value=e}},Ws=class{constructor(){b(this,"first");b(this,"last");this.first=null,this.last=null}enqueue(e){const n=new Ds(e);return this.last?this.last===this.first?(this.last=n,this.last.prev=this.first,this.first.next=n):(n.prev=this.last,this.last.next=n,this.last=n):(this.first=n,this.last=n),!0}dequeue(){if(!this.first)return null;if(this.first===this.last){const n=this.first;return this.first=null,this.last=null,n.value}const e=this.first;return this.first=e.next,e.value}},Fs=class{generateSecretKey(){return D.utils.randomPrivateKey()}getPublicKey(e){return V(D.getPublicKey(e))}finalizeEvent(e,n){const r=e;return r.pubkey=V(D.getPublicKey(n)),r.id=Mt(r),r.sig=V(D.sign(Mt(r),n)),r[_e]=!0,r}verifyEvent(e){if(typeof e[_e]=="boolean")return e[_e];const n=Mt(e);if(n!==e.id)return e[_e]=!1,!1;try{const r=D.verify(e.sig,n,e.pubkey);return e[_e]=r,r}catch{return e[_e]=!1,!1}}};function Gs(t){if(!zs(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function Mt(t){let e=Lt(Vs.encode(Gs(t)));return V(e)}var ct=new Fs;ct.generateSecretKey,ct.getPublicKey,ct.finalizeEvent;var Zs=ct.verifyEvent,Js=22242;function Ys(t,e){if(t.ids&&t.ids.indexOf(e.id)===-1&&!t.ids.some(n=>e.id.startsWith(n))||t.kinds&&t.kinds.indexOf(e.kind)===-1||t.authors&&t.authors.indexOf(e.pubkey)===-1&&!t.authors.some(n=>e.pubkey.startsWith(n)))return!1;for(let n in t)if(n[0]==="#"){let r=n.slice(1),s=t[`#${r}`];if(s&&!e.tags.find(([o,i])=>o===n.slice(1)&&s.indexOf(i)!==-1))return!1}return!(t.since&&e.created_at<t.since||t.until&&e.created_at>t.until)}function Qs(t,e){for(let n=0;n<t.length;n++)if(Ys(t[n],e))return!0;return!1}function Xs(t,e){let n=e.length+3,r=t.indexOf(`"${e}":`)+n,s=t.slice(r).indexOf('"')+r+1;return t.slice(s,s+64)}function eo(t){let e=t.slice(0,22).indexOf('"EVENT"');if(e===-1)return null;let n=t.slice(e+7+1).indexOf('"');if(n===-1)return null;let r=e+7+1+n,s=t.slice(r+1,80).indexOf('"');if(s===-1)return null;let o=r+1+s;return t.slice(r+1,o)}function to(t,e){return{kind:Js,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t],["challenge",e]],content:""}}async function no(){return new Promise(t=>{const e=new MessageChannel,n=()=>{e.port1.removeEventListener("message",n),t()};e.port1.addEventListener("message",n),e.port2.postMessage(0),e.port1.start()})}var ro=t=>(t[_e]=!0,!0),Hn;try{Hn=WebSocket}catch{}var Ln=class{constructor(e,n){b(this,"url");b(this,"_connected",!1);b(this,"onclose",null);b(this,"onnotice",e=>console.debug(`NOTICE from ${this.url}: ${e}`));b(this,"baseEoseTimeout",4400);b(this,"connectionTimeout",4400);b(this,"openSubs",new Map);b(this,"connectionTimeoutHandle");b(this,"connectionPromise");b(this,"openCountRequests",new Map);b(this,"openEventPublishes",new Map);b(this,"ws");b(this,"incomingMessageQueue",new Ws);b(this,"queueRunning",!1);b(this,"challenge");b(this,"serial",0);b(this,"verifyEvent");this.url=De(e),this.verifyEvent=n.verifyEvent}static async connect(e,n){const r=new Ln(e,n);return await r.connect(),r}closeAllSubscriptions(e){for(let[n,r]of this.openSubs)r.close(e);this.openSubs.clear();for(let[n,r]of this.openEventPublishes)r.reject(new Error(e));this.openEventPublishes.clear();for(let[n,r]of this.openCountRequests)r.reject(new Error(e));this.openCountRequests.clear()}get connected(){return this._connected}async connect(){return this.connectionPromise?this.connectionPromise:(this.challenge=void 0,this.connectionPromise=new Promise((e,n)=>{this.connectionTimeoutHandle=setTimeout(()=>{var r;n("connection timed out"),this.connectionPromise=void 0,(r=this.onclose)==null||r.call(this),this.closeAllSubscriptions("relay connection timed out")},this.connectionTimeout);try{this.ws=new Hn(this.url)}catch(r){n(r);return}this.ws.onopen=()=>{clearTimeout(this.connectionTimeoutHandle),this._connected=!0,e()},this.ws.onerror=r=>{var s;n(r.message),this._connected&&((s=this.onclose)==null||s.call(this),this.closeAllSubscriptions("relay connection errored"),this._connected=!1)},this.ws.onclose=async()=>{var r;this.connectionPromise=void 0,(r=this.onclose)==null||r.call(this),this.closeAllSubscriptions("relay connection closed"),this._connected=!1},this.ws.onmessage=this._onmessage.bind(this)}),this.connectionPromise)}async runQueue(){for(this.queueRunning=!0;this.handleNext()!==!1;)await no();this.queueRunning=!1}handleNext(){var r,s;const e=this.incomingMessageQueue.dequeue();if(!e)return!1;const n=eo(e);if(n){const o=this.openSubs.get(n);if(!o)return;const i=Xs(e,"id"),c=(r=o.alreadyHaveEvent)==null?void 0:r.call(o,i);if((s=o.receivedEvent)==null||s.call(o,this,i),c)return}try{let o=JSON.parse(e);switch(o[0]){case"EVENT":{const i=this.openSubs.get(o[1]),c=o[2];this.verifyEvent(c)&&Qs(i.filters,c)&&i.onevent(c);return}case"COUNT":{const i=o[1],c=o[2],a=this.openCountRequests.get(i);a&&(a.resolve(c.count),this.openCountRequests.delete(i));return}case"EOSE":{const i=this.openSubs.get(o[1]);if(!i)return;i.receivedEose();return}case"OK":{const i=o[1],c=o[2],a=o[3],u=this.openEventPublishes.get(i);c?u.resolve(a):u.reject(new Error(a)),this.openEventPublishes.delete(i);return}case"CLOSED":{const i=o[1],c=this.openSubs.get(i);if(!c)return;c.closed=!0,c.close(o[2]);return}case"NOTICE":this.onnotice(o[1]);return;case"AUTH":{this.challenge=o[1];return}}}catch{return}}async send(e){if(!this.connectionPromise)throw new Error("sending on closed connection");this.connectionPromise.then(()=>{var n;(n=this.ws)==null||n.send(e)})}async auth(e){if(!this.challenge)throw new Error("can't perform auth, no challenge was received");const n=await e(to(this.url,this.challenge)),r=new Promise((s,o)=>{this.openEventPublishes.set(n.id,{resolve:s,reject:o})});return this.send('["AUTH",'+JSON.stringify(n)+"]"),r}async publish(e){const n=new Promise((r,s)=>{this.openEventPublishes.set(e.id,{resolve:r,reject:s})});return this.send('["EVENT",'+JSON.stringify(e)+"]"),n}async count(e,n){this.serial++;const r=(n==null?void 0:n.id)||"count:"+this.serial,s=new Promise((o,i)=>{this.openCountRequests.set(r,{resolve:o,reject:i})});return this.send('["COUNT","'+r+'",'+JSON.stringify(e)+"]"),s}subscribe(e,n){const r=this.prepareSubscription(e,n);return r.fire(),r}prepareSubscription(e,n){this.serial++;const r=n.id||"sub:"+this.serial,s=new so(this,r,e,n);return this.openSubs.set(r,s),s}close(){var e;this.closeAllSubscriptions("relay connection closed by us"),this._connected=!1,(e=this.ws)==null||e.close()}_onmessage(e){this.incomingMessageQueue.enqueue(e.data),this.queueRunning||this.runQueue()}},so=class{constructor(e,n,r,s){b(this,"relay");b(this,"id");b(this,"closed",!1);b(this,"eosed",!1);b(this,"filters");b(this,"alreadyHaveEvent");b(this,"receivedEvent");b(this,"onevent");b(this,"oneose");b(this,"onclose");b(this,"eoseTimeout");b(this,"eoseTimeoutHandle");this.relay=e,this.filters=r,this.id=n,this.alreadyHaveEvent=s.alreadyHaveEvent,this.receivedEvent=s.receivedEvent,this.eoseTimeout=s.eoseTimeout||e.baseEoseTimeout,this.oneose=s.oneose,this.onclose=s.onclose,this.onevent=s.onevent||(o=>{console.warn(`onevent() callback not defined for subscription '${this.id}' in relay ${this.relay.url}. event received:`,o)})}fire(){this.relay.send('["REQ","'+this.id+'",'+JSON.stringify(this.filters).substring(1)),this.eoseTimeoutHandle=setTimeout(this.receivedEose.bind(this),this.eoseTimeout)}receivedEose(){var e;this.eosed||(clearTimeout(this.eoseTimeoutHandle),this.eosed=!0,(e=this.oneose)==null||e.call(this))}close(e="closed by caller"){var n;this.closed||(this.relay.send('["CLOSE",'+JSON.stringify(this.id)+"]"),this.closed=!0),this.relay.openSubs.delete(this.id),(n=this.onclose)==null||n.call(this,e)}},oo=class{constructor(e){b(this,"relays",new Map);b(this,"seenOn",new Map);b(this,"trackRelays",!1);b(this,"verifyEvent");b(this,"trustedRelayURLs",new Set);this.verifyEvent=e.verifyEvent}async ensureRelay(e,n){e=De(e);let r=this.relays.get(e);return r||(r=new Ln(e,{verifyEvent:this.trustedRelayURLs.has(e)?ro:this.verifyEvent}),n!=null&&n.connectionTimeout&&(r.connectionTimeout=n.connectionTimeout),this.relays.set(e,r)),await r.connect(),r}close(e){e.map(De).forEach(n=>{var r;(r=this.relays.get(n))==null||r.close()})}subscribeMany(e,n,r){this.trackRelays&&(r.receivedEvent=(h,w)=>{let g=this.seenOn.get(w);g||(g=new Set,this.seenOn.set(w,g)),g.add(h)});const s=new Set,o=[],i=[];let c=h=>{var w;i[h]=!0,i.filter(g=>g).length===e.length&&((w=r.oneose)==null||w.call(r),c=()=>{})};const a=[];let u=(h,w)=>{var g;c(h),a[h]=w,a.filter(d=>d).length===e.length&&((g=r.onclose)==null||g.call(r,a),u=()=>{})};const f=h=>{var g;if((g=r.alreadyHaveEvent)!=null&&g.call(r,h))return!0;const w=s.has(h);return s.add(h),w},l=Promise.all(e.map(De).map(async(h,w,g)=>{if(g.indexOf(h)!==w){u(w,"duplicate url");return}let d;try{d=await this.ensureRelay(h,{connectionTimeout:r.maxWait?Math.max(r.maxWait*.8,r.maxWait-1e3):void 0})}catch(m){u(w,(m==null?void 0:m.message)||String(m));return}let p=d.subscribe(n,{...r,oneose:()=>c(w),onclose:m=>u(w,m),alreadyHaveEvent:f,eoseTimeout:r.maxWait});o.push(p)}));return{async close(){await l,o.forEach(h=>{h.close()})}}}subscribeManyEose(e,n,r){const s=this.subscribeMany(e,n,{...r,oneose(){s.close()}});return s}async querySync(e,n,r){return new Promise(async s=>{const o=[];this.subscribeManyEose(e,[n],{...r,onevent(i){o.push(i)},onclose(i){s(o)}})})}async get(e,n,r){n.limit=1;const s=await this.querySync(e,n,r);return s.sort((o,i)=>i.created_at-o.created_at),s[0]||null}publish(e,n){return e.map(De).map(async(r,s,o)=>o.indexOf(r)!==s?Promise.reject("duplicate url"):(await this.ensureRelay(r)).publish(n))}},io=class extends oo{constructor(){super({verifyEvent:Zs})}};/*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */function Re(t){if(!Number.isSafeInteger(t))throw new Error(`Wrong integer: ${t}`)}function ie(...t){const e=(s,o)=>i=>s(o(i)),n=Array.from(t).reverse().reduce((s,o)=>s?e(s,o.encode):o.encode,void 0),r=t.reduce((s,o)=>s?e(s,o.decode):o.decode,void 0);return{encode:n,decode:r}}function ce(t){return{encode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="number")throw new Error("alphabet.encode input should be an array of numbers");return e.map(n=>{if(Re(n),n<0||n>=t.length)throw new Error(`Digit index outside alphabet: ${n} (alphabet: ${t.length})`);return t[n]})},decode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="string")throw new Error("alphabet.decode input should be array of strings");return e.map(n=>{if(typeof n!="string")throw new Error(`alphabet.decode: not string element=${n}`);const r=t.indexOf(n);if(r===-1)throw new Error(`Unknown letter: "${n}". Allowed: ${t}`);return r})}}}function ae(t=""){if(typeof t!="string")throw new Error("join separator should be string");return{encode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="string")throw new Error("join.encode input should be array of strings");for(let n of e)if(typeof n!="string")throw new Error(`join.encode: non-string input=${n}`);return e.join(t)},decode:e=>{if(typeof e!="string")throw new Error("join.decode input should be string");return e.split(t)}}}function at(t,e="="){if(Re(t),typeof e!="string")throw new Error("padding chr should be string");return{encode(n){if(!Array.isArray(n)||n.length&&typeof n[0]!="string")throw new Error("padding.encode input should be array of strings");for(let r of n)if(typeof r!="string")throw new Error(`padding.encode: non-string input=${r}`);for(;n.length*t%8;)n.push(e);return n},decode(n){if(!Array.isArray(n)||n.length&&typeof n[0]!="string")throw new Error("padding.encode input should be array of strings");for(let s of n)if(typeof s!="string")throw new Error(`padding.decode: non-string input=${s}`);let r=n.length;if(r*t%8)throw new Error("Invalid padding: string should have whole number of bytes");for(;r>0&&n[r-1]===e;r--)if(!((r-1)*t%8))throw new Error("Invalid padding: string has too much padding");return n.slice(0,r)}}}function qn(t){if(typeof t!="function")throw new Error("normalize fn should be function");return{encode:e=>e,decode:e=>t(e)}}function Mn(t,e,n){if(e<2)throw new Error(`convertRadix: wrong from=${e}, base cannot be less than 2`);if(n<2)throw new Error(`convertRadix: wrong to=${n}, base cannot be less than 2`);if(!Array.isArray(t))throw new Error("convertRadix: data should be array");if(!t.length)return[];let r=0;const s=[],o=Array.from(t);for(o.forEach(i=>{if(Re(i),i<0||i>=e)throw new Error(`Wrong integer: ${i}`)});;){let i=0,c=!0;for(let a=r;a<o.length;a++){const u=o[a],f=e*i+u;if(!Number.isSafeInteger(f)||e*i/e!==i||f-u!==e*i)throw new Error("convertRadix: carry overflow");if(i=f%n,o[a]=Math.floor(f/n),!Number.isSafeInteger(o[a])||o[a]*n+i!==f)throw new Error("convertRadix: carry overflow");if(c)o[a]?c=!1:r=a;else continue}if(s.push(i),c)break}for(let i=0;i<t.length-1&&t[i]===0;i++)s.push(0);return s.reverse()}const Kn=(t,e)=>e?Kn(e,t%e):t,lt=(t,e)=>t+(e-Kn(t,e));function Kt(t,e,n,r){if(!Array.isArray(t))throw new Error("convertRadix2: data should be array");if(e<=0||e>32)throw new Error(`convertRadix2: wrong from=${e}`);if(n<=0||n>32)throw new Error(`convertRadix2: wrong to=${n}`);if(lt(e,n)>32)throw new Error(`convertRadix2: carry overflow from=${e} to=${n} carryBits=${lt(e,n)}`);let s=0,o=0;const i=2**n-1,c=[];for(const a of t){if(Re(a),a>=2**e)throw new Error(`convertRadix2: invalid data word=${a} from=${e}`);if(s=s<<e|a,o+e>32)throw new Error(`convertRadix2: carry overflow pos=${o} from=${e}`);for(o+=e;o>=n;o-=n)c.push((s>>o-n&i)>>>0);s&=2**o-1}if(s=s<<n-o&i,!r&&o>=e)throw new Error("Excess padding");if(!r&&s)throw new Error(`Non-zero padding: ${s}`);return r&&o>0&&c.push(s>>>0),c}function co(t){return Re(t),{encode:e=>{if(!(e instanceof Uint8Array))throw new Error("radix.encode input should be Uint8Array");return Mn(Array.from(e),2**8,t)},decode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="number")throw new Error("radix.decode input should be array of strings");return Uint8Array.from(Mn(e,t,2**8))}}}function ye(t,e=!1){if(Re(t),t<=0||t>32)throw new Error("radix2: bits should be in (0..32]");if(lt(8,t)>32||lt(t,8)>32)throw new Error("radix2: carry overflow");return{encode:n=>{if(!(n instanceof Uint8Array))throw new Error("radix2.encode input should be Uint8Array");return Kt(Array.from(n),8,t,!e)},decode:n=>{if(!Array.isArray(n)||n.length&&typeof n[0]!="number")throw new Error("radix2.decode input should be array of strings");return Uint8Array.from(Kt(n,t,8,e))}}}function jn(t){if(typeof t!="function")throw new Error("unsafeWrapper fn should be function");return function(...e){try{return t.apply(null,e)}catch{}}}const ao=ie(ye(4),ce("0123456789ABCDEF"),ae("")),lo=ie(ye(5),ce("ABCDEFGHIJKLMNOPQRSTUVWXYZ234567"),at(5),ae(""));ie(ye(5),ce("0123456789ABCDEFGHIJKLMNOPQRSTUV"),at(5),ae("")),ie(ye(5),ce("0123456789ABCDEFGHJKMNPQRSTVWXYZ"),ae(""),qn(t=>t.toUpperCase().replace(/O/g,"0").replace(/[IL]/g,"1")));const We=ie(ye(6),ce("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"),at(6),ae("")),uo=ie(ye(6),ce("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"),at(6),ae("")),jt=t=>ie(co(58),ce(t),ae("")),zt=jt("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz");jt("123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"),jt("rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz");const zn=[0,2,3,5,6,7,9,10,11],fo={encode(t){let e="";for(let n=0;n<t.length;n+=8){const r=t.subarray(n,n+8);e+=zt.encode(r).padStart(zn[r.length],"1")}return e},decode(t){let e=[];for(let n=0;n<t.length;n+=11){const r=t.slice(n,n+11),s=zn.indexOf(r.length),o=zt.decode(r);for(let i=0;i<o.length-s;i++)if(o[i]!==0)throw new Error("base58xmr: wrong padding");e=e.concat(Array.from(o.slice(o.length-s)))}return Uint8Array.from(e)}},Vt=ie(ce("qpzry9x8gf2tvdw0s3jn54khce6mua7l"),ae("")),Vn=[996825010,642813549,513874426,1027748829,705979059];function Fe(t){const e=t>>25;let n=(t&33554431)<<5;for(let r=0;r<Vn.length;r++)(e>>r&1)===1&&(n^=Vn[r]);return n}function Dn(t,e,n=1){const r=t.length;let s=1;for(let o=0;o<r;o++){const i=t.charCodeAt(o);if(i<33||i>126)throw new Error(`Invalid prefix (${t})`);s=Fe(s)^i>>5}s=Fe(s);for(let o=0;o<r;o++)s=Fe(s)^t.charCodeAt(o)&31;for(let o of e)s=Fe(s)^o;for(let o=0;o<6;o++)s=Fe(s);return s^=n,Vt.encode(Kt([s%2**30],30,5,!1))}function Wn(t){const e=t==="bech32"?1:734539939,n=ye(5),r=n.decode,s=n.encode,o=jn(r);function i(f,l,h=90){if(typeof f!="string")throw new Error(`bech32.encode prefix should be string, not ${typeof f}`);if(!Array.isArray(l)||l.length&&typeof l[0]!="number")throw new Error(`bech32.encode words should be array of numbers, not ${typeof l}`);const w=f.length+7+l.length;if(h!==!1&&w>h)throw new TypeError(`Length ${w} exceeds limit ${h}`);return f=f.toLowerCase(),`${f}1${Vt.encode(l)}${Dn(f,l,e)}`}function c(f,l=90){if(typeof f!="string")throw new Error(`bech32.decode input should be string, not ${typeof f}`);if(f.length<8||l!==!1&&f.length>l)throw new TypeError(`Wrong string length: ${f.length} (${f}). Expected (8..${l})`);const h=f.toLowerCase();if(f!==h&&f!==f.toUpperCase())throw new Error("String must be lowercase or uppercase");f=h;const w=f.lastIndexOf("1");if(w===0||w===-1)throw new Error('Letter "1" must be present between prefix and data only');const g=f.slice(0,w),d=f.slice(w+1);if(d.length<6)throw new Error("Data must be at least 6 characters long");const p=Vt.decode(d).slice(0,-6),m=Dn(g,p,e);if(!d.endsWith(m))throw new Error(`Invalid checksum in ${f}: expected "${m}"`);return{prefix:g,words:p}}const a=jn(c);function u(f){const{prefix:l,words:h}=c(f,!1);return{prefix:l,words:h,bytes:r(h)}}return{encode:i,decode:c,decodeToBytes:u,decodeUnsafe:a,fromWords:r,fromWordsUnsafe:o,toWords:s}}const Fn=Wn("bech32");Wn("bech32m");const ho={encode:t=>new TextDecoder().decode(t),decode:t=>new TextEncoder().encode(t)},wo=ie(ye(4),ce("0123456789abcdef"),ae(""),qn(t=>{if(typeof t!="string"||t.length%2)throw new TypeError(`hex.decode: expected string, got ${typeof t} with length ${t.length}`);return t.toLowerCase()}));`${Object.keys({utf8:ho,hex:wo,base16:ao,base32:lo,base64:We,base64url:uo,base58:zt,base58xmr:fo}).join(", ")}`;var Ae=Symbol("verified"),po=t=>t instanceof Object;function yo(t){if(!po(t)||typeof t.kind!="number"||typeof t.content!="string"||typeof t.created_at!="number"||typeof t.pubkey!="string"||!t.pubkey.match(/^[a-f0-9]{64}$/)||!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){let n=t.tags[e];if(!Array.isArray(n))return!1;for(let r=0;r<n.length;r++)if(typeof n[r]=="object")return!1}return!0}var go=new TextDecoder("utf-8"),Gn=new TextEncoder;function Ge(t){t.indexOf("://")===-1&&(t="wss://"+t);let e=new URL(t);return e.pathname=e.pathname.replace(/\/+/g,"/"),e.pathname.endsWith("/")&&(e.pathname=e.pathname.slice(0,-1)),(e.port==="80"&&e.protocol==="ws:"||e.port==="443"&&e.protocol==="wss:")&&(e.port=""),e.searchParams.sort(),e.hash="",e.toString()}var bo=class{constructor(t){b(this,"value");b(this,"next",null);b(this,"prev",null);this.value=t}},mo=class{constructor(){b(this,"first");b(this,"last");this.first=null,this.last=null}enqueue(t){const e=new bo(t);return this.last?this.last===this.first?(this.last=e,this.last.prev=this.first,this.first.next=e):(e.prev=this.last,this.last.next=e,this.last=e):(this.first=e,this.last=e),!0}dequeue(){if(!this.first)return null;if(this.first===this.last){const e=this.first;return this.first=null,this.last=null,e.value}const t=this.first;return this.first=t.next,t.value}},Eo=class{generateSecretKey(){return D.utils.randomPrivateKey()}getPublicKey(t){return V(D.getPublicKey(t))}finalizeEvent(t,e){const n=t;return n.pubkey=V(D.getPublicKey(e)),n.id=Dt(n),n.sig=V(D.sign(Dt(n),e)),n[Ae]=!0,n}verifyEvent(t){if(typeof t[Ae]=="boolean")return t[Ae];const e=Dt(t);if(e!==t.id)return t[Ae]=!1,!1;try{const n=D.verify(t.sig,e,t.pubkey);return t[Ae]=n,n}catch{return t[Ae]=!1,!1}}};function xo(t){if(!yo(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function Dt(t){let e=Lt(Gn.encode(xo(t)));return V(e)}var ut=new Eo,vo=ut.generateSecretKey,Zn=ut.getPublicKey,So=ut.finalizeEvent,Jn=ut.verifyEvent;typeof crypto<"u"&&!crypto.subtle&&crypto.webcrypto&&(crypto.subtle=crypto.webcrypto.subtle);async function _o(t,e,n){const r=t instanceof Uint8Array?V(t):t,s=ze.getSharedSecret(r,"02"+e),o=Yn(s);let i=Uint8Array.from(Pr(16)),c=Gn.encode(n),a=await crypto.subtle.importKey("raw",o,{name:"AES-CBC"},!1,["encrypt"]),u=await crypto.subtle.encrypt({name:"AES-CBC",iv:i},a,c),f=We.encode(new Uint8Array(u)),l=We.encode(new Uint8Array(i.buffer));return`${f}?iv=${l}`}async function Ao(t,e,n){const r=t instanceof Uint8Array?V(t):t;let[s,o]=n.split("?iv="),i=ze.getSharedSecret(r,"02"+e),c=Yn(i),a=await crypto.subtle.importKey("raw",c,{name:"AES-CBC"},!1,["decrypt"]),u=We.decode(s),f=We.decode(o),l=await crypto.subtle.decrypt({name:"AES-CBC",iv:f},a,u);return go.decode(l)}function Yn(t){return t.slice(1,33)}var ko=/^(?:([\w.+-]+)@)?([\w_-]+(\.[\w_-]+)+)$/,Bo;try{Bo=fetch}catch{}var $o=22242,Wt=24133,Oo=31990;function Io(t,e){if(t.ids&&t.ids.indexOf(e.id)===-1&&!t.ids.some(n=>e.id.startsWith(n))||t.kinds&&t.kinds.indexOf(e.kind)===-1||t.authors&&t.authors.indexOf(e.pubkey)===-1&&!t.authors.some(n=>e.pubkey.startsWith(n)))return!1;for(let n in t)if(n[0]==="#"){let r=n.slice(1),s=t[`#${r}`];if(s&&!e.tags.find(([o,i])=>o===n.slice(1)&&s.indexOf(i)!==-1))return!1}return!(t.since&&e.created_at<t.since||t.until&&e.created_at>t.until)}function To(t,e){for(let n=0;n<t.length;n++)if(Io(t[n],e))return!0;return!1}function No(t,e){let n=e.length+3,r=t.indexOf(`"${e}":`)+n,s=t.slice(r).indexOf('"')+r+1;return t.slice(s,s+64)}function Co(t){let e=t.slice(0,22).indexOf('"EVENT"');if(e===-1)return null;let n=t.slice(e+7+1).indexOf('"');if(n===-1)return null;let r=e+7+1+n,s=t.slice(r+1,80).indexOf('"');if(s===-1)return null;let o=r+1+s;return t.slice(r+1,o)}function Po(t,e){return{kind:$o,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t],["challenge",e]],content:""}}async function Ro(){return new Promise(t=>{const e=new MessageChannel,n=()=>{e.port1.removeEventListener("message",n),t()};e.port1.addEventListener("message",n),e.port2.postMessage(0),e.port1.start()})}var Uo=t=>(t[Ae]=!0,!0),Qn;try{Qn=WebSocket}catch{}var Xn=class{constructor(t,e){b(this,"url");b(this,"_connected",!1);b(this,"onclose",null);b(this,"onnotice",t=>console.debug(`NOTICE from ${this.url}: ${t}`));b(this,"baseEoseTimeout",4400);b(this,"connectionTimeout",4400);b(this,"openSubs",new Map);b(this,"connectionTimeoutHandle");b(this,"connectionPromise");b(this,"openCountRequests",new Map);b(this,"openEventPublishes",new Map);b(this,"ws");b(this,"incomingMessageQueue",new mo);b(this,"queueRunning",!1);b(this,"challenge");b(this,"serial",0);b(this,"verifyEvent");this.url=Ge(t),this.verifyEvent=e.verifyEvent}static async connect(t,e){const n=new Xn(t,e);return await n.connect(),n}closeAllSubscriptions(t){for(let[e,n]of this.openSubs)n.close(t);this.openSubs.clear();for(let[e,n]of this.openEventPublishes)n.reject(new Error(t));this.openEventPublishes.clear();for(let[e,n]of this.openCountRequests)n.reject(new Error(t));this.openCountRequests.clear()}get connected(){return this._connected}async connect(){return this.connectionPromise?this.connectionPromise:(this.challenge=void 0,this.connectionPromise=new Promise((t,e)=>{this.connectionTimeoutHandle=setTimeout(()=>{var n;e("connection timed out"),this.connectionPromise=void 0,(n=this.onclose)==null||n.call(this),this.closeAllSubscriptions("relay connection timed out")},this.connectionTimeout);try{this.ws=new Qn(this.url)}catch(n){e(n);return}this.ws.onopen=()=>{clearTimeout(this.connectionTimeoutHandle),this._connected=!0,t()},this.ws.onerror=n=>{var r;e(n.message),this._connected&&((r=this.onclose)==null||r.call(this),this.closeAllSubscriptions("relay connection errored"),this._connected=!1)},this.ws.onclose=async()=>{var n;this.connectionPromise=void 0,(n=this.onclose)==null||n.call(this),this.closeAllSubscriptions("relay connection closed"),this._connected=!1},this.ws.onmessage=this._onmessage.bind(this)}),this.connectionPromise)}async runQueue(){for(this.queueRunning=!0;this.handleNext()!==!1;)await Ro();this.queueRunning=!1}handleNext(){var n,r;const t=this.incomingMessageQueue.dequeue();if(!t)return!1;const e=Co(t);if(e){const s=this.openSubs.get(e);if(!s)return;const o=No(t,"id"),i=(n=s.alreadyHaveEvent)==null?void 0:n.call(s,o);if((r=s.receivedEvent)==null||r.call(s,this,o),i)return}try{let s=JSON.parse(t);switch(s[0]){case"EVENT":{const o=this.openSubs.get(s[1]),i=s[2];this.verifyEvent(i)&&To(o.filters,i)&&o.onevent(i);return}case"COUNT":{const o=s[1],i=s[2],c=this.openCountRequests.get(o);c&&(c.resolve(i.count),this.openCountRequests.delete(o));return}case"EOSE":{const o=this.openSubs.get(s[1]);if(!o)return;o.receivedEose();return}case"OK":{const o=s[1],i=s[2],c=s[3],a=this.openEventPublishes.get(o);i?a.resolve(c):a.reject(new Error(c)),this.openEventPublishes.delete(o);return}case"CLOSED":{const o=s[1],i=this.openSubs.get(o);if(!i)return;i.closed=!0,i.close(s[2]);return}case"NOTICE":this.onnotice(s[1]);return;case"AUTH":{this.challenge=s[1];return}}}catch{return}}async send(t){if(!this.connectionPromise)throw new Error("sending on closed connection");this.connectionPromise.then(()=>{var e;(e=this.ws)==null||e.send(t)})}async auth(t){if(!this.challenge)throw new Error("can't perform auth, no challenge was received");const e=await t(Po(this.url,this.challenge)),n=new Promise((r,s)=>{this.openEventPublishes.set(e.id,{resolve:r,reject:s})});return this.send('["AUTH",'+JSON.stringify(e)+"]"),n}async publish(t){const e=new Promise((n,r)=>{this.openEventPublishes.set(t.id,{resolve:n,reject:r})});return this.send('["EVENT",'+JSON.stringify(t)+"]"),e}async count(t,e){this.serial++;const n=(e==null?void 0:e.id)||"count:"+this.serial,r=new Promise((s,o)=>{this.openCountRequests.set(n,{resolve:s,reject:o})});return this.send('["COUNT","'+n+'",'+JSON.stringify(t)+"]"),r}subscribe(t,e){const n=this.prepareSubscription(t,e);return n.fire(),n}prepareSubscription(t,e){this.serial++;const n=e.id||"sub:"+this.serial,r=new Ho(this,n,t,e);return this.openSubs.set(n,r),r}close(){var t;this.closeAllSubscriptions("relay connection closed by us"),this._connected=!1,(t=this.ws)==null||t.close()}_onmessage(t){this.incomingMessageQueue.enqueue(t.data),this.queueRunning||this.runQueue()}},Ho=class{constructor(t,e,n,r){b(this,"relay");b(this,"id");b(this,"closed",!1);b(this,"eosed",!1);b(this,"filters");b(this,"alreadyHaveEvent");b(this,"receivedEvent");b(this,"onevent");b(this,"oneose");b(this,"onclose");b(this,"eoseTimeout");b(this,"eoseTimeoutHandle");this.relay=t,this.filters=n,this.id=e,this.alreadyHaveEvent=r.alreadyHaveEvent,this.receivedEvent=r.receivedEvent,this.eoseTimeout=r.eoseTimeout||t.baseEoseTimeout,this.oneose=r.oneose,this.onclose=r.onclose,this.onevent=r.onevent||(s=>{console.warn(`onevent() callback not defined for subscription '${this.id}' in relay ${this.relay.url}. event received:`,s)})}fire(){this.relay.send('["REQ","'+this.id+'",'+JSON.stringify(this.filters).substring(1)),this.eoseTimeoutHandle=setTimeout(this.receivedEose.bind(this),this.eoseTimeout)}receivedEose(){var t;this.eosed||(clearTimeout(this.eoseTimeoutHandle),this.eosed=!0,(t=this.oneose)==null||t.call(this))}close(t="closed by caller"){var e;this.closed||(this.relay.send('["CLOSE",'+JSON.stringify(this.id)+"]"),this.closed=!0),this.relay.openSubs.delete(this.id),(e=this.onclose)==null||e.call(this,t)}},Lo=class{constructor(t){b(this,"relays",new Map);b(this,"seenOn",new Map);b(this,"trackRelays",!1);b(this,"verifyEvent");b(this,"trustedRelayURLs",new Set);this.verifyEvent=t.verifyEvent}async ensureRelay(t,e){t=Ge(t);let n=this.relays.get(t);return n||(n=new Xn(t,{verifyEvent:this.trustedRelayURLs.has(t)?Uo:this.verifyEvent}),e!=null&&e.connectionTimeout&&(n.connectionTimeout=e.connectionTimeout),this.relays.set(t,n)),await n.connect(),n}close(t){t.map(Ge).forEach(e=>{var n;(n=this.relays.get(e))==null||n.close()})}subscribeMany(t,e,n){this.trackRelays&&(n.receivedEvent=(l,h)=>{let w=this.seenOn.get(h);w||(w=new Set,this.seenOn.set(h,w)),w.add(l)});const r=new Set,s=[],o=[];let i=l=>{var h;o[l]=!0,o.filter(w=>w).length===t.length&&((h=n.oneose)==null||h.call(n),i=()=>{})};const c=[];let a=(l,h)=>{var w;i(l),c[l]=h,c.filter(g=>g).length===t.length&&((w=n.onclose)==null||w.call(n,c),a=()=>{})};const u=l=>{var w;if((w=n.alreadyHaveEvent)!=null&&w.call(n,l))return!0;const h=r.has(l);return r.add(l),h},f=Promise.all(t.map(Ge).map(async(l,h,w)=>{if(w.indexOf(l)!==h){a(h,"duplicate url");return}let g;try{g=await this.ensureRelay(l,{connectionTimeout:n.maxWait?Math.max(n.maxWait*.8,n.maxWait-1e3):void 0})}catch(p){a(h,(p==null?void 0:p.message)||String(p));return}let d=g.subscribe(e,{...n,oneose:()=>i(h),onclose:p=>a(h,p),alreadyHaveEvent:u,eoseTimeout:n.maxWait});s.push(d)}));return{async close(){await f,s.forEach(l=>{l.close()})}}}subscribeManyEose(t,e,n){const r=this.subscribeMany(t,e,{...n,oneose(){r.close()}});return r}async querySync(t,e,n){return new Promise(async r=>{const s=[];this.subscribeManyEose(t,[e],{...n,onevent(o){s.push(o)},onclose(o){r(s)}})})}async get(t,e,n){e.limit=1;const r=await this.querySync(t,e,n);return r.sort((s,o)=>o.created_at-s.created_at),r[0]||null}publish(t,e){return t.map(Ge).map(async(n,r,s)=>s.indexOf(n)!==r?Promise.reject("duplicate url"):(await this.ensureRelay(n)).publish(e))}},qo=class extends Lo{constructor(){super({verifyEvent:Jn})}},er;try{er=fetch}catch{}var Mo=/^bunker:\/\/([0-9a-f]{64})\??([?\/\w:.=&%]*)$/,Ko=/^[^\s@]+@[^\s@]+\.[^\s@]+$/;async function jo(t){let e=t.match(Mo);if(e)try{const n=e[1],r=new URLSearchParams(e[2]);return{pubkey:n,relays:r.getAll("relay"),secret:r.get("secret")}}catch{}return tr(t)}async function tr(t){const e=t.match(ko);if(!e)return null;const[n,r="_",s]=e;try{const o=`https://${s}/.well-known/nostr.json?name=${r}`,i=await(await er(o,{redirect:"error"})).json();let c=i.names[r],a=i.nip46[c]||[];return{pubkey:c,relays:a,secret:null}}catch{return null}}var Ft=class{constructor(t,e,n={}){b(this,"pool");b(this,"subCloser");b(this,"isOpen");b(this,"serial");b(this,"idPrefix");b(this,"listeners");b(this,"waitingForAuth");b(this,"secretKey");b(this,"bp");if(e.relays.length===0)throw new Error("no relays are specified for this bunker");this.pool=n.pool||new qo,this.secretKey=t,this.bp=e,this.isOpen=!1,this.idPrefix=Math.random().toString(36).substring(7),this.serial=0,this.listeners={},this.waitingForAuth={};const r=this.listeners,s=this.waitingForAuth;this.subCloser=this.pool.subscribeMany(this.bp.relays,[{kinds:[Wt],"#p":[Zn(this.secretKey)]}],{async onevent(o){const{id:i,result:c,error:a}=JSON.parse(await Ao(t,o.pubkey,o.content));if(c==="auth_url"&&s[i]){delete r[i],n.onauth?n.onauth(a):console.warn(`nostr-tools/nip46: remote signer ${e.pubkey} tried to send an "auth_url"='${a}' but there was no onauth() callback configured.`);return}let u=r[i];u&&(a?u.reject(a):c&&u.resolve(c),delete r[i])}}),this.isOpen=!0}async close(){this.isOpen=!1,this.subCloser.close()}async sendRequest(t,e){return new Promise(async(n,r)=>{try{if(!this.isOpen)throw new Error("this signer is not open anymore, create a new one");this.serial++;const s=`${this.idPrefix}-${this.serial}`,o=await _o(this.secretKey,this.bp.pubkey,JSON.stringify({id:s,method:t,params:e})),i=So({kind:Wt,tags:[["p",this.bp.pubkey]],content:o,created_at:Math.floor(Date.now()/1e3)},this.secretKey);this.listeners[s]={resolve:n,reject:r},this.waitingForAuth[s]=!0,await Promise.any(this.pool.publish(this.bp.relays,i))}catch(s){r(s)}})}async ping(){let t=await this.sendRequest("ping",[]);if(t!=="pong")throw new Error(`result is not pong: ${t}`)}async connect(){await this.sendRequest("connect",[Zn(this.secretKey),this.bp.secret||""])}async getPublicKey(){return this.bp.pubkey}async getRelays(){return JSON.parse(await this.sendRequest("get_relays",[]))}async signEvent(t){let e=await this.sendRequest("sign_event",[JSON.stringify(t)]),n=JSON.parse(e);if(n.pubkey===this.bp.pubkey&&Jn(n))return n;throw new Error(`event returned from bunker is improperly signed: ${JSON.stringify(n)}`)}async nip04Encrypt(t,e){return await this.sendRequest("nip04_encrypt",[t,e])}async nip04Decrypt(t,e){return await this.sendRequest("nip04_decrypt",[t,e])}async nip44GetKey(t){let e=await this.sendRequest("nip44_get_key",[t]);return gt(e)}async nip44Encrypt(t,e){return await this.sendRequest("nip44_encrypt",[t,e])}async nip44Decrypt(t,e){return await this.sendRequest("nip44_encrypt",[t,e])}};async function zo(t,e,n,r,s){if(s&&!Ko.test(s))throw new Error("Invalid email");let o=vo(),i=new Ft(o,t.bunkerPointer,e),c=await i.sendRequest("create_account",[n,r,s||""]);return i.bp.pubkey=c,await i.connect(),i}async function Vo(t,e){const n=await t.querySync(e,{kinds:[Oo],"#k":[Wt.toString()]});return(await Promise.all(n.map(async s=>{try{const o=JSON.parse(s.content),i=await tr(o.nip05);if(i&&i.pubkey===s.pubkey&&i.relays.length)return{bunkerPointer:i,nip05:o.nip05,domain:o.nip05.split("@")[1],name:o.name||o.display_name,picture:o.picture,about:o.about,website:o.website,local:!1}}catch{return}}))).filter(s=>s!==void 0)}var Do=/^(?:([\w.+-]+)@)?([\w_-]+(\.[\w_-]+)+)$/,nr;try{nr=fetch}catch{}async function Wo(t){var o;const e=t.match(Do);if(!e)return null;const[n,r="_",s]=e;try{const i=`https://${s}/.well-known/nostr.json?name=${r}`,c=await(await nr(i,{redirect:"error"})).json();let a=c.names[r];return a?{pubkey:a,relays:(o=c.relays)==null?void 0:o[a]}:null}catch{return null}}new TextDecoder("utf-8"),new TextEncoder;var Fo=5e3;function Go(t){return Jo("npub",gt(t))}function Zo(t,e){let n=Fn.toWords(e);return Fn.encode(t,n,Fo)}function Jo(t,e){return Zo(t,e)}const{window:Yo}=ur;function rr(t,e,n){const r=t.slice();return r[28]=e[n],r}function Qo(t){let e;function n(o,i){if(o[5])return ni;if(!o[6])return ti;if(o[6])return ei}let r=n(t),s=r&&r(t);return{c(){e=P("div"),s&&s.c(),T(e,"class","tw-w-80 tw-px-6 tw-py-6 tw-transition-all tw-bg-cyan-700 tw-shadow-xl tw-rounded-md")},m(o,i){H(o,e,i),s&&s.m(e,null)},p(o,i){r===(r=n(o))&&s?s.p(o,i):(s&&s.d(1),s=r&&r(o),s&&(s.c(),s.m(e,null)))},d(o){o&&U(e),s&&s.d()}}}function Xo(t){let e;function n(o,i){return o[4]?oi:o[6]?ri:si}let r=n(t),s=r(t);return{c(){e=P("div"),s.c(),T(e,"class","tw-px-4 tw-py-2 tw-transition-all tw-bg-cyan-700 hover:tw-bg-cyan-800 tw-shadow-xl tw-rounded tw-cursor-pointer")},m(o,i){H(o,e,i),s.m(e,null)},p(o,i){r===(r=n(o))&&s?s.p(o,i):(s.d(1),s=r(o),s&&(s.c(),s.m(e,null)))},d(o){o&&U(e),s.d()}}}function ei(t){let e,n,r,s,o=t[6].npub+"",i,c,a,u,f,l;return{c(){e=P("div"),n=P("div"),n.textContent="You are currently connect to Nostr as",r=se(),s=P("a"),i=$e(o),a=se(),u=P("button"),u.textContent="Disconnect",T(n,"class","tw-text-xs"),T(s,"target","_blank"),T(s,"href",c="https://nosta.me/"+t[6].npub),T(s,"class","tw-block tw-text-white tw-mt-4 tw-break-all tw-no-underline hover:tw-underline"),T(e,"class","tw-text-center"),T(u,"class","tw-block tw-w-full tw-my-2 tw-mt-4 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white")},m(h,w){H(h,e,w),M(e,n),M(e,r),M(e,s),M(s,i),H(h,a,w),H(h,u,w),f||(l=Ee(u,"click",t[10]),f=!0)},p(h,w){w&64&&o!==(o=h[6].npub+"")&&Yt(i,o),w&64&&c!==(c="https://nosta.me/"+h[6].npub)&&T(s,"href",c)},d(h){h&&(U(e),U(a),U(u)),f=!1,l()}}}function ti(t){let e,n,r,s,o,i,c,a,u,f,l,h;return{c(){e=P("div"),e.textContent="How do you want to connect to Nostr?",n=se(),r=P("form"),s=P("input"),o=se(),i=P("button"),i.textContent="Connect »",c=se(),a=P("div"),u=$e(`Do you need a Nostr account?
3
- `),f=P("button"),f.textContent="Get one now for free",T(e,"class","tw-text-lg tw-text-center"),T(s,"class","tw-box-border tw-w-full tw-px-2 tw-py-1 tw-rounded tw-text-lg tw-border-none tw-outline-none"),T(s,"placeholder","user@provider or bunker://..."),T(i,"class","tw-block tw-w-full tw-mt-4 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white"),T(r,"class","flex tw-mt-4 tw-mb-1"),T(f,"class","tw-border-0 tw-bg-transparent tw-text-white tw-cursor-pointer tw-underline tw-text-sm"),T(a,"class","tw-mt-6 tw-text-center tw-text-sm tw-leading-3")},m(w,g){H(w,e,g),H(w,n,g),H(w,r,g),M(r,s),t[16](s),M(r,o),M(r,i),H(w,c,g),H(w,a,g),M(a,u),M(a,f),l||(h=[Ee(r,"submit",t[9]),Ee(f,"click",t[11])],l=!0)},p:j,d(w){w&&(U(e),U(n),U(r),U(c),U(a)),t[16](null),l=!1,Be(h)}}}function ni(t){let e,n,r,s,o,i,c,a,u,f,l,h,w,g=rn(t[7]),d=[];for(let p=0;p<g.length;p+=1)d[p]=sr(rr(t,g,p));return{c(){e=P("div"),e.textContent="Create a new Nostr account",n=se(),r=P("form"),s=P("div"),o=P("input"),i=se(),c=P("div"),c.textContent="@",a=se(),u=P("select");for(let p=0;p<d.length;p+=1)d[p].c();f=se(),l=P("button"),l.textContent="create",T(e,"class","tw-text-lg tw-text-center"),T(o,"class","tw-box-border tw-w-full tw-px-2 tw-py-1 tw-rounded tw-text-lg tw-border-none tw-outline-none"),T(o,"placeholder","bob"),T(c,"class","tw-mx-2 tw-text-2xl"),T(u,"class","tw-w-full tw-box-border tw-px-2 tw-py-1 tw-rounded tw-text-lg tw-border-none tw-outline-none"),t[2]===void 0&&Ye(()=>t[15].call(u)),T(s,"class","tw-flex items-center"),T(l,"class","tw-block tw-w-full tw-mt-4 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white"),T(r,"class","tw-mt-4 tw-mb-1")},m(p,m){H(p,e,m),H(p,n,m),H(p,r,m),M(r,s),M(s,o),t[14](o),M(s,i),M(s,c),M(s,a),M(s,u);for(let x=0;x<d.length;x+=1)d[x]&&d[x].m(u,null);Xt(u,t[2],!0),M(r,f),M(r,l),h||(w=[Ee(o,"input",t[13]),Ee(u,"change",t[15]),Ee(r,"submit",t[12])],h=!0)},p(p,m){if(m&128){g=rn(p[7]);let x;for(x=0;x<g.length;x+=1){const S=rr(p,g,x);d[x]?d[x].p(S,m):(d[x]=sr(S),d[x].c(),d[x].m(u,null))}for(;x<d.length;x+=1)d[x].d(1);d.length=g.length}m&132&&Xt(u,p[2])},d(p){p&&(U(e),U(n),U(r)),t[14](null),fr(d,p),h=!1,Be(w)}}}function sr(t){let e,n,r;return{c(){e=P("option"),T(e,"label",n=t[28].domain),e.__value=r=t[28],Qt(e,e.__value),T(e,"class","tw-px-2 tw-py-1 tw-text-lg")},m(s,o){H(s,e,o)},p(s,o){o&128&&n!==(n=s[28].domain)&&T(e,"label",n),o&128&&r!==(r=s[28])&&(e.__value=r,Qt(e,e.__value))},d(s){s&&U(e)}}}function ri(t){let e,n=(t[6].name||t[6].npub.slice(0,7)+"…"+t[6].npub.slice(-4))+"",r;return{c(){e=$e(""),r=$e(n)},m(s,o){H(s,e,o),H(s,r,o)},p(s,o){o&64&&n!==(n=(s[6].name||s[6].npub.slice(0,7)+"…"+s[6].npub.slice(-4))+"")&&Yt(r,n)},d(s){s&&(U(e),U(r))}}}function si(t){let e;return{c(){e=$e("Login with Nostr")},m(n,r){H(n,e,r)},p:j,d(n){n&&U(e)}}}function oi(t){let e;return{c(){e=P("div"),e.textContent="Connecting to bunker..."},m(n,r){H(n,e,r)},p:j,d(n){n&&U(e)}}}function ii(t){let e,n,r;function s(c,a){return c[3]?Qo:Xo}let o=s(t),i=o(t);return{c(){e=P("div"),i.c(),T(e,"class","tw-text-white tw-font-sans"),en(e,"tw-cursor-pointer",!t[6]&&!t[3])},m(c,a){H(c,e,a),i.m(e,null),n||(r=Ee(Yo,"click",t[8]),n=!0)},p(c,[a]){o===(o=s(c))&&i?i.p(c,a):(i.d(1),i=o(c),i&&(i.c(),i.m(e,null))),a&72&&en(e,"tw-cursor-pointer",!c[6]&&!c[3])},i:j,o:j,d(c){c&&U(e),i.d(),n=!1,r()}}}function ci(t,e,n){const r=window,s=new io;let o,i,c,a;const u=localStorage.getItem("nip46ClientSecretKey");u?a=gt(u):(a=Ks(),localStorage.setItem("nip46ClientSecretKey",V(a)));let f,l,h,w,g,d,p,m,x=[];S();function S(){n(3,f=!1),l=null,w=new Promise(y=>{h=y}),n(4,g=!1),n(5,d=!1),n(6,p=null),m=null}const $={pool:s,onauth(y){window.open(y,"window.nostr","width=600,height=800,popup=yes")}};pr(()=>{let y=localStorage.getItem("nip46BunkerPointer");return y&&(l=JSON.parse(y),n(4,g=!0),O(new Ft(a,l,$))),setTimeout(()=>{if(r.nostr&&!r.nostr.isWnj){r.destroyWnj();return}else r.nostr={isWnj:!0,async getPublicKey(){return g||n(3,f=!0),(await w).bp.pubkey},async signEvent(E){return g||n(3,f=!0),(await w).signEvent(E)}}},3e3),()=>{m&&m.close()}});function B(y){y.composedPath().find(E=>E.id==="windowNostrModal")?n(3,f=!0):n(3,f=!1)}async function v(y){if(y.preventDefault(),l=await jo(o.value),!l){o.setCustomValidity('invalid NIP-05 "name@domain.com" address or bunker:// URI');return}o.setCustomValidity(""),O(new Ft(a,l,$))}async function _(y){y.preventDefault(),localStorage.removeItem("nip46BunkerPointer"),r.isWnj&&delete r.nostr,S()}async function k(y){y.preventDefault(),n(5,d=!0),x.length===0&&n(7,x=await Vo(s,["wss://relay.nostr.band"]))}async function Z(y){if(y.preventDefault(),!c)return;let E=await zo(c,$,i.value,c.domain);n(3,f=!0),n(5,d=!1),O(E)}const C=Ir(async()=>{c&&i.value.length>0&&(await Wo(i.value+"@"+c.domain)?i.setCustomValidity(`'${i.value}' is already taken.`):i.setCustomValidity(""))},500);async function O(y){await y.connect(),n(6,p={pubkey:y.bp.pubkey,npub:Go(y.bp.pubkey),event:null}),n(4,g=!1),localStorage.setItem("nip46BunkerPointer",JSON.stringify(l)),m=s.subscribeMany(["wss://purplepag.es","wss://relay.snort.social","wss://relay.nos.social"],[{kinds:[0],authors:[y.bp.pubkey]}],{onevent(E){var A;if(!((((A=p.event)==null?void 0:A.created_at)||0)>=E.created_at))try{let{name:N,picture:I}=JSON.parse(E.content);n(6,p.event=E,p),n(6,p.name=N,p),n(6,p.picture=I,p)}catch{}}}),n(3,f=!1),h(y)}function W(y){Je[y?"unshift":"push"](()=>{i=y,n(1,i)})}function F(){c=hr(this),n(2,c),n(7,x)}function re(y){Je[y?"unshift":"push"](()=>{o=y,n(0,o)})}return[o,i,c,f,g,d,p,x,B,v,_,k,Z,C,W,F,re]}class ai extends kr{constructor(e){super(),Ar(this,e,ci,ii,ar,{})}}const ft=document.createElement("div");document.body.appendChild(ft),ft.id="windowNostrModal",ft.classList.add("tw-fixed","tw-top-6","tw-right-6");const li=new ai({target:ft});window.destroyWnj=()=>{li.$destroy()}})();
1
+ var gi=Object.defineProperty;var bi=(le,K,ue)=>K in le?gi(le,K,{enumerable:!0,configurable:!0,writable:!0,value:ue}):le[K]=ue;var g=(le,K,ue)=>(bi(le,typeof K!="symbol"?K+"":K,ue),ue);(function(){"use strict";var le=document.createElement("style");le.textContent=`.tw-fixed{position:fixed}.tw-absolute{position:absolute}.tw-right-0{right:0}.tw-right-0\\.5{right:.125rem}.tw-right-6{right:1.5rem}.tw-top-0{top:0}.tw-top-6{top:1.5rem}.tw-mx-2{margin-left:.5rem;margin-right:.5rem}.tw-my-2{margin-top:.5rem;margin-bottom:.5rem}.tw-mb-1{margin-bottom:.25rem}.tw-mb-2{margin-bottom:.5rem}.tw-mb-4{margin-bottom:1rem}.tw-mr-2{margin-right:.5rem}.tw-mt-4{margin-top:1rem}.tw-mt-6{margin-top:1.5rem}.tw-box-border{box-sizing:border-box}.tw-block{display:block}.tw-flex{display:flex}.tw-h-10{height:2.5rem}.tw-h-5{height:1.25rem}.tw-w-10{width:2.5rem}.tw-w-5{width:1.25rem}.tw-w-80{width:20rem}.tw-w-full{width:100%}.tw-cursor-pointer{cursor:pointer}.tw-items-center{align-items:center}.tw-justify-center{justify-content:center}.tw-gap-2{gap:.5rem}.tw-break-all{word-break:break-all}.tw-rounded{border-radius:.25rem}.tw-rounded-full{border-radius:9999px}.tw-rounded-md{border-radius:.375rem}.tw-border-0{border-width:0px}.tw-border-2{border-width:2px}.tw-border-solid{border-style:solid}.tw-border-none{border-style:none}.tw-border-transparent{border-color:transparent}.tw-bg-cyan-700{--tw-bg-opacity: 1;background-color:rgb(14 116 144 / var(--tw-bg-opacity))}.tw-bg-cyan-900{--tw-bg-opacity: 1;background-color:rgb(22 78 99 / var(--tw-bg-opacity))}.tw-bg-transparent{background-color:transparent}.tw-px-2{padding-left:.5rem;padding-right:.5rem}.tw-px-4{padding-left:1rem;padding-right:1rem}.tw-px-6{padding-left:1.5rem;padding-right:1.5rem}.tw-py-1{padding-top:.25rem;padding-bottom:.25rem}.tw-py-2{padding-top:.5rem;padding-bottom:.5rem}.tw-py-8{padding-top:2rem;padding-bottom:2rem}.tw-text-center{text-align:center}.tw-font-sans{font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.tw-text-2xl{font-size:1.5rem;line-height:2rem}.tw-text-3xl{font-size:1.875rem;line-height:2.25rem}.tw-text-lg{font-size:1.125rem;line-height:1.75rem}.tw-text-sm{font-size:.875rem;line-height:1.25rem}.tw-text-xs{font-size:.75rem;line-height:1rem}.tw-leading-3{line-height:.75rem}.tw-text-cyan-950{--tw-text-opacity: 1;color:rgb(8 51 68 / var(--tw-text-opacity))}.tw-text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.tw-underline{text-decoration-line:underline}.tw-no-underline{text-decoration-line:none}.tw-decoration-2{text-decoration-thickness:2px}.tw-underline-offset-4{text-underline-offset:4px}.tw-shadow-\\[0_0px_10px_0px_rgba\\(0\\,0\\,0\\,0\\.3\\)\\]{--tw-shadow: 0 0px 10px 0px rgba(0,0,0,.3);--tw-shadow-colored: 0 0px 10px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.tw-shadow-\\[0_0px_30px_0px_rgba\\(0\\,0\\,0\\,0\\.6\\)\\]{--tw-shadow: 0 0px 30px 0px rgba(0,0,0,.6);--tw-shadow-colored: 0 0px 30px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.tw-outline-none{outline:2px solid transparent;outline-offset:2px}.tw-transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.hover\\:tw-bg-cyan-800:hover{--tw-bg-opacity: 1;background-color:rgb(21 94 117 / var(--tw-bg-opacity))}.hover\\:tw-bg-cyan-950:hover{--tw-bg-opacity: 1;background-color:rgb(8 51 68 / var(--tw-bg-opacity))}.tw-group:hover .group-hover\\:tw-border-cyan-100{--tw-border-opacity: 1;border-color:rgb(207 250 254 / var(--tw-border-opacity))}.tw-group:hover .group-hover\\:tw-underline{text-decoration-line:underline}
2
+ `,document.head.appendChild(le);function K(){}function ue(t){return t()}function Qt(){return Object.create(null)}function $e(t){t.forEach(ue)}function Xt(t){return typeof t=="function"}function hr(t,e){return t!=t?e==e:t!==e||t&&typeof t=="object"||typeof t=="function"}let Je;function Ye(t,e){return t===e?!0:(Je||(Je=document.createElement("a")),Je.href=e,t===Je.href)}function wr(t){return Object.keys(t).length===0}const pr=typeof window<"u"?window:typeof globalThis<"u"?globalThis:global;function R(t,e){t.appendChild(e)}function H(t,e,n){t.insertBefore(e,n||null)}function U(t){t.parentNode&&t.parentNode.removeChild(t)}function yr(t,e){for(let n=0;n<t.length;n+=1)t[n]&&t[n].d(e)}function C(t){return document.createElement(t)}function Ee(t){return document.createTextNode(t)}function Y(){return Ee(" ")}function fe(t,e,n,r){return t.addEventListener(e,n,r),()=>t.removeEventListener(e,n,r)}function k(t,e,n){n==null?t.removeAttribute(e):t.getAttribute(e)!==n&&t.setAttribute(e,n)}function gr(t){return Array.from(t.childNodes)}function wt(t,e){e=""+e,t.data!==e&&(t.data=e)}function en(t,e){t.value=e??""}function tn(t,e,n){for(let r=0;r<t.options.length;r+=1){const o=t.options[r];if(o.__value===e){o.selected=!0;return}}(!n||e!==void 0)&&(t.selectedIndex=-1)}function br(t){const e=t.querySelector(":checked");return e&&e.__value}function nn(t,e,n){t.classList.toggle(e,!!n)}let Me;function Ke(t){Me=t}function mr(){if(!Me)throw new Error("Function called outside component initialization");return Me}function xr(t){mr().$$.on_mount.push(t)}const Oe=[],Qe=[];let Ie=[];const rn=[],Er=Promise.resolve();let pt=!1;function vr(){pt||(pt=!0,Er.then(on))}function Xe(t){Ie.push(t)}const yt=new Set;let Ne=0;function on(){if(Ne!==0)return;const t=Me;do{try{for(;Ne<Oe.length;){const e=Oe[Ne];Ne++,Ke(e),_r(e.$$)}}catch(e){throw Oe.length=0,Ne=0,e}for(Ke(null),Oe.length=0,Ne=0;Qe.length;)Qe.pop()();for(let e=0;e<Ie.length;e+=1){const n=Ie[e];yt.has(n)||(yt.add(n),n())}Ie.length=0}while(Oe.length);for(;rn.length;)rn.pop()();pt=!1,yt.clear(),Ke(t)}function _r(t){if(t.fragment!==null){t.update(),$e(t.before_update);const e=t.dirty;t.dirty=[-1],t.fragment&&t.fragment.p(t.ctx,e),t.after_update.forEach(Xe)}}function Sr(t){const e=[],n=[];Ie.forEach(r=>t.indexOf(r)===-1?e.push(r):n.push(r)),n.forEach(r=>r()),Ie=e}const Ar=new Set;function kr(t,e){t&&t.i&&(Ar.delete(t),t.i(e))}function sn(t){return(t==null?void 0:t.length)!==void 0?t:Array.from(t)}function Br(t,e,n){const{fragment:r,after_update:o}=t.$$;r&&r.m(e,n),Xe(()=>{const s=t.$$.on_mount.map(ue).filter(Xt);t.$$.on_destroy?t.$$.on_destroy.push(...s):$e(s),t.$$.on_mount=[]}),o.forEach(Xe)}function $r(t,e){const n=t.$$;n.fragment!==null&&(Sr(n.after_update),$e(n.on_destroy),n.fragment&&n.fragment.d(e),n.on_destroy=n.fragment=null,n.ctx=[])}function Or(t,e){t.$$.dirty[0]===-1&&(Oe.push(t),vr(),t.$$.dirty.fill(0)),t.$$.dirty[e/31|0]|=1<<e%31}function Ir(t,e,n,r,o,s,i=null,c=[-1]){const a=Me;Ke(t);const l=t.$$={fragment:null,ctx:[],props:s,update:K,not_equal:o,bound:Qt(),on_mount:[],on_destroy:[],on_disconnect:[],before_update:[],after_update:[],context:new Map(e.context||(a?a.$$.context:[])),callbacks:Qt(),dirty:c,skip_bound:!1,root:e.target||a.$$.root};i&&i(l.root);let f=!1;if(l.ctx=n?n(t,e.props||{},(u,y,...p)=>{const w=p.length?p[0]:y;return l.ctx&&o(l.ctx[u],l.ctx[u]=w)&&(!l.skip_bound&&l.bound[u]&&l.bound[u](w),f&&Or(t,u)),y}):[],l.update(),f=!0,$e(l.before_update),l.fragment=r?r(l.ctx):!1,e.target){if(e.hydrate){const u=gr(e.target);l.fragment&&l.fragment.l(u),u.forEach(U)}else l.fragment&&l.fragment.c();e.intro&&kr(t.$$.fragment),Br(t,e.target,e.anchor),on()}Ke(a)}class Nr{constructor(){g(this,"$$");g(this,"$$set")}$destroy(){$r(this,1),this.$destroy=K}$on(e,n){if(!Xt(n))return K;const r=this.$$.callbacks[e]||(this.$$.callbacks[e]=[]);return r.push(n),()=>{const o=r.indexOf(n);o!==-1&&r.splice(o,1)}}$set(e){this.$$set&&!wr(e)&&(this.$$.skip_bound=!0,this.$$set(e),this.$$.skip_bound=!1)}}const Tr="4";typeof window<"u"&&(window.__svelte||(window.__svelte={v:new Set})).v.add(Tr);function Cr(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}var gt={exports:{}};function cn(t,e=100,n={}){if(typeof t!="function")throw new TypeError(`Expected the first parameter to be a function, got \`${typeof t}\`.`);if(e<0)throw new RangeError("`wait` must not be negative.");const{immediate:r}=typeof n=="boolean"?{immediate:n}:n;let o,s,i,c,a;function l(){const u=Date.now()-c;if(u<e&&u>=0)i=setTimeout(l,e-u);else if(i=void 0,!r){const y=o,p=s;o=void 0,s=void 0,a=t.apply(y,p)}}const f=function(...u){if(o&&this!==o)throw new Error("Debounced method called with different contexts.");o=this,s=u,c=Date.now();const y=r&&!i;if(i||(i=setTimeout(l,e)),y){const p=o,w=s;o=void 0,s=void 0,a=t.apply(p,w)}return a};return f.clear=()=>{i&&(clearTimeout(i),i=void 0)},f.flush=()=>{if(!i)return;const u=o,y=s;o=void 0,s=void 0,a=t.apply(u,y),clearTimeout(i),i=void 0},f}gt.exports.debounce=cn,gt.exports=cn;var Pr=gt.exports;const Rr=Cr(Pr),bt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */const an=t=>t instanceof Uint8Array,mt=t=>new DataView(t.buffer,t.byteOffset,t.byteLength),ne=(t,e)=>t<<32-e|t>>>e;if(!(new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68))throw new Error("Non little-endian hardware is not supported");const Ur=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function D(t){if(!an(t))throw new Error("Uint8Array expected");let e="";for(let n=0;n<t.length;n++)e+=Ur[t[n]];return e}function xt(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);const e=t.length;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);const n=new Uint8Array(e/2);for(let r=0;r<n.length;r++){const o=r*2,s=t.slice(o,o+2),i=Number.parseInt(s,16);if(Number.isNaN(i)||i<0)throw new Error("Invalid byte sequence");n[r]=i}return n}function Hr(t){if(typeof t!="string")throw new Error(`utf8ToBytes expected string, got ${typeof t}`);return new Uint8Array(new TextEncoder().encode(t))}function ln(t){if(typeof t=="string"&&(t=Hr(t)),!an(t))throw new Error(`expected Uint8Array, got ${typeof t}`);return t}let Lr=class{clone(){return this._cloneInto()}};function un(t){const e=r=>t().update(ln(r)).digest(),n=t();return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=()=>t(),e}function qr(t=32){if(bt&&typeof bt.getRandomValues=="function")return bt.getRandomValues(new Uint8Array(t));throw new Error("crypto.getRandomValues must be defined")}function fn(t){if(!Number.isSafeInteger(t)||t<0)throw new Error(`Wrong positive integer: ${t}`)}function dn(t,...e){if(!(t instanceof Uint8Array))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(t.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${t.length}`)}function Mr(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");fn(t.outputLen),fn(t.blockLen)}function et(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function Kr(t,e){dn(t);const n=e.outputLen;if(t.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const Et=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */const hn=t=>t instanceof Uint8Array,vt=t=>new DataView(t.buffer,t.byteOffset,t.byteLength),re=(t,e)=>t<<32-e|t>>>e;if(!(new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68))throw new Error("Non little-endian hardware is not supported");function jr(t){if(typeof t!="string")throw new Error(`utf8ToBytes expected string, got ${typeof t}`);return new Uint8Array(new TextEncoder().encode(t))}function _t(t){if(typeof t=="string"&&(t=jr(t)),!hn(t))throw new Error(`expected Uint8Array, got ${typeof t}`);return t}function zr(...t){const e=new Uint8Array(t.reduce((r,o)=>r+o.length,0));let n=0;return t.forEach(r=>{if(!hn(r))throw new Error("Uint8Array expected");e.set(r,n),n+=r.length}),e}class wn{clone(){return this._cloneInto()}}function Vr(t){const e=r=>t().update(_t(r)).digest(),n=t();return e.outputLen=n.outputLen,e.blockLen=n.blockLen,e.create=()=>t(),e}function pn(t=32){if(Et&&typeof Et.getRandomValues=="function")return Et.getRandomValues(new Uint8Array(t));throw new Error("crypto.getRandomValues must be defined")}function Dr(t,e,n,r){if(typeof t.setBigUint64=="function")return t.setBigUint64(e,n,r);const o=BigInt(32),s=BigInt(4294967295),i=Number(n>>o&s),c=Number(n&s),a=r?4:0,l=r?0:4;t.setUint32(e+a,i,r),t.setUint32(e+l,c,r)}let Wr=class extends wn{constructor(e,n,r,o){super(),this.blockLen=e,this.outputLen=n,this.padOffset=r,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=vt(this.buffer)}update(e){et(this);const{view:n,buffer:r,blockLen:o}=this;e=_t(e);const s=e.length;for(let i=0;i<s;){const c=Math.min(o-this.pos,s-i);if(c===o){const a=vt(e);for(;o<=s-i;i+=o)this.process(a,i);continue}r.set(e.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===o&&(this.process(n,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){et(this),Kr(e,this),this.finished=!0;const{buffer:n,view:r,blockLen:o,isLE:s}=this;let{pos:i}=this;n[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(r,0),i=0);for(let u=i;u<o;u++)n[u]=0;Dr(r,o-8,BigInt(this.length*8),s),this.process(r,0);const c=vt(e),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const l=a/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)c.setUint32(4*u,f[u],s)}digest(){const{buffer:e,outputLen:n}=this;this.digestInto(e);const r=e.slice(0,n);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:n,buffer:r,length:o,finished:s,destroyed:i,pos:c}=this;return e.length=o,e.pos=c,e.finished=s,e.destroyed=i,o%n&&e.buffer.set(r),e}};const Fr=(t,e,n)=>t&e^~t&n,Gr=(t,e,n)=>t&e^t&n^e&n,Zr=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),de=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),he=new Uint32Array(64);let Jr=class extends Wr{constructor(){super(64,32,8,!1),this.A=de[0]|0,this.B=de[1]|0,this.C=de[2]|0,this.D=de[3]|0,this.E=de[4]|0,this.F=de[5]|0,this.G=de[6]|0,this.H=de[7]|0}get(){const{A:e,B:n,C:r,D:o,E:s,F:i,G:c,H:a}=this;return[e,n,r,o,s,i,c,a]}set(e,n,r,o,s,i,c,a){this.A=e|0,this.B=n|0,this.C=r|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=c|0,this.H=a|0}process(e,n){for(let u=0;u<16;u++,n+=4)he[u]=e.getUint32(n,!1);for(let u=16;u<64;u++){const y=he[u-15],p=he[u-2],w=re(y,7)^re(y,18)^y>>>3,d=re(p,17)^re(p,19)^p>>>10;he[u]=d+he[u-7]+w+he[u-16]|0}let{A:r,B:o,C:s,D:i,E:c,F:a,G:l,H:f}=this;for(let u=0;u<64;u++){const y=re(c,6)^re(c,11)^re(c,25),p=f+y+Fr(c,a,l)+Zr[u]+he[u]|0,d=(re(r,2)^re(r,13)^re(r,22))+Gr(r,o,s)|0;f=l,l=a,a=c,c=i+p|0,i=s,s=o,o=r,r=p+d|0}r=r+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,c=c+this.E|0,a=a+this.F|0,l=l+this.G|0,f=f+this.H|0,this.set(r,o,s,i,c,a,l,f)}roundClean(){he.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};const St=Vr(()=>new Jr);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const yn=BigInt(0),tt=BigInt(1),Yr=BigInt(2),nt=t=>t instanceof Uint8Array,Qr=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function Te(t){if(!nt(t))throw new Error("Uint8Array expected");let e="";for(let n=0;n<t.length;n++)e+=Qr[t[n]];return e}function gn(t){const e=t.toString(16);return e.length&1?`0${e}`:e}function At(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);return BigInt(t===""?"0":`0x${t}`)}function Ce(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);const e=t.length;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);const n=new Uint8Array(e/2);for(let r=0;r<n.length;r++){const o=r*2,s=t.slice(o,o+2),i=Number.parseInt(s,16);if(Number.isNaN(i)||i<0)throw new Error("Invalid byte sequence");n[r]=i}return n}function Z(t){return At(Te(t))}function kt(t){if(!nt(t))throw new Error("Uint8Array expected");return At(Te(Uint8Array.from(t).reverse()))}function we(t,e){return Ce(t.toString(16).padStart(e*2,"0"))}function Bt(t,e){return we(t,e).reverse()}function Xr(t){return Ce(gn(t))}function V(t,e,n){let r;if(typeof e=="string")try{r=Ce(e)}catch(s){throw new Error(`${t} must be valid hex string, got "${e}". Cause: ${s}`)}else if(nt(e))r=Uint8Array.from(e);else throw new Error(`${t} must be hex string or Uint8Array`);const o=r.length;if(typeof n=="number"&&o!==n)throw new Error(`${t} expected ${n} bytes, got ${o}`);return r}function ve(...t){const e=new Uint8Array(t.reduce((r,o)=>r+o.length,0));let n=0;return t.forEach(r=>{if(!nt(r))throw new Error("Uint8Array expected");e.set(r,n),n+=r.length}),e}function eo(t,e){if(t.length!==e.length)return!1;for(let n=0;n<t.length;n++)if(t[n]!==e[n])return!1;return!0}function to(t){if(typeof t!="string")throw new Error(`utf8ToBytes expected string, got ${typeof t}`);return new Uint8Array(new TextEncoder().encode(t))}function no(t){let e;for(e=0;t>yn;t>>=tt,e+=1);return e}function ro(t,e){return t>>BigInt(e)&tt}const oo=(t,e,n)=>t|(n?tt:yn)<<BigInt(e),$t=t=>(Yr<<BigInt(t-1))-tt,Ot=t=>new Uint8Array(t),bn=t=>Uint8Array.from(t);function mn(t,e,n){if(typeof t!="number"||t<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof n!="function")throw new Error("hmacFn must be a function");let r=Ot(t),o=Ot(t),s=0;const i=()=>{r.fill(1),o.fill(0),s=0},c=(...u)=>n(o,r,...u),a=(u=Ot())=>{o=c(bn([0]),u),r=c(),u.length!==0&&(o=c(bn([1]),u),r=c())},l=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let u=0;const y=[];for(;u<e;){r=c();const p=r.slice();y.push(p),u+=r.length}return ve(...y)};return(u,y)=>{i(),a(u);let p;for(;!(p=y(l()));)a();return i(),p}}const so={bigint:t=>typeof t=="bigint",function:t=>typeof t=="function",boolean:t=>typeof t=="boolean",string:t=>typeof t=="string",stringOrUint8Array:t=>typeof t=="string"||t instanceof Uint8Array,isSafeInteger:t=>Number.isSafeInteger(t),array:t=>Array.isArray(t),field:(t,e)=>e.Fp.isValid(t),hash:t=>typeof t=="function"&&Number.isSafeInteger(t.outputLen)};function je(t,e,n={}){const r=(o,s,i)=>{const c=so[s];if(typeof c!="function")throw new Error(`Invalid validator "${s}", expected function`);const a=t[o];if(!(i&&a===void 0)&&!c(a,t))throw new Error(`Invalid param ${String(o)}=${a} (${typeof a}), expected ${s}`)};for(const[o,s]of Object.entries(e))r(o,s,!1);for(const[o,s]of Object.entries(n))r(o,s,!0);return t}const io=Object.freeze(Object.defineProperty({__proto__:null,bitGet:ro,bitLen:no,bitMask:$t,bitSet:oo,bytesToHex:Te,bytesToNumberBE:Z,bytesToNumberLE:kt,concatBytes:ve,createHmacDrbg:mn,ensureBytes:V,equalBytes:eo,hexToBytes:Ce,hexToNumber:At,numberToBytesBE:we,numberToBytesLE:Bt,numberToHexUnpadded:gn,numberToVarBytesBE:Xr,utf8ToBytes:to,validateObject:je},Symbol.toStringTag,{value:"Module"}));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const M=BigInt(0),L=BigInt(1),_e=BigInt(2),co=BigInt(3),It=BigInt(4),xn=BigInt(5),En=BigInt(8);BigInt(9),BigInt(16);function j(t,e){const n=t%e;return n>=M?n:e+n}function ao(t,e,n){if(n<=M||e<M)throw new Error("Expected power/modulo > 0");if(n===L)return M;let r=L;for(;e>M;)e&L&&(r=r*t%n),t=t*t%n,e>>=L;return r}function X(t,e,n){let r=t;for(;e-- >M;)r*=r,r%=n;return r}function Nt(t,e){if(t===M||e<=M)throw new Error(`invert: expected positive integers, got n=${t} mod=${e}`);let n=j(t,e),r=e,o=M,s=L;for(;n!==M;){const c=r/n,a=r%n,l=o-s*c;r=n,n=a,o=s,s=l}if(r!==L)throw new Error("invert: does not exist");return j(o,e)}function lo(t){const e=(t-L)/_e;let n,r,o;for(n=t-L,r=0;n%_e===M;n/=_e,r++);for(o=_e;o<t&&ao(o,e,t)!==t-L;o++);if(r===1){const i=(t+L)/It;return function(a,l){const f=a.pow(l,i);if(!a.eql(a.sqr(f),l))throw new Error("Cannot find square root");return f}}const s=(n+L)/_e;return function(c,a){if(c.pow(a,e)===c.neg(c.ONE))throw new Error("Cannot find square root");let l=r,f=c.pow(c.mul(c.ONE,o),n),u=c.pow(a,s),y=c.pow(a,n);for(;!c.eql(y,c.ONE);){if(c.eql(y,c.ZERO))return c.ZERO;let p=1;for(let d=c.sqr(y);p<l&&!c.eql(d,c.ONE);p++)d=c.sqr(d);const w=c.pow(f,L<<BigInt(l-p-1));f=c.sqr(w),u=c.mul(u,w),y=c.mul(y,f),l=p}return u}}function uo(t){if(t%It===co){const e=(t+L)/It;return function(r,o){const s=r.pow(o,e);if(!r.eql(r.sqr(s),o))throw new Error("Cannot find square root");return s}}if(t%En===xn){const e=(t-xn)/En;return function(r,o){const s=r.mul(o,_e),i=r.pow(s,e),c=r.mul(o,i),a=r.mul(r.mul(c,_e),i),l=r.mul(c,r.sub(a,r.ONE));if(!r.eql(r.sqr(l),o))throw new Error("Cannot find square root");return l}}return lo(t)}const fo=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ho(t){const e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},n=fo.reduce((r,o)=>(r[o]="function",r),e);return je(t,n)}function wo(t,e,n){if(n<M)throw new Error("Expected power > 0");if(n===M)return t.ONE;if(n===L)return e;let r=t.ONE,o=e;for(;n>M;)n&L&&(r=t.mul(r,o)),o=t.sqr(o),n>>=L;return r}function po(t,e){const n=new Array(e.length),r=e.reduce((s,i,c)=>t.is0(i)?s:(n[c]=s,t.mul(s,i)),t.ONE),o=t.inv(r);return e.reduceRight((s,i,c)=>t.is0(i)?s:(n[c]=t.mul(s,n[c]),t.mul(s,i)),o),n}function vn(t,e){const n=e!==void 0?e:t.toString(2).length,r=Math.ceil(n/8);return{nBitLength:n,nByteLength:r}}function yo(t,e,n=!1,r={}){if(t<=M)throw new Error(`Expected Field ORDER > 0, got ${t}`);const{nBitLength:o,nByteLength:s}=vn(t,e);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");const i=uo(t),c=Object.freeze({ORDER:t,BITS:o,BYTES:s,MASK:$t(o),ZERO:M,ONE:L,create:a=>j(a,t),isValid:a=>{if(typeof a!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof a}`);return M<=a&&a<t},is0:a=>a===M,isOdd:a=>(a&L)===L,neg:a=>j(-a,t),eql:(a,l)=>a===l,sqr:a=>j(a*a,t),add:(a,l)=>j(a+l,t),sub:(a,l)=>j(a-l,t),mul:(a,l)=>j(a*l,t),pow:(a,l)=>wo(c,a,l),div:(a,l)=>j(a*Nt(l,t),t),sqrN:a=>a*a,addN:(a,l)=>a+l,subN:(a,l)=>a-l,mulN:(a,l)=>a*l,inv:a=>Nt(a,t),sqrt:r.sqrt||(a=>i(c,a)),invertBatch:a=>po(c,a),cmov:(a,l,f)=>f?l:a,toBytes:a=>n?Bt(a,s):we(a,s),fromBytes:a=>{if(a.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${a.length}`);return n?kt(a):Z(a)}});return Object.freeze(c)}function _n(t){if(typeof t!="bigint")throw new Error("field order must be bigint");const e=t.toString(2).length;return Math.ceil(e/8)}function Sn(t){const e=_n(t);return e+Math.ceil(e/2)}function go(t,e,n=!1){const r=t.length,o=_n(e),s=Sn(e);if(r<16||r<s||r>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${r}`);const i=n?Z(t):kt(t),c=j(i,e-L)+L;return n?Bt(c,o):we(c,o)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const bo=BigInt(0),Tt=BigInt(1);function mo(t,e){const n=(o,s)=>{const i=s.negate();return o?i:s},r=o=>{const s=Math.ceil(e/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:n,unsafeLadder(o,s){let i=t.ZERO,c=o;for(;s>bo;)s&Tt&&(i=i.add(c)),c=c.double(),s>>=Tt;return i},precomputeWindow(o,s){const{windows:i,windowSize:c}=r(s),a=[];let l=o,f=l;for(let u=0;u<i;u++){f=l,a.push(f);for(let y=1;y<c;y++)f=f.add(l),a.push(f);l=f.double()}return a},wNAF(o,s,i){const{windows:c,windowSize:a}=r(o);let l=t.ZERO,f=t.BASE;const u=BigInt(2**o-1),y=2**o,p=BigInt(o);for(let w=0;w<c;w++){const d=w*a;let h=Number(i&u);i>>=p,h>a&&(h-=y,i+=Tt);const b=d,E=d+Math.abs(h)-1,S=w%2!==0,I=h<0;h===0?f=f.add(n(S,s[b])):l=l.add(n(I,s[E]))}return{p:l,f}},wNAFCached(o,s,i,c){const a=o._WINDOW_SIZE||1;let l=s.get(o);return l||(l=this.precomputeWindow(o,a),a!==1&&s.set(o,c(l))),this.wNAF(a,l,i)}}}function An(t){return ho(t.Fp),je(t,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...vn(t.n,t.nBitLength),...t,p:t.Fp.ORDER})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function xo(t){const e=An(t);je(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});const{endo:n,Fp:r,a:o}=e;if(n){if(!r.eql(o,r.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof n!="object"||typeof n.beta!="bigint"||typeof n.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}const{bytesToNumberBE:Eo,hexToBytes:vo}=io,Se={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(t){const{Err:e}=Se;if(t.length<2||t[0]!==2)throw new e("Invalid signature integer tag");const n=t[1],r=t.subarray(2,n+2);if(!n||r.length!==n)throw new e("Invalid signature integer: wrong length");if(r[0]&128)throw new e("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:Eo(r),l:t.subarray(n+2)}},toSig(t){const{Err:e}=Se,n=typeof t=="string"?vo(t):t;if(!(n instanceof Uint8Array))throw new Error("ui8a expected");let r=n.length;if(r<2||n[0]!=48)throw new e("Invalid signature tag");if(n[1]!==r-2)throw new e("Invalid signature: incorrect length");const{d:o,l:s}=Se._parseInt(n.subarray(2)),{d:i,l:c}=Se._parseInt(s);if(c.length)throw new e("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(t){const e=l=>Number.parseInt(l[0],16)&8?"00"+l:l,n=l=>{const f=l.toString(16);return f.length&1?`0${f}`:f},r=e(n(t.s)),o=e(n(t.r)),s=r.length/2,i=o.length/2,c=n(s),a=n(i);return`30${n(i+s+4)}02${a}${o}02${c}${r}`}},se=BigInt(0),ee=BigInt(1);BigInt(2);const kn=BigInt(3);BigInt(4);function _o(t){const e=xo(t),{Fp:n}=e,r=e.toBytes||((w,d,h)=>{const b=d.toAffine();return ve(Uint8Array.from([4]),n.toBytes(b.x),n.toBytes(b.y))}),o=e.fromBytes||(w=>{const d=w.subarray(1),h=n.fromBytes(d.subarray(0,n.BYTES)),b=n.fromBytes(d.subarray(n.BYTES,2*n.BYTES));return{x:h,y:b}});function s(w){const{a:d,b:h}=e,b=n.sqr(w),E=n.mul(b,w);return n.add(n.add(E,n.mul(w,d)),h)}if(!n.eql(n.sqr(e.Gy),s(e.Gx)))throw new Error("bad generator point: equation left != right");function i(w){return typeof w=="bigint"&&se<w&&w<e.n}function c(w){if(!i(w))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function a(w){const{allowedPrivateKeyLengths:d,nByteLength:h,wrapPrivateKey:b,n:E}=e;if(d&&typeof w!="bigint"){if(w instanceof Uint8Array&&(w=Te(w)),typeof w!="string"||!d.includes(w.length))throw new Error("Invalid key");w=w.padStart(h*2,"0")}let S;try{S=typeof w=="bigint"?w:Z(V("private key",w,h))}catch{throw new Error(`private key must be ${h} bytes, hex or bigint, not ${typeof w}`)}return b&&(S=j(S,E)),c(S),S}const l=new Map;function f(w){if(!(w instanceof u))throw new Error("ProjectivePoint expected")}class u{constructor(d,h,b){if(this.px=d,this.py=h,this.pz=b,d==null||!n.isValid(d))throw new Error("x required");if(h==null||!n.isValid(h))throw new Error("y required");if(b==null||!n.isValid(b))throw new Error("z required")}static fromAffine(d){const{x:h,y:b}=d||{};if(!d||!n.isValid(h)||!n.isValid(b))throw new Error("invalid affine point");if(d instanceof u)throw new Error("projective point not allowed");const E=S=>n.eql(S,n.ZERO);return E(h)&&E(b)?u.ZERO:new u(h,b,n.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){const h=n.invertBatch(d.map(b=>b.pz));return d.map((b,E)=>b.toAffine(h[E])).map(u.fromAffine)}static fromHex(d){const h=u.fromAffine(o(V("pointHex",d)));return h.assertValidity(),h}static fromPrivateKey(d){return u.BASE.multiply(a(d))}_setWindowSize(d){this._WINDOW_SIZE=d,l.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!n.is0(this.py))return;throw new Error("bad point: ZERO")}const{x:d,y:h}=this.toAffine();if(!n.isValid(d)||!n.isValid(h))throw new Error("bad point: x or y not FE");const b=n.sqr(h),E=s(d);if(!n.eql(b,E))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){const{y:d}=this.toAffine();if(n.isOdd)return!n.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);const{px:h,py:b,pz:E}=this,{px:S,py:I,pz:$}=d,_=n.eql(n.mul(h,$),n.mul(S,E)),A=n.eql(n.mul(b,$),n.mul(I,E));return _&&A}negate(){return new u(this.px,n.neg(this.py),this.pz)}double(){const{a:d,b:h}=e,b=n.mul(h,kn),{px:E,py:S,pz:I}=this;let $=n.ZERO,_=n.ZERO,A=n.ZERO,O=n.mul(E,E),J=n.mul(S,S),P=n.mul(I,I),N=n.mul(E,S);return N=n.add(N,N),A=n.mul(E,I),A=n.add(A,A),$=n.mul(d,A),_=n.mul(b,P),_=n.add($,_),$=n.sub(J,_),_=n.add(J,_),_=n.mul($,_),$=n.mul(N,$),A=n.mul(b,A),P=n.mul(d,P),N=n.sub(O,P),N=n.mul(d,N),N=n.add(N,A),A=n.add(O,O),O=n.add(A,O),O=n.add(O,P),O=n.mul(O,N),_=n.add(_,O),P=n.mul(S,I),P=n.add(P,P),O=n.mul(P,N),$=n.sub($,O),A=n.mul(P,J),A=n.add(A,A),A=n.add(A,A),new u($,_,A)}add(d){f(d);const{px:h,py:b,pz:E}=this,{px:S,py:I,pz:$}=d;let _=n.ZERO,A=n.ZERO,O=n.ZERO;const J=e.a,P=n.mul(e.b,kn);let N=n.mul(h,S),F=n.mul(b,I),z=n.mul(E,$),oe=n.add(h,b),m=n.add(S,I);oe=n.mul(oe,m),m=n.add(N,F),oe=n.sub(oe,m),m=n.add(h,E);let v=n.add(S,$);return m=n.mul(m,v),v=n.add(N,z),m=n.sub(m,v),v=n.add(b,E),_=n.add(I,$),v=n.mul(v,_),_=n.add(F,z),v=n.sub(v,_),O=n.mul(J,m),_=n.mul(P,z),O=n.add(_,O),_=n.sub(F,O),O=n.add(F,O),A=n.mul(_,O),F=n.add(N,N),F=n.add(F,N),z=n.mul(J,z),m=n.mul(P,m),F=n.add(F,z),z=n.sub(N,z),z=n.mul(J,z),m=n.add(m,z),N=n.mul(F,m),A=n.add(A,N),N=n.mul(v,m),_=n.mul(oe,_),_=n.sub(_,N),N=n.mul(oe,F),O=n.mul(v,O),O=n.add(O,N),new u(_,A,O)}subtract(d){return this.add(d.negate())}is0(){return this.equals(u.ZERO)}wNAF(d){return p.wNAFCached(this,l,d,h=>{const b=n.invertBatch(h.map(E=>E.pz));return h.map((E,S)=>E.toAffine(b[S])).map(u.fromAffine)})}multiplyUnsafe(d){const h=u.ZERO;if(d===se)return h;if(c(d),d===ee)return this;const{endo:b}=e;if(!b)return p.unsafeLadder(this,d);let{k1neg:E,k1:S,k2neg:I,k2:$}=b.splitScalar(d),_=h,A=h,O=this;for(;S>se||$>se;)S&ee&&(_=_.add(O)),$&ee&&(A=A.add(O)),O=O.double(),S>>=ee,$>>=ee;return E&&(_=_.negate()),I&&(A=A.negate()),A=new u(n.mul(A.px,b.beta),A.py,A.pz),_.add(A)}multiply(d){c(d);let h=d,b,E;const{endo:S}=e;if(S){const{k1neg:I,k1:$,k2neg:_,k2:A}=S.splitScalar(h);let{p:O,f:J}=this.wNAF($),{p:P,f:N}=this.wNAF(A);O=p.constTimeNegate(I,O),P=p.constTimeNegate(_,P),P=new u(n.mul(P.px,S.beta),P.py,P.pz),b=O.add(P),E=J.add(N)}else{const{p:I,f:$}=this.wNAF(h);b=I,E=$}return u.normalizeZ([b,E])[0]}multiplyAndAddUnsafe(d,h,b){const E=u.BASE,S=($,_)=>_===se||_===ee||!$.equals(E)?$.multiplyUnsafe(_):$.multiply(_),I=S(this,h).add(S(d,b));return I.is0()?void 0:I}toAffine(d){const{px:h,py:b,pz:E}=this,S=this.is0();d==null&&(d=S?n.ONE:n.inv(E));const I=n.mul(h,d),$=n.mul(b,d),_=n.mul(E,d);if(S)return{x:n.ZERO,y:n.ZERO};if(!n.eql(_,n.ONE))throw new Error("invZ was invalid");return{x:I,y:$}}isTorsionFree(){const{h:d,isTorsionFree:h}=e;if(d===ee)return!0;if(h)return h(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){const{h:d,clearCofactor:h}=e;return d===ee?this:h?h(u,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return this.assertValidity(),r(u,this,d)}toHex(d=!0){return Te(this.toRawBytes(d))}}u.BASE=new u(e.Gx,e.Gy,n.ONE),u.ZERO=new u(n.ZERO,n.ONE,n.ZERO);const y=e.nBitLength,p=mo(u,e.endo?Math.ceil(y/2):y);return{CURVE:e,ProjectivePoint:u,normPrivateKeyToScalar:a,weierstrassEquation:s,isWithinCurveOrder:i}}function So(t){const e=An(t);return je(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Ao(t){const e=So(t),{Fp:n,n:r}=e,o=n.BYTES+1,s=2*n.BYTES+1;function i(m){return se<m&&m<n.ORDER}function c(m){return j(m,r)}function a(m){return Nt(m,r)}const{ProjectivePoint:l,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:y}=_o({...e,toBytes(m,v,x){const B=v.toAffine(),T=n.toBytes(B.x),q=ve;return x?q(Uint8Array.from([v.hasEvenY()?2:3]),T):q(Uint8Array.from([4]),T,n.toBytes(B.y))},fromBytes(m){const v=m.length,x=m[0],B=m.subarray(1);if(v===o&&(x===2||x===3)){const T=Z(B);if(!i(T))throw new Error("Point is not on curve");const q=u(T);let G=n.sqrt(q);const Q=(G&ee)===ee;return(x&1)===1!==Q&&(G=n.neg(G)),{x:T,y:G}}else if(v===s&&x===4){const T=n.fromBytes(B.subarray(0,n.BYTES)),q=n.fromBytes(B.subarray(n.BYTES,2*n.BYTES));return{x:T,y:q}}else throw new Error(`Point of length ${v} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),p=m=>Te(we(m,e.nByteLength));function w(m){const v=r>>ee;return m>v}function d(m){return w(m)?c(-m):m}const h=(m,v,x)=>Z(m.slice(v,x));class b{constructor(v,x,B){this.r=v,this.s=x,this.recovery=B,this.assertValidity()}static fromCompact(v){const x=e.nByteLength;return v=V("compactSignature",v,x*2),new b(h(v,0,x),h(v,x,2*x))}static fromDER(v){const{r:x,s:B}=Se.toSig(V("DER",v));return new b(x,B)}assertValidity(){if(!y(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!y(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(v){return new b(this.r,this.s,v)}recoverPublicKey(v){const{r:x,s:B,recovery:T}=this,q=A(V("msgHash",v));if(T==null||![0,1,2,3].includes(T))throw new Error("recovery id invalid");const G=T===2||T===3?x+e.n:x;if(G>=n.ORDER)throw new Error("recovery id 2 or 3 invalid");const Q=T&1?"03":"02",be=l.fromHex(Q+p(G)),me=a(G),Ue=c(-q*me),Ze=c(B*me),xe=l.BASE.multiplyAndAddUnsafe(be,Ue,Ze);if(!xe)throw new Error("point at infinify");return xe.assertValidity(),xe}hasHighS(){return w(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return Ce(this.toDERHex())}toDERHex(){return Se.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ce(this.toCompactHex())}toCompactHex(){return p(this.r)+p(this.s)}}const E={isValidPrivateKey(m){try{return f(m),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{const m=Sn(e.n);return go(e.randomBytes(m),e.n)},precompute(m=8,v=l.BASE){return v._setWindowSize(m),v.multiply(BigInt(3)),v}};function S(m,v=!0){return l.fromPrivateKey(m).toRawBytes(v)}function I(m){const v=m instanceof Uint8Array,x=typeof m=="string",B=(v||x)&&m.length;return v?B===o||B===s:x?B===2*o||B===2*s:m instanceof l}function $(m,v,x=!0){if(I(m))throw new Error("first arg must be private key");if(!I(v))throw new Error("second arg must be public key");return l.fromHex(v).multiply(f(m)).toRawBytes(x)}const _=e.bits2int||function(m){const v=Z(m),x=m.length*8-e.nBitLength;return x>0?v>>BigInt(x):v},A=e.bits2int_modN||function(m){return c(_(m))},O=$t(e.nBitLength);function J(m){if(typeof m!="bigint")throw new Error("bigint expected");if(!(se<=m&&m<O))throw new Error(`bigint expected < 2^${e.nBitLength}`);return we(m,e.nByteLength)}function P(m,v,x=N){if(["recovered","canonical"].some(Be=>Be in x))throw new Error("sign() legacy options not supported");const{hash:B,randomBytes:T}=e;let{lowS:q,prehash:G,extraEntropy:Q}=x;q==null&&(q=!0),m=V("msgHash",m),G&&(m=V("prehashed msgHash",B(m)));const be=A(m),me=f(v),Ue=[J(me),J(be)];if(Q!=null){const Be=Q===!0?T(n.BYTES):Q;Ue.push(V("extraEntropy",Be))}const Ze=ve(...Ue),xe=be;function Yt(Be){const He=_(Be);if(!y(He))return;const ur=a(He),Le=l.BASE.multiply(He).toAffine(),te=c(Le.x);if(te===se)return;const qe=c(ur*c(xe+te*me));if(qe===se)return;let fr=(Le.x===te?0:2)|Number(Le.y&ee),dr=qe;return q&&w(qe)&&(dr=d(qe),fr^=1),new b(te,dr,fr)}return{seed:Ze,k2sig:Yt}}const N={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function z(m,v,x=N){const{seed:B,k2sig:T}=P(m,v,x),q=e;return mn(q.hash.outputLen,q.nByteLength,q.hmac)(B,T)}l.BASE._setWindowSize(8);function oe(m,v,x,B=F){var Le;const T=m;if(v=V("msgHash",v),x=V("publicKey",x),"strict"in B)throw new Error("options.strict was renamed to lowS");const{lowS:q,prehash:G}=B;let Q,be;try{if(typeof T=="string"||T instanceof Uint8Array)try{Q=b.fromDER(T)}catch(te){if(!(te instanceof Se.Err))throw te;Q=b.fromCompact(T)}else if(typeof T=="object"&&typeof T.r=="bigint"&&typeof T.s=="bigint"){const{r:te,s:qe}=T;Q=new b(te,qe)}else throw new Error("PARSE");be=l.fromHex(x)}catch(te){if(te.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(q&&Q.hasHighS())return!1;G&&(v=e.hash(v));const{r:me,s:Ue}=Q,Ze=A(v),xe=a(Ue),Yt=c(Ze*xe),Be=c(me*xe),He=(Le=l.BASE.multiplyAndAddUnsafe(be,Yt,Be))==null?void 0:Le.toAffine();return He?c(He.x)===me:!1}return{CURVE:e,getPublicKey:S,getSharedSecret:$,sign:z,verify:oe,ProjectivePoint:l,Signature:b,utils:E}}class Bn extends wn{constructor(e,n){super(),this.finished=!1,this.destroyed=!1,Mr(e);const r=_t(n);if(this.iHash=e.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;const o=this.blockLen,s=new Uint8Array(o);s.set(r.length>o?e.create().update(r).digest():r);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=e.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(e){return et(this),this.iHash.update(e),this}digestInto(e){et(this),dn(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){const e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));const{oHash:n,iHash:r,finished:o,destroyed:s,blockLen:i,outputLen:c}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=c,e.oHash=n._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}const $n=(t,e,n)=>new Bn(t,e).update(n).digest();$n.create=(t,e)=>new Bn(t,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function ko(t){return{hash:t,hmac:(e,...n)=>$n(t,e,zr(...n)),randomBytes:pn}}function Bo(t,e){const n=r=>Ao({...t,...ko(r)});return Object.freeze({...n(e),create:n})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const rt=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),ot=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),On=BigInt(1),st=BigInt(2),In=(t,e)=>(t+e/st)/e;function Nn(t){const e=rt,n=BigInt(3),r=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),l=t*t*t%e,f=l*l*t%e,u=X(f,n,e)*f%e,y=X(u,n,e)*f%e,p=X(y,st,e)*l%e,w=X(p,o,e)*p%e,d=X(w,s,e)*w%e,h=X(d,c,e)*d%e,b=X(h,a,e)*h%e,E=X(b,c,e)*d%e,S=X(E,n,e)*f%e,I=X(S,i,e)*w%e,$=X(I,r,e)*l%e,_=X($,st,e);if(!Ct.eql(Ct.sqr(_),t))throw new Error("Cannot find square root");return _}const Ct=yo(rt,void 0,void 0,{sqrt:Nn}),ze=Bo({a:BigInt(0),b:BigInt(7),Fp:Ct,n:ot,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:t=>{const e=ot,n=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),r=-On*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=n,i=BigInt("0x100000000000000000000000000000000"),c=In(s*t,e),a=In(-r*t,e);let l=j(t-c*n-a*o,e),f=j(-c*r-a*s,e);const u=l>i,y=f>i;if(u&&(l=e-l),y&&(f=e-f),l>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+t);return{k1neg:u,k1:l,k2neg:y,k2:f}}}},St),it=BigInt(0),Tn=t=>typeof t=="bigint"&&it<t&&t<rt,$o=t=>typeof t=="bigint"&&it<t&&t<ot,Cn={};function ct(t,...e){let n=Cn[t];if(n===void 0){const r=St(Uint8Array.from(t,o=>o.charCodeAt(0)));n=ve(r,r),Cn[t]=n}return St(ve(n,...e))}const Pt=t=>t.toRawBytes(!0).slice(1),Rt=t=>we(t,32),Ut=t=>j(t,rt),Ve=t=>j(t,ot),Ht=ze.ProjectivePoint,Oo=(t,e,n)=>Ht.BASE.multiplyAndAddUnsafe(t,e,n);function Lt(t){let e=ze.utils.normPrivateKeyToScalar(t),n=Ht.fromPrivateKey(e);return{scalar:n.hasEvenY()?e:Ve(-e),bytes:Pt(n)}}function Pn(t){if(!Tn(t))throw new Error("bad x: need 0 < x < p");const e=Ut(t*t),n=Ut(e*t+BigInt(7));let r=Nn(n);r%st!==it&&(r=Ut(-r));const o=new Ht(t,r,On);return o.assertValidity(),o}function Rn(...t){return Ve(Z(ct("BIP0340/challenge",...t)))}function Io(t){return Lt(t).bytes}function No(t,e,n=pn(32)){const r=V("message",t),{bytes:o,scalar:s}=Lt(e),i=V("auxRand",n,32),c=Rt(s^Z(ct("BIP0340/aux",i))),a=ct("BIP0340/nonce",c,o,r),l=Ve(Z(a));if(l===it)throw new Error("sign failed: k is zero");const{bytes:f,scalar:u}=Lt(l),y=Rn(f,o,r),p=new Uint8Array(64);if(p.set(f,0),p.set(Rt(Ve(u+y*s)),32),!Un(p,r,o))throw new Error("sign: Invalid signature produced");return p}function Un(t,e,n){const r=V("signature",t,64),o=V("message",e),s=V("publicKey",n,32);try{const i=Pn(Z(s)),c=Z(r.subarray(0,32));if(!Tn(c))return!1;const a=Z(r.subarray(32,64));if(!$o(a))return!1;const l=Rn(Rt(c),Pt(i),o),f=Oo(i,a,Ve(-l));return!(!f||!f.hasEvenY()||f.toAffine().x!==c)}catch{return!1}}const W={getPublicKey:Io,sign:No,verify:Un,utils:{randomPrivateKey:ze.utils.randomPrivateKey,lift_x:Pn,pointToBytes:Pt,numberToBytesBE:we,bytesToNumberBE:Z,taggedHash:ct,mod:j}};function qt(t){if(!Number.isSafeInteger(t)||t<0)throw new Error(`Wrong positive integer: ${t}`)}function To(t){if(typeof t!="boolean")throw new Error(`Expected boolean, not ${t}`)}function Hn(t,...e){if(!(t instanceof Uint8Array))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(t.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${t.length}`)}function Co(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");qt(t.outputLen),qt(t.blockLen)}function Po(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function Ro(t,e){Hn(t);const n=e.outputLen;if(t.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const Mt={number:qt,bool:To,bytes:Hn,hash:Co,exists:Po,output:Ro};function Uo(t,e,n,r){if(typeof t.setBigUint64=="function")return t.setBigUint64(e,n,r);const o=BigInt(32),s=BigInt(4294967295),i=Number(n>>o&s),c=Number(n&s),a=r?4:0,l=r?0:4;t.setUint32(e+a,i,r),t.setUint32(e+l,c,r)}class Ho extends Lr{constructor(e,n,r,o){super(),this.blockLen=e,this.outputLen=n,this.padOffset=r,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=mt(this.buffer)}update(e){Mt.exists(this);const{view:n,buffer:r,blockLen:o}=this;e=ln(e);const s=e.length;for(let i=0;i<s;){const c=Math.min(o-this.pos,s-i);if(c===o){const a=mt(e);for(;o<=s-i;i+=o)this.process(a,i);continue}r.set(e.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===o&&(this.process(n,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Mt.exists(this),Mt.output(e,this),this.finished=!0;const{buffer:n,view:r,blockLen:o,isLE:s}=this;let{pos:i}=this;n[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(r,0),i=0);for(let u=i;u<o;u++)n[u]=0;Uo(r,o-8,BigInt(this.length*8),s),this.process(r,0);const c=mt(e),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const l=a/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)c.setUint32(4*u,f[u],s)}digest(){const{buffer:e,outputLen:n}=this;this.digestInto(e);const r=e.slice(0,n);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:n,buffer:r,length:o,finished:s,destroyed:i,pos:c}=this;return e.length=o,e.pos=c,e.finished=s,e.destroyed=i,o%n&&e.buffer.set(r),e}}const Lo=(t,e,n)=>t&e^~t&n,qo=(t,e,n)=>t&e^t&n^e&n,Mo=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),pe=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),ye=new Uint32Array(64);class Ln extends Ho{constructor(){super(64,32,8,!1),this.A=pe[0]|0,this.B=pe[1]|0,this.C=pe[2]|0,this.D=pe[3]|0,this.E=pe[4]|0,this.F=pe[5]|0,this.G=pe[6]|0,this.H=pe[7]|0}get(){const{A:e,B:n,C:r,D:o,E:s,F:i,G:c,H:a}=this;return[e,n,r,o,s,i,c,a]}set(e,n,r,o,s,i,c,a){this.A=e|0,this.B=n|0,this.C=r|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=c|0,this.H=a|0}process(e,n){for(let u=0;u<16;u++,n+=4)ye[u]=e.getUint32(n,!1);for(let u=16;u<64;u++){const y=ye[u-15],p=ye[u-2],w=ne(y,7)^ne(y,18)^y>>>3,d=ne(p,17)^ne(p,19)^p>>>10;ye[u]=d+ye[u-7]+w+ye[u-16]|0}let{A:r,B:o,C:s,D:i,E:c,F:a,G:l,H:f}=this;for(let u=0;u<64;u++){const y=ne(c,6)^ne(c,11)^ne(c,25),p=f+y+Lo(c,a,l)+Mo[u]+ye[u]|0,d=(ne(r,2)^ne(r,13)^ne(r,22))+qo(r,o,s)|0;f=l,l=a,a=c,c=i+p|0,i=s,s=o,o=r,r=p+d|0}r=r+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,c=c+this.E|0,a=a+this.F|0,l=l+this.G|0,f=f+this.H|0,this.set(r,o,s,i,c,a,l,f)}roundClean(){ye.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}}class Ko extends Ln{constructor(){super(),this.A=-1056596264,this.B=914150663,this.C=812702999,this.D=-150054599,this.E=-4191439,this.F=1750603025,this.G=1694076839,this.H=-1090891868,this.outputLen=28}}const Kt=un(()=>new Ln);un(()=>new Ko);var Pe=Symbol("verified"),jo=t=>t instanceof Object;function zo(t){if(!jo(t)||typeof t.kind!="number"||typeof t.content!="string"||typeof t.created_at!="number"||typeof t.pubkey!="string"||!t.pubkey.match(/^[a-f0-9]{64}$/)||!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){let n=t.tags[e];if(!Array.isArray(n))return!1;for(let r=0;r<n.length;r++)if(typeof n[r]=="object")return!1}return!0}new TextDecoder("utf-8");var Vo=new TextEncoder,Do=class{generateSecretKey(){return W.utils.randomPrivateKey()}getPublicKey(e){return D(W.getPublicKey(e))}finalizeEvent(e,n){const r=e;return r.pubkey=D(W.getPublicKey(n)),r.id=jt(r),r.sig=D(W.sign(jt(r),n)),r[Pe]=!0,r}verifyEvent(e){if(typeof e[Pe]=="boolean")return e[Pe];const n=jt(e);if(n!==e.id)return e[Pe]=!1,!1;try{const r=W.verify(e.sig,n,e.pubkey);return e[Pe]=r,r}catch{return e[Pe]=!1,!1}}};function Wo(t){if(!zo(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function jt(t){let e=Kt(Vo.encode(Wo(t)));return D(e)}var at=new Do,Fo=at.generateSecretKey;at.getPublicKey,at.finalizeEvent,at.verifyEvent;var Ae=Symbol("verified"),Go=t=>t instanceof Object;function Zo(t){if(!Go(t)||typeof t.kind!="number"||typeof t.content!="string"||typeof t.created_at!="number"||typeof t.pubkey!="string"||!t.pubkey.match(/^[a-f0-9]{64}$/)||!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){let n=t.tags[e];if(!Array.isArray(n))return!1;for(let r=0;r<n.length;r++)if(typeof n[r]=="object")return!1}return!0}new TextDecoder("utf-8");var Jo=new TextEncoder;function De(t){t.indexOf("://")===-1&&(t="wss://"+t);let e=new URL(t);return e.pathname=e.pathname.replace(/\/+/g,"/"),e.pathname.endsWith("/")&&(e.pathname=e.pathname.slice(0,-1)),(e.port==="80"&&e.protocol==="ws:"||e.port==="443"&&e.protocol==="wss:")&&(e.port=""),e.searchParams.sort(),e.hash="",e.toString()}var Yo=class{constructor(e){g(this,"value");g(this,"next",null);g(this,"prev",null);this.value=e}},Qo=class{constructor(){g(this,"first");g(this,"last");this.first=null,this.last=null}enqueue(e){const n=new Yo(e);return this.last?this.last===this.first?(this.last=n,this.last.prev=this.first,this.first.next=n):(n.prev=this.last,this.last.next=n,this.last=n):(this.first=n,this.last=n),!0}dequeue(){if(!this.first)return null;if(this.first===this.last){const n=this.first;return this.first=null,this.last=null,n.value}const e=this.first;return this.first=e.next,e.value}},Xo=class{generateSecretKey(){return W.utils.randomPrivateKey()}getPublicKey(e){return D(W.getPublicKey(e))}finalizeEvent(e,n){const r=e;return r.pubkey=D(W.getPublicKey(n)),r.id=zt(r),r.sig=D(W.sign(zt(r),n)),r[Ae]=!0,r}verifyEvent(e){if(typeof e[Ae]=="boolean")return e[Ae];const n=zt(e);if(n!==e.id)return e[Ae]=!1,!1;try{const r=W.verify(e.sig,n,e.pubkey);return e[Ae]=r,r}catch{return e[Ae]=!1,!1}}};function es(t){if(!Zo(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function zt(t){let e=Kt(Jo.encode(es(t)));return D(e)}var lt=new Xo;lt.generateSecretKey,lt.getPublicKey,lt.finalizeEvent;var ts=lt.verifyEvent,ns=22242;function rs(t,e){if(t.ids&&t.ids.indexOf(e.id)===-1&&!t.ids.some(n=>e.id.startsWith(n))||t.kinds&&t.kinds.indexOf(e.kind)===-1||t.authors&&t.authors.indexOf(e.pubkey)===-1&&!t.authors.some(n=>e.pubkey.startsWith(n)))return!1;for(let n in t)if(n[0]==="#"){let r=n.slice(1),o=t[`#${r}`];if(o&&!e.tags.find(([s,i])=>s===n.slice(1)&&o.indexOf(i)!==-1))return!1}return!(t.since&&e.created_at<t.since||t.until&&e.created_at>t.until)}function os(t,e){for(let n=0;n<t.length;n++)if(rs(t[n],e))return!0;return!1}function ss(t,e){let n=e.length+3,r=t.indexOf(`"${e}":`)+n,o=t.slice(r).indexOf('"')+r+1;return t.slice(o,o+64)}function is(t){let e=t.slice(0,22).indexOf('"EVENT"');if(e===-1)return null;let n=t.slice(e+7+1).indexOf('"');if(n===-1)return null;let r=e+7+1+n,o=t.slice(r+1,80).indexOf('"');if(o===-1)return null;let s=r+1+o;return t.slice(r+1,s)}function cs(t,e){return{kind:ns,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t],["challenge",e]],content:""}}async function as(){return new Promise(t=>{const e=new MessageChannel,n=()=>{e.port1.removeEventListener("message",n),t()};e.port1.addEventListener("message",n),e.port2.postMessage(0),e.port1.start()})}var ls=t=>(t[Ae]=!0,!0),qn;try{qn=WebSocket}catch{}var Mn=class{constructor(e,n){g(this,"url");g(this,"_connected",!1);g(this,"onclose",null);g(this,"onnotice",e=>console.debug(`NOTICE from ${this.url}: ${e}`));g(this,"baseEoseTimeout",4400);g(this,"connectionTimeout",4400);g(this,"openSubs",new Map);g(this,"connectionTimeoutHandle");g(this,"connectionPromise");g(this,"openCountRequests",new Map);g(this,"openEventPublishes",new Map);g(this,"ws");g(this,"incomingMessageQueue",new Qo);g(this,"queueRunning",!1);g(this,"challenge");g(this,"serial",0);g(this,"verifyEvent");this.url=De(e),this.verifyEvent=n.verifyEvent}static async connect(e,n){const r=new Mn(e,n);return await r.connect(),r}closeAllSubscriptions(e){for(let[n,r]of this.openSubs)r.close(e);this.openSubs.clear();for(let[n,r]of this.openEventPublishes)r.reject(new Error(e));this.openEventPublishes.clear();for(let[n,r]of this.openCountRequests)r.reject(new Error(e));this.openCountRequests.clear()}get connected(){return this._connected}async connect(){return this.connectionPromise?this.connectionPromise:(this.challenge=void 0,this.connectionPromise=new Promise((e,n)=>{this.connectionTimeoutHandle=setTimeout(()=>{var r;n("connection timed out"),this.connectionPromise=void 0,(r=this.onclose)==null||r.call(this),this.closeAllSubscriptions("relay connection timed out")},this.connectionTimeout);try{this.ws=new qn(this.url)}catch(r){n(r);return}this.ws.onopen=()=>{clearTimeout(this.connectionTimeoutHandle),this._connected=!0,e()},this.ws.onerror=r=>{var o;n(r.message),this._connected&&((o=this.onclose)==null||o.call(this),this.closeAllSubscriptions("relay connection errored"),this._connected=!1)},this.ws.onclose=async()=>{var r;this.connectionPromise=void 0,(r=this.onclose)==null||r.call(this),this.closeAllSubscriptions("relay connection closed"),this._connected=!1},this.ws.onmessage=this._onmessage.bind(this)}),this.connectionPromise)}async runQueue(){for(this.queueRunning=!0;this.handleNext()!==!1;)await as();this.queueRunning=!1}handleNext(){var r,o;const e=this.incomingMessageQueue.dequeue();if(!e)return!1;const n=is(e);if(n){const s=this.openSubs.get(n);if(!s)return;const i=ss(e,"id"),c=(r=s.alreadyHaveEvent)==null?void 0:r.call(s,i);if((o=s.receivedEvent)==null||o.call(s,this,i),c)return}try{let s=JSON.parse(e);switch(s[0]){case"EVENT":{const i=this.openSubs.get(s[1]),c=s[2];this.verifyEvent(c)&&os(i.filters,c)&&i.onevent(c);return}case"COUNT":{const i=s[1],c=s[2],a=this.openCountRequests.get(i);a&&(a.resolve(c.count),this.openCountRequests.delete(i));return}case"EOSE":{const i=this.openSubs.get(s[1]);if(!i)return;i.receivedEose();return}case"OK":{const i=s[1],c=s[2],a=s[3],l=this.openEventPublishes.get(i);c?l.resolve(a):l.reject(new Error(a)),this.openEventPublishes.delete(i);return}case"CLOSED":{const i=s[1],c=this.openSubs.get(i);if(!c)return;c.closed=!0,c.close(s[2]);return}case"NOTICE":this.onnotice(s[1]);return;case"AUTH":{this.challenge=s[1];return}}}catch{return}}async send(e){if(!this.connectionPromise)throw new Error("sending on closed connection");this.connectionPromise.then(()=>{var n;(n=this.ws)==null||n.send(e)})}async auth(e){if(!this.challenge)throw new Error("can't perform auth, no challenge was received");const n=await e(cs(this.url,this.challenge)),r=new Promise((o,s)=>{this.openEventPublishes.set(n.id,{resolve:o,reject:s})});return this.send('["AUTH",'+JSON.stringify(n)+"]"),r}async publish(e){const n=new Promise((r,o)=>{this.openEventPublishes.set(e.id,{resolve:r,reject:o})});return this.send('["EVENT",'+JSON.stringify(e)+"]"),n}async count(e,n){this.serial++;const r=(n==null?void 0:n.id)||"count:"+this.serial,o=new Promise((s,i)=>{this.openCountRequests.set(r,{resolve:s,reject:i})});return this.send('["COUNT","'+r+'",'+JSON.stringify(e)+"]"),o}subscribe(e,n){const r=this.prepareSubscription(e,n);return r.fire(),r}prepareSubscription(e,n){this.serial++;const r=n.id||"sub:"+this.serial,o=new us(this,r,e,n);return this.openSubs.set(r,o),o}close(){var e;this.closeAllSubscriptions("relay connection closed by us"),this._connected=!1,(e=this.ws)==null||e.close()}_onmessage(e){this.incomingMessageQueue.enqueue(e.data),this.queueRunning||this.runQueue()}},us=class{constructor(e,n,r,o){g(this,"relay");g(this,"id");g(this,"closed",!1);g(this,"eosed",!1);g(this,"filters");g(this,"alreadyHaveEvent");g(this,"receivedEvent");g(this,"onevent");g(this,"oneose");g(this,"onclose");g(this,"eoseTimeout");g(this,"eoseTimeoutHandle");this.relay=e,this.filters=r,this.id=n,this.alreadyHaveEvent=o.alreadyHaveEvent,this.receivedEvent=o.receivedEvent,this.eoseTimeout=o.eoseTimeout||e.baseEoseTimeout,this.oneose=o.oneose,this.onclose=o.onclose,this.onevent=o.onevent||(s=>{console.warn(`onevent() callback not defined for subscription '${this.id}' in relay ${this.relay.url}. event received:`,s)})}fire(){this.relay.send('["REQ","'+this.id+'",'+JSON.stringify(this.filters).substring(1)),this.eoseTimeoutHandle=setTimeout(this.receivedEose.bind(this),this.eoseTimeout)}receivedEose(){var e;this.eosed||(clearTimeout(this.eoseTimeoutHandle),this.eosed=!0,(e=this.oneose)==null||e.call(this))}close(e="closed by caller"){var n;this.closed||(this.relay.send('["CLOSE",'+JSON.stringify(this.id)+"]"),this.closed=!0),this.relay.openSubs.delete(this.id),(n=this.onclose)==null||n.call(this,e)}},fs=class{constructor(e){g(this,"relays",new Map);g(this,"seenOn",new Map);g(this,"trackRelays",!1);g(this,"verifyEvent");g(this,"trustedRelayURLs",new Set);this.verifyEvent=e.verifyEvent}async ensureRelay(e,n){e=De(e);let r=this.relays.get(e);return r||(r=new Mn(e,{verifyEvent:this.trustedRelayURLs.has(e)?ls:this.verifyEvent}),n!=null&&n.connectionTimeout&&(r.connectionTimeout=n.connectionTimeout),this.relays.set(e,r)),await r.connect(),r}close(e){e.map(De).forEach(n=>{var r;(r=this.relays.get(n))==null||r.close()})}subscribeMany(e,n,r){this.trackRelays&&(r.receivedEvent=(y,p)=>{let w=this.seenOn.get(p);w||(w=new Set,this.seenOn.set(p,w)),w.add(y)});const o=new Set,s=[],i=[];let c=y=>{var p;i[y]=!0,i.filter(w=>w).length===e.length&&((p=r.oneose)==null||p.call(r),c=()=>{})};const a=[];let l=(y,p)=>{var w;c(y),a[y]=p,a.filter(d=>d).length===e.length&&((w=r.onclose)==null||w.call(r,a),l=()=>{})};const f=y=>{var w;if((w=r.alreadyHaveEvent)!=null&&w.call(r,y))return!0;const p=o.has(y);return o.add(y),p},u=Promise.all(e.map(De).map(async(y,p,w)=>{if(w.indexOf(y)!==p){l(p,"duplicate url");return}let d;try{d=await this.ensureRelay(y,{connectionTimeout:r.maxWait?Math.max(r.maxWait*.8,r.maxWait-1e3):void 0})}catch(b){l(p,(b==null?void 0:b.message)||String(b));return}let h=d.subscribe(n,{...r,oneose:()=>c(p),onclose:b=>l(p,b),alreadyHaveEvent:f,eoseTimeout:r.maxWait});s.push(h)}));return{async close(){await u,s.forEach(y=>{y.close()})}}}subscribeManyEose(e,n,r){const o=this.subscribeMany(e,n,{...r,oneose(){o.close()}});return o}async querySync(e,n,r){return new Promise(async o=>{const s=[];this.subscribeManyEose(e,[n],{...r,onevent(i){s.push(i)},onclose(i){o(s)}})})}async get(e,n,r){n.limit=1;const o=await this.querySync(e,n,r);return o.sort((s,i)=>i.created_at-s.created_at),o[0]||null}publish(e,n){return e.map(De).map(async(r,o,s)=>s.indexOf(r)!==o?Promise.reject("duplicate url"):(await this.ensureRelay(r)).publish(n))}},ds=class extends fs{constructor(){super({verifyEvent:ts})}};/*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */function Re(t){if(!Number.isSafeInteger(t))throw new Error(`Wrong integer: ${t}`)}function ie(...t){const e=(o,s)=>i=>o(s(i)),n=Array.from(t).reverse().reduce((o,s)=>o?e(o,s.encode):s.encode,void 0),r=t.reduce((o,s)=>o?e(o,s.decode):s.decode,void 0);return{encode:n,decode:r}}function ce(t){return{encode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="number")throw new Error("alphabet.encode input should be an array of numbers");return e.map(n=>{if(Re(n),n<0||n>=t.length)throw new Error(`Digit index outside alphabet: ${n} (alphabet: ${t.length})`);return t[n]})},decode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="string")throw new Error("alphabet.decode input should be array of strings");return e.map(n=>{if(typeof n!="string")throw new Error(`alphabet.decode: not string element=${n}`);const r=t.indexOf(n);if(r===-1)throw new Error(`Unknown letter: "${n}". Allowed: ${t}`);return r})}}}function ae(t=""){if(typeof t!="string")throw new Error("join separator should be string");return{encode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="string")throw new Error("join.encode input should be array of strings");for(let n of e)if(typeof n!="string")throw new Error(`join.encode: non-string input=${n}`);return e.join(t)},decode:e=>{if(typeof e!="string")throw new Error("join.decode input should be string");return e.split(t)}}}function ut(t,e="="){if(Re(t),typeof e!="string")throw new Error("padding chr should be string");return{encode(n){if(!Array.isArray(n)||n.length&&typeof n[0]!="string")throw new Error("padding.encode input should be array of strings");for(let r of n)if(typeof r!="string")throw new Error(`padding.encode: non-string input=${r}`);for(;n.length*t%8;)n.push(e);return n},decode(n){if(!Array.isArray(n)||n.length&&typeof n[0]!="string")throw new Error("padding.encode input should be array of strings");for(let o of n)if(typeof o!="string")throw new Error(`padding.decode: non-string input=${o}`);let r=n.length;if(r*t%8)throw new Error("Invalid padding: string should have whole number of bytes");for(;r>0&&n[r-1]===e;r--)if(!((r-1)*t%8))throw new Error("Invalid padding: string has too much padding");return n.slice(0,r)}}}function Kn(t){if(typeof t!="function")throw new Error("normalize fn should be function");return{encode:e=>e,decode:e=>t(e)}}function jn(t,e,n){if(e<2)throw new Error(`convertRadix: wrong from=${e}, base cannot be less than 2`);if(n<2)throw new Error(`convertRadix: wrong to=${n}, base cannot be less than 2`);if(!Array.isArray(t))throw new Error("convertRadix: data should be array");if(!t.length)return[];let r=0;const o=[],s=Array.from(t);for(s.forEach(i=>{if(Re(i),i<0||i>=e)throw new Error(`Wrong integer: ${i}`)});;){let i=0,c=!0;for(let a=r;a<s.length;a++){const l=s[a],f=e*i+l;if(!Number.isSafeInteger(f)||e*i/e!==i||f-l!==e*i)throw new Error("convertRadix: carry overflow");if(i=f%n,s[a]=Math.floor(f/n),!Number.isSafeInteger(s[a])||s[a]*n+i!==f)throw new Error("convertRadix: carry overflow");if(c)s[a]?c=!1:r=a;else continue}if(o.push(i),c)break}for(let i=0;i<t.length-1&&t[i]===0;i++)o.push(0);return o.reverse()}const zn=(t,e)=>e?zn(e,t%e):t,ft=(t,e)=>t+(e-zn(t,e));function Vt(t,e,n,r){if(!Array.isArray(t))throw new Error("convertRadix2: data should be array");if(e<=0||e>32)throw new Error(`convertRadix2: wrong from=${e}`);if(n<=0||n>32)throw new Error(`convertRadix2: wrong to=${n}`);if(ft(e,n)>32)throw new Error(`convertRadix2: carry overflow from=${e} to=${n} carryBits=${ft(e,n)}`);let o=0,s=0;const i=2**n-1,c=[];for(const a of t){if(Re(a),a>=2**e)throw new Error(`convertRadix2: invalid data word=${a} from=${e}`);if(o=o<<e|a,s+e>32)throw new Error(`convertRadix2: carry overflow pos=${s} from=${e}`);for(s+=e;s>=n;s-=n)c.push((o>>s-n&i)>>>0);o&=2**s-1}if(o=o<<n-s&i,!r&&s>=e)throw new Error("Excess padding");if(!r&&o)throw new Error(`Non-zero padding: ${o}`);return r&&s>0&&c.push(o>>>0),c}function hs(t){return Re(t),{encode:e=>{if(!(e instanceof Uint8Array))throw new Error("radix.encode input should be Uint8Array");return jn(Array.from(e),2**8,t)},decode:e=>{if(!Array.isArray(e)||e.length&&typeof e[0]!="number")throw new Error("radix.decode input should be array of strings");return Uint8Array.from(jn(e,t,2**8))}}}function ge(t,e=!1){if(Re(t),t<=0||t>32)throw new Error("radix2: bits should be in (0..32]");if(ft(8,t)>32||ft(t,8)>32)throw new Error("radix2: carry overflow");return{encode:n=>{if(!(n instanceof Uint8Array))throw new Error("radix2.encode input should be Uint8Array");return Vt(Array.from(n),8,t,!e)},decode:n=>{if(!Array.isArray(n)||n.length&&typeof n[0]!="number")throw new Error("radix2.decode input should be array of strings");return Uint8Array.from(Vt(n,t,8,e))}}}function Vn(t){if(typeof t!="function")throw new Error("unsafeWrapper fn should be function");return function(...e){try{return t.apply(null,e)}catch{}}}const ws=ie(ge(4),ce("0123456789ABCDEF"),ae("")),ps=ie(ge(5),ce("ABCDEFGHIJKLMNOPQRSTUVWXYZ234567"),ut(5),ae(""));ie(ge(5),ce("0123456789ABCDEFGHIJKLMNOPQRSTUV"),ut(5),ae("")),ie(ge(5),ce("0123456789ABCDEFGHJKMNPQRSTVWXYZ"),ae(""),Kn(t=>t.toUpperCase().replace(/O/g,"0").replace(/[IL]/g,"1")));const We=ie(ge(6),ce("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"),ut(6),ae("")),ys=ie(ge(6),ce("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"),ut(6),ae("")),Dt=t=>ie(hs(58),ce(t),ae("")),Wt=Dt("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz");Dt("123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"),Dt("rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz");const Dn=[0,2,3,5,6,7,9,10,11],gs={encode(t){let e="";for(let n=0;n<t.length;n+=8){const r=t.subarray(n,n+8);e+=Wt.encode(r).padStart(Dn[r.length],"1")}return e},decode(t){let e=[];for(let n=0;n<t.length;n+=11){const r=t.slice(n,n+11),o=Dn.indexOf(r.length),s=Wt.decode(r);for(let i=0;i<s.length-o;i++)if(s[i]!==0)throw new Error("base58xmr: wrong padding");e=e.concat(Array.from(s.slice(s.length-o)))}return Uint8Array.from(e)}},Ft=ie(ce("qpzry9x8gf2tvdw0s3jn54khce6mua7l"),ae("")),Wn=[996825010,642813549,513874426,1027748829,705979059];function Fe(t){const e=t>>25;let n=(t&33554431)<<5;for(let r=0;r<Wn.length;r++)(e>>r&1)===1&&(n^=Wn[r]);return n}function Fn(t,e,n=1){const r=t.length;let o=1;for(let s=0;s<r;s++){const i=t.charCodeAt(s);if(i<33||i>126)throw new Error(`Invalid prefix (${t})`);o=Fe(o)^i>>5}o=Fe(o);for(let s=0;s<r;s++)o=Fe(o)^t.charCodeAt(s)&31;for(let s of e)o=Fe(o)^s;for(let s=0;s<6;s++)o=Fe(o);return o^=n,Ft.encode(Vt([o%2**30],30,5,!1))}function Gn(t){const e=t==="bech32"?1:734539939,n=ge(5),r=n.decode,o=n.encode,s=Vn(r);function i(f,u,y=90){if(typeof f!="string")throw new Error(`bech32.encode prefix should be string, not ${typeof f}`);if(!Array.isArray(u)||u.length&&typeof u[0]!="number")throw new Error(`bech32.encode words should be array of numbers, not ${typeof u}`);const p=f.length+7+u.length;if(y!==!1&&p>y)throw new TypeError(`Length ${p} exceeds limit ${y}`);return f=f.toLowerCase(),`${f}1${Ft.encode(u)}${Fn(f,u,e)}`}function c(f,u=90){if(typeof f!="string")throw new Error(`bech32.decode input should be string, not ${typeof f}`);if(f.length<8||u!==!1&&f.length>u)throw new TypeError(`Wrong string length: ${f.length} (${f}). Expected (8..${u})`);const y=f.toLowerCase();if(f!==y&&f!==f.toUpperCase())throw new Error("String must be lowercase or uppercase");f=y;const p=f.lastIndexOf("1");if(p===0||p===-1)throw new Error('Letter "1" must be present between prefix and data only');const w=f.slice(0,p),d=f.slice(p+1);if(d.length<6)throw new Error("Data must be at least 6 characters long");const h=Ft.decode(d).slice(0,-6),b=Fn(w,h,e);if(!d.endsWith(b))throw new Error(`Invalid checksum in ${f}: expected "${b}"`);return{prefix:w,words:h}}const a=Vn(c);function l(f){const{prefix:u,words:y}=c(f,!1);return{prefix:u,words:y,bytes:r(y)}}return{encode:i,decode:c,decodeToBytes:l,decodeUnsafe:a,fromWords:r,fromWordsUnsafe:s,toWords:o}}const Zn=Gn("bech32");Gn("bech32m");const bs={encode:t=>new TextDecoder().decode(t),decode:t=>new TextEncoder().encode(t)},ms=ie(ge(4),ce("0123456789abcdef"),ae(""),Kn(t=>{if(typeof t!="string"||t.length%2)throw new TypeError(`hex.decode: expected string, got ${typeof t} with length ${t.length}`);return t.toLowerCase()}));`${Object.keys({utf8:bs,hex:ms,base16:ws,base32:ps,base64:We,base64url:ys,base58:Wt,base58xmr:gs}).join(", ")}`;var ke=Symbol("verified"),xs=t=>t instanceof Object;function Es(t){if(!xs(t)||typeof t.kind!="number"||typeof t.content!="string"||typeof t.created_at!="number"||typeof t.pubkey!="string"||!t.pubkey.match(/^[a-f0-9]{64}$/)||!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){let n=t.tags[e];if(!Array.isArray(n))return!1;for(let r=0;r<n.length;r++)if(typeof n[r]=="object")return!1}return!0}var vs=new TextDecoder("utf-8"),Jn=new TextEncoder;function Ge(t){t.indexOf("://")===-1&&(t="wss://"+t);let e=new URL(t);return e.pathname=e.pathname.replace(/\/+/g,"/"),e.pathname.endsWith("/")&&(e.pathname=e.pathname.slice(0,-1)),(e.port==="80"&&e.protocol==="ws:"||e.port==="443"&&e.protocol==="wss:")&&(e.port=""),e.searchParams.sort(),e.hash="",e.toString()}var _s=class{constructor(t){g(this,"value");g(this,"next",null);g(this,"prev",null);this.value=t}},Ss=class{constructor(){g(this,"first");g(this,"last");this.first=null,this.last=null}enqueue(t){const e=new _s(t);return this.last?this.last===this.first?(this.last=e,this.last.prev=this.first,this.first.next=e):(e.prev=this.last,this.last.next=e,this.last=e):(this.first=e,this.last=e),!0}dequeue(){if(!this.first)return null;if(this.first===this.last){const e=this.first;return this.first=null,this.last=null,e.value}const t=this.first;return this.first=t.next,t.value}},As=class{generateSecretKey(){return W.utils.randomPrivateKey()}getPublicKey(t){return D(W.getPublicKey(t))}finalizeEvent(t,e){const n=t;return n.pubkey=D(W.getPublicKey(e)),n.id=Gt(n),n.sig=D(W.sign(Gt(n),e)),n[ke]=!0,n}verifyEvent(t){if(typeof t[ke]=="boolean")return t[ke];const e=Gt(t);if(e!==t.id)return t[ke]=!1,!1;try{const n=W.verify(t.sig,e,t.pubkey);return t[ke]=n,n}catch{return t[ke]=!1,!1}}};function ks(t){if(!Es(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function Gt(t){let e=Kt(Jn.encode(ks(t)));return D(e)}var dt=new As,Bs=dt.generateSecretKey,Yn=dt.getPublicKey,$s=dt.finalizeEvent,Qn=dt.verifyEvent;typeof crypto<"u"&&!crypto.subtle&&crypto.webcrypto&&(crypto.subtle=crypto.webcrypto.subtle);async function Os(t,e,n){const r=t instanceof Uint8Array?D(t):t,o=ze.getSharedSecret(r,"02"+e),s=Xn(o);let i=Uint8Array.from(qr(16)),c=Jn.encode(n),a=await crypto.subtle.importKey("raw",s,{name:"AES-CBC"},!1,["encrypt"]),l=await crypto.subtle.encrypt({name:"AES-CBC",iv:i},a,c),f=We.encode(new Uint8Array(l)),u=We.encode(new Uint8Array(i.buffer));return`${f}?iv=${u}`}async function Is(t,e,n){const r=t instanceof Uint8Array?D(t):t;let[o,s]=n.split("?iv="),i=ze.getSharedSecret(r,"02"+e),c=Xn(i),a=await crypto.subtle.importKey("raw",c,{name:"AES-CBC"},!1,["decrypt"]),l=We.decode(o),f=We.decode(s),u=await crypto.subtle.decrypt({name:"AES-CBC",iv:f},a,l);return vs.decode(u)}function Xn(t){return t.slice(1,33)}var Ns=/^(?:([\w.+-]+)@)?([\w_-]+(\.[\w_-]+)+)$/,Ts;try{Ts=fetch}catch{}var Cs=22242,Zt=24133,Ps=31990;function Rs(t,e){if(t.ids&&t.ids.indexOf(e.id)===-1&&!t.ids.some(n=>e.id.startsWith(n))||t.kinds&&t.kinds.indexOf(e.kind)===-1||t.authors&&t.authors.indexOf(e.pubkey)===-1&&!t.authors.some(n=>e.pubkey.startsWith(n)))return!1;for(let n in t)if(n[0]==="#"){let r=n.slice(1),o=t[`#${r}`];if(o&&!e.tags.find(([s,i])=>s===n.slice(1)&&o.indexOf(i)!==-1))return!1}return!(t.since&&e.created_at<t.since||t.until&&e.created_at>t.until)}function Us(t,e){for(let n=0;n<t.length;n++)if(Rs(t[n],e))return!0;return!1}function Hs(t,e){let n=e.length+3,r=t.indexOf(`"${e}":`)+n,o=t.slice(r).indexOf('"')+r+1;return t.slice(o,o+64)}function Ls(t){let e=t.slice(0,22).indexOf('"EVENT"');if(e===-1)return null;let n=t.slice(e+7+1).indexOf('"');if(n===-1)return null;let r=e+7+1+n,o=t.slice(r+1,80).indexOf('"');if(o===-1)return null;let s=r+1+o;return t.slice(r+1,s)}function qs(t,e){return{kind:Cs,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t],["challenge",e]],content:""}}async function Ms(){return new Promise(t=>{const e=new MessageChannel,n=()=>{e.port1.removeEventListener("message",n),t()};e.port1.addEventListener("message",n),e.port2.postMessage(0),e.port1.start()})}var Ks=t=>(t[ke]=!0,!0),er;try{er=WebSocket}catch{}var tr=class{constructor(t,e){g(this,"url");g(this,"_connected",!1);g(this,"onclose",null);g(this,"onnotice",t=>console.debug(`NOTICE from ${this.url}: ${t}`));g(this,"baseEoseTimeout",4400);g(this,"connectionTimeout",4400);g(this,"openSubs",new Map);g(this,"connectionTimeoutHandle");g(this,"connectionPromise");g(this,"openCountRequests",new Map);g(this,"openEventPublishes",new Map);g(this,"ws");g(this,"incomingMessageQueue",new Ss);g(this,"queueRunning",!1);g(this,"challenge");g(this,"serial",0);g(this,"verifyEvent");this.url=Ge(t),this.verifyEvent=e.verifyEvent}static async connect(t,e){const n=new tr(t,e);return await n.connect(),n}closeAllSubscriptions(t){for(let[e,n]of this.openSubs)n.close(t);this.openSubs.clear();for(let[e,n]of this.openEventPublishes)n.reject(new Error(t));this.openEventPublishes.clear();for(let[e,n]of this.openCountRequests)n.reject(new Error(t));this.openCountRequests.clear()}get connected(){return this._connected}async connect(){return this.connectionPromise?this.connectionPromise:(this.challenge=void 0,this.connectionPromise=new Promise((t,e)=>{this.connectionTimeoutHandle=setTimeout(()=>{var n;e("connection timed out"),this.connectionPromise=void 0,(n=this.onclose)==null||n.call(this),this.closeAllSubscriptions("relay connection timed out")},this.connectionTimeout);try{this.ws=new er(this.url)}catch(n){e(n);return}this.ws.onopen=()=>{clearTimeout(this.connectionTimeoutHandle),this._connected=!0,t()},this.ws.onerror=n=>{var r;e(n.message),this._connected&&((r=this.onclose)==null||r.call(this),this.closeAllSubscriptions("relay connection errored"),this._connected=!1)},this.ws.onclose=async()=>{var n;this.connectionPromise=void 0,(n=this.onclose)==null||n.call(this),this.closeAllSubscriptions("relay connection closed"),this._connected=!1},this.ws.onmessage=this._onmessage.bind(this)}),this.connectionPromise)}async runQueue(){for(this.queueRunning=!0;this.handleNext()!==!1;)await Ms();this.queueRunning=!1}handleNext(){var n,r;const t=this.incomingMessageQueue.dequeue();if(!t)return!1;const e=Ls(t);if(e){const o=this.openSubs.get(e);if(!o)return;const s=Hs(t,"id"),i=(n=o.alreadyHaveEvent)==null?void 0:n.call(o,s);if((r=o.receivedEvent)==null||r.call(o,this,s),i)return}try{let o=JSON.parse(t);switch(o[0]){case"EVENT":{const s=this.openSubs.get(o[1]),i=o[2];this.verifyEvent(i)&&Us(s.filters,i)&&s.onevent(i);return}case"COUNT":{const s=o[1],i=o[2],c=this.openCountRequests.get(s);c&&(c.resolve(i.count),this.openCountRequests.delete(s));return}case"EOSE":{const s=this.openSubs.get(o[1]);if(!s)return;s.receivedEose();return}case"OK":{const s=o[1],i=o[2],c=o[3],a=this.openEventPublishes.get(s);i?a.resolve(c):a.reject(new Error(c)),this.openEventPublishes.delete(s);return}case"CLOSED":{const s=o[1],i=this.openSubs.get(s);if(!i)return;i.closed=!0,i.close(o[2]);return}case"NOTICE":this.onnotice(o[1]);return;case"AUTH":{this.challenge=o[1];return}}}catch{return}}async send(t){if(!this.connectionPromise)throw new Error("sending on closed connection");this.connectionPromise.then(()=>{var e;(e=this.ws)==null||e.send(t)})}async auth(t){if(!this.challenge)throw new Error("can't perform auth, no challenge was received");const e=await t(qs(this.url,this.challenge)),n=new Promise((r,o)=>{this.openEventPublishes.set(e.id,{resolve:r,reject:o})});return this.send('["AUTH",'+JSON.stringify(e)+"]"),n}async publish(t){const e=new Promise((n,r)=>{this.openEventPublishes.set(t.id,{resolve:n,reject:r})});return this.send('["EVENT",'+JSON.stringify(t)+"]"),e}async count(t,e){this.serial++;const n=(e==null?void 0:e.id)||"count:"+this.serial,r=new Promise((o,s)=>{this.openCountRequests.set(n,{resolve:o,reject:s})});return this.send('["COUNT","'+n+'",'+JSON.stringify(t)+"]"),r}subscribe(t,e){const n=this.prepareSubscription(t,e);return n.fire(),n}prepareSubscription(t,e){this.serial++;const n=e.id||"sub:"+this.serial,r=new js(this,n,t,e);return this.openSubs.set(n,r),r}close(){var t;this.closeAllSubscriptions("relay connection closed by us"),this._connected=!1,(t=this.ws)==null||t.close()}_onmessage(t){this.incomingMessageQueue.enqueue(t.data),this.queueRunning||this.runQueue()}},js=class{constructor(t,e,n,r){g(this,"relay");g(this,"id");g(this,"closed",!1);g(this,"eosed",!1);g(this,"filters");g(this,"alreadyHaveEvent");g(this,"receivedEvent");g(this,"onevent");g(this,"oneose");g(this,"onclose");g(this,"eoseTimeout");g(this,"eoseTimeoutHandle");this.relay=t,this.filters=n,this.id=e,this.alreadyHaveEvent=r.alreadyHaveEvent,this.receivedEvent=r.receivedEvent,this.eoseTimeout=r.eoseTimeout||t.baseEoseTimeout,this.oneose=r.oneose,this.onclose=r.onclose,this.onevent=r.onevent||(o=>{console.warn(`onevent() callback not defined for subscription '${this.id}' in relay ${this.relay.url}. event received:`,o)})}fire(){this.relay.send('["REQ","'+this.id+'",'+JSON.stringify(this.filters).substring(1)),this.eoseTimeoutHandle=setTimeout(this.receivedEose.bind(this),this.eoseTimeout)}receivedEose(){var t;this.eosed||(clearTimeout(this.eoseTimeoutHandle),this.eosed=!0,(t=this.oneose)==null||t.call(this))}close(t="closed by caller"){var e;this.closed||(this.relay.send('["CLOSE",'+JSON.stringify(this.id)+"]"),this.closed=!0),this.relay.openSubs.delete(this.id),(e=this.onclose)==null||e.call(this,t)}},zs=class{constructor(t){g(this,"relays",new Map);g(this,"seenOn",new Map);g(this,"trackRelays",!1);g(this,"verifyEvent");g(this,"trustedRelayURLs",new Set);this.verifyEvent=t.verifyEvent}async ensureRelay(t,e){t=Ge(t);let n=this.relays.get(t);return n||(n=new tr(t,{verifyEvent:this.trustedRelayURLs.has(t)?Ks:this.verifyEvent}),e!=null&&e.connectionTimeout&&(n.connectionTimeout=e.connectionTimeout),this.relays.set(t,n)),await n.connect(),n}close(t){t.map(Ge).forEach(e=>{var n;(n=this.relays.get(e))==null||n.close()})}subscribeMany(t,e,n){this.trackRelays&&(n.receivedEvent=(u,y)=>{let p=this.seenOn.get(y);p||(p=new Set,this.seenOn.set(y,p)),p.add(u)});const r=new Set,o=[],s=[];let i=u=>{var y;s[u]=!0,s.filter(p=>p).length===t.length&&((y=n.oneose)==null||y.call(n),i=()=>{})};const c=[];let a=(u,y)=>{var p;i(u),c[u]=y,c.filter(w=>w).length===t.length&&((p=n.onclose)==null||p.call(n,c),a=()=>{})};const l=u=>{var p;if((p=n.alreadyHaveEvent)!=null&&p.call(n,u))return!0;const y=r.has(u);return r.add(u),y},f=Promise.all(t.map(Ge).map(async(u,y,p)=>{if(p.indexOf(u)!==y){a(y,"duplicate url");return}let w;try{w=await this.ensureRelay(u,{connectionTimeout:n.maxWait?Math.max(n.maxWait*.8,n.maxWait-1e3):void 0})}catch(h){a(y,(h==null?void 0:h.message)||String(h));return}let d=w.subscribe(e,{...n,oneose:()=>i(y),onclose:h=>a(y,h),alreadyHaveEvent:l,eoseTimeout:n.maxWait});o.push(d)}));return{async close(){await f,o.forEach(u=>{u.close()})}}}subscribeManyEose(t,e,n){const r=this.subscribeMany(t,e,{...n,oneose(){r.close()}});return r}async querySync(t,e,n){return new Promise(async r=>{const o=[];this.subscribeManyEose(t,[e],{...n,onevent(s){o.push(s)},onclose(s){r(o)}})})}async get(t,e,n){e.limit=1;const r=await this.querySync(t,e,n);return r.sort((o,s)=>s.created_at-o.created_at),r[0]||null}publish(t,e){return t.map(Ge).map(async(n,r,o)=>o.indexOf(n)!==r?Promise.reject("duplicate url"):(await this.ensureRelay(n)).publish(e))}},Vs=class extends zs{constructor(){super({verifyEvent:Qn})}},nr;try{nr=fetch}catch{}var Ds=/^bunker:\/\/([0-9a-f]{64})\??([?\/\w:.=&%]*)$/,Ws=/^[^\s@]+@[^\s@]+\.[^\s@]+$/;async function Fs(t){let e=t.match(Ds);if(e)try{const n=e[1],r=new URLSearchParams(e[2]);return{pubkey:n,relays:r.getAll("relay"),secret:r.get("secret")}}catch{}return rr(t)}async function rr(t){const e=t.match(Ns);if(!e)return null;const[n,r="_",o]=e;try{const s=`https://${o}/.well-known/nostr.json?name=${r}`,i=await(await nr(s,{redirect:"error"})).json();let c=i.names[r],a=i.nip46[c]||[];return{pubkey:c,relays:a,secret:null}}catch{return null}}var Jt=class{constructor(t,e,n={}){g(this,"pool");g(this,"subCloser");g(this,"isOpen");g(this,"serial");g(this,"idPrefix");g(this,"listeners");g(this,"waitingForAuth");g(this,"secretKey");g(this,"bp");if(e.relays.length===0)throw new Error("no relays are specified for this bunker");this.pool=n.pool||new Vs,this.secretKey=t,this.bp=e,this.isOpen=!1,this.idPrefix=Math.random().toString(36).substring(7),this.serial=0,this.listeners={},this.waitingForAuth={};const r=this.listeners,o=this.waitingForAuth;this.subCloser=this.pool.subscribeMany(this.bp.relays,[{kinds:[Zt],"#p":[Yn(this.secretKey)]}],{async onevent(s){const{id:i,result:c,error:a}=JSON.parse(await Is(t,s.pubkey,s.content));if(c==="auth_url"&&o[i]){delete r[i],n.onauth?n.onauth(a):console.warn(`nostr-tools/nip46: remote signer ${e.pubkey} tried to send an "auth_url"='${a}' but there was no onauth() callback configured.`);return}let l=r[i];l&&(a?l.reject(a):c&&l.resolve(c),delete r[i])}}),this.isOpen=!0}async close(){this.isOpen=!1,this.subCloser.close()}async sendRequest(t,e){return new Promise(async(n,r)=>{try{if(!this.isOpen)throw new Error("this signer is not open anymore, create a new one");this.serial++;const o=`${this.idPrefix}-${this.serial}`,s=await Os(this.secretKey,this.bp.pubkey,JSON.stringify({id:o,method:t,params:e})),i=$s({kind:Zt,tags:[["p",this.bp.pubkey]],content:s,created_at:Math.floor(Date.now()/1e3)},this.secretKey);this.listeners[o]={resolve:n,reject:r},this.waitingForAuth[o]=!0,await Promise.any(this.pool.publish(this.bp.relays,i))}catch(o){r(o)}})}async ping(){let t=await this.sendRequest("ping",[]);if(t!=="pong")throw new Error(`result is not pong: ${t}`)}async connect(){await this.sendRequest("connect",[Yn(this.secretKey),this.bp.secret||""])}async getPublicKey(){return this.bp.pubkey}async getRelays(){return JSON.parse(await this.sendRequest("get_relays",[]))}async signEvent(t){let e=await this.sendRequest("sign_event",[JSON.stringify(t)]),n=JSON.parse(e);if(n.pubkey===this.bp.pubkey&&Qn(n))return n;throw new Error(`event returned from bunker is improperly signed: ${JSON.stringify(n)}`)}async nip04Encrypt(t,e){return await this.sendRequest("nip04_encrypt",[t,e])}async nip04Decrypt(t,e){return await this.sendRequest("nip04_decrypt",[t,e])}async nip44GetKey(t){let e=await this.sendRequest("nip44_get_key",[t]);return xt(e)}async nip44Encrypt(t,e){return await this.sendRequest("nip44_encrypt",[t,e])}async nip44Decrypt(t,e){return await this.sendRequest("nip44_encrypt",[t,e])}};async function Gs(t,e,n,r,o){if(o&&!Ws.test(o))throw new Error("Invalid email");let s=Bs(),i=new Jt(s,t.bunkerPointer,e),c=await i.sendRequest("create_account",[n,r,o||""]);return i.bp.pubkey=c,await i.connect(),i}async function Zs(t,e){const n=await t.querySync(e,{kinds:[Ps],"#k":[Zt.toString()]});return(await Promise.all(n.map(async o=>{try{const s=JSON.parse(o.content),i=await rr(s.nip05);if(i&&i.pubkey===o.pubkey&&i.relays.length)return{bunkerPointer:i,nip05:s.nip05,domain:s.nip05.split("@")[1],name:s.name||s.display_name,picture:s.picture,about:s.about,website:s.website,local:!1}}catch{return}}))).filter(o=>o!==void 0)}var Js=/^(?:([\w.+-]+)@)?([\w_-]+(\.[\w_-]+)+)$/,or;try{or=fetch}catch{}async function Ys(t){var s;const e=t.match(Js);if(!e)return null;const[n,r="_",o]=e;try{const i=`https://${o}/.well-known/nostr.json?name=${r}`,c=await(await or(i,{redirect:"error"})).json();let a=c.names[r];return a?{pubkey:a,relays:(s=c.relays)==null?void 0:s[a]}:null}catch{return null}}new TextDecoder("utf-8"),new TextEncoder;var Qs=5e3;function Xs(t){return ti("npub",xt(t))}function ei(t,e){let n=Zn.toWords(e);return Zn.encode(t,n,Qs)}function ti(t,e){return ei(t,e)}const{window:ni}=pr;function sr(t,e,n){const r=t.slice();return r[30]=e[n],r}function ri(t){let e,n,r,o,s;function i(l,f){if(l[5])return ci;if(!l[6])return ii;if(l[6])return si}let c=i(t),a=c&&c(t);return{c(){e=C("div"),n=C("button"),n.textContent="⤫",r=Y(),a&&a.c(),k(n,"class","tw-absolute tw-top-0 tw-right-0.5 tw-bg-transparent tw-border-none tw-cursor-pointer tw-text-cyan-950 tw-text-3xl"),k(e,"class","tw-w-80 tw-px-6 tw-py-8 tw-transition-all tw-bg-cyan-700 tw-rounded-md tw-shadow-[0_0px_30px_0px_rgba(0,0,0,0.6)]")},m(l,f){H(l,e,f),R(e,n),R(e,r),a&&a.m(e,null),o||(s=fe(n,"click",t[9]),o=!0)},p(l,f){c===(c=i(l))&&a?a.p(l,f):(a&&a.d(1),a=c&&c(l),a&&(a.c(),a.m(e,null)))},d(l){l&&U(e),a&&a.d(),o=!1,s()}}}function oi(t){let e;function n(s,i){return s[4]?ui:s[6]?ai:li}let r=n(t),o=r(t);return{c(){e=C("div"),o.c(),k(e,"class","tw-px-4 tw-py-2 tw-transition-all tw-bg-cyan-700 hover:tw-bg-cyan-800 tw-rounded tw-cursor-pointer tw-shadow-[0_0px_10px_0px_rgba(0,0,0,0.3)]")},m(s,i){H(s,e,i),o.m(e,null)},p(s,i){r===(r=n(s))&&o?o.p(s,i):(o.d(1),o=r(s),o&&(o.c(),o.m(e,null)))},d(s){s&&U(e),o.d()}}}function si(t){let e,n,r,o,s,i,c=t[6].npub+"",a,l,f,u,y,p,w=(t[6].picture||t[6].name)&&ir(t);return{c(){e=C("div"),n=C("div"),n.textContent="You are connected to Nostr as",r=Y(),o=C("a"),w&&w.c(),s=Y(),i=C("div"),a=Ee(c),f=Y(),u=C("button"),u.textContent="Disconnect",k(n,"class","tw-text-xs tw-mb-4"),k(i,"class","tw-block tw-break-all"),k(o,"target","_blank"),k(o,"href",l="https://nosta.me/"+t[6].npub),k(o,"class","tw-text-white tw-no-underline tw-group"),k(e,"class","tw-text-center"),k(u,"class","tw-block tw-w-full tw-my-2 tw-mt-6 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white")},m(d,h){H(d,e,h),R(e,n),R(e,r),R(e,o),w&&w.m(o,null),R(o,s),R(o,i),R(i,a),H(d,f,h),H(d,u,h),y||(p=fe(u,"click",t[11]),y=!0)},p(d,h){d[6].picture||d[6].name?w?w.p(d,h):(w=ir(d),w.c(),w.m(o,s)):w&&(w.d(1),w=null),h[0]&64&&c!==(c=d[6].npub+"")&&wt(a,c),h[0]&64&&l!==(l="https://nosta.me/"+d[6].npub)&&k(o,"href",l)},d(d){d&&(U(e),U(f),U(u)),w&&w.d(),y=!1,p()}}}function ii(t){let e,n,r,o,s,i,c,a,l,f,u,y;return{c(){e=C("div"),e.textContent="How do you want to connect to Nostr?",n=Y(),r=C("form"),o=C("input"),s=Y(),i=C("button"),i.textContent="Connect »",c=Y(),a=C("div"),l=Ee(`Do you need a Nostr account?
3
+ `),f=C("button"),f.textContent="Get one now for free",k(e,"class","tw-text-lg tw-text-center"),k(o,"class","tw-box-border tw-w-full tw-px-2 tw-py-1 tw-rounded tw-text-lg tw-border-none tw-outline-none"),k(o,"placeholder","user@provider or bunker://..."),k(i,"class","tw-block tw-w-full tw-mt-4 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white"),k(r,"class","flex tw-mt-4 tw-mb-1"),k(f,"class","tw-border-0 tw-bg-transparent tw-text-white tw-cursor-pointer tw-underline tw-text-sm"),k(a,"class","tw-mt-6 tw-text-center tw-text-sm tw-leading-3")},m(p,w){H(p,e,w),H(p,n,w),H(p,r,w),R(r,o),t[17](o),R(r,s),R(r,i),H(p,c,w),H(p,a,w),R(a,l),R(a,f),u||(y=[fe(r,"submit",t[10]),fe(f,"click",t[12])],u=!0)},p:K,d(p){p&&(U(e),U(n),U(r),U(c),U(a)),t[17](null),u=!1,$e(y)}}}function ci(t){let e,n,r,o,s,i,c,a,l,f,u,y,p,w=sn(t[7]),d=[];for(let h=0;h<w.length;h+=1)d[h]=lr(sr(t,w,h));return{c(){e=C("div"),e.textContent="Create a new Nostr account",n=Y(),r=C("form"),o=C("div"),s=C("input"),i=Y(),c=C("div"),c.textContent="@",a=Y(),l=C("select");for(let h=0;h<d.length;h+=1)d[h].c();f=Y(),u=C("button"),u.textContent="create",k(e,"class","tw-text-lg tw-text-center"),k(s,"class","tw-box-border tw-w-full tw-px-2 tw-py-1 tw-rounded tw-text-lg tw-border-none tw-outline-none"),k(s,"placeholder","bob"),k(c,"class","tw-mx-2 tw-text-2xl"),k(l,"class","tw-w-full tw-box-border tw-px-2 tw-py-1 tw-rounded tw-text-lg tw-border-none tw-outline-none"),t[2]===void 0&&Xe(()=>t[16].call(l)),k(o,"class","tw-flex items-center"),k(u,"class","tw-block tw-w-full tw-mt-4 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white"),k(r,"class","tw-mt-4 tw-mb-1")},m(h,b){H(h,e,b),H(h,n,b),H(h,r,b),R(r,o),R(o,s),t[15](s),R(o,i),R(o,c),R(o,a),R(o,l);for(let E=0;E<d.length;E+=1)d[E]&&d[E].m(l,null);tn(l,t[2],!0),R(r,f),R(r,u),y||(p=[fe(s,"input",t[14]),fe(l,"change",t[16]),fe(r,"submit",t[13])],y=!0)},p(h,b){if(b[0]&128){w=sn(h[7]);let E;for(E=0;E<w.length;E+=1){const S=sr(h,w,E);d[E]?d[E].p(S,b):(d[E]=lr(S),d[E].c(),d[E].m(l,null))}for(;E<d.length;E+=1)d[E].d(1);d.length=w.length}b[0]&132&&tn(l,h[2])},d(h){h&&(U(e),U(n),U(r)),t[15](null),yr(d,h),y=!1,$e(p)}}}function ir(t){let e,n,r=t[6].picture&&cr(t),o=t[6].name&&ar(t);return{c(){e=C("div"),r&&r.c(),n=Y(),o&&o.c(),k(e,"class","tw-flex tw-items-center tw-justify-center tw-gap-2 tw-mb-2")},m(s,i){H(s,e,i),r&&r.m(e,null),R(e,n),o&&o.m(e,null)},p(s,i){s[6].picture?r?r.p(s,i):(r=cr(s),r.c(),r.m(e,n)):r&&(r.d(1),r=null),s[6].name?o?o.p(s,i):(o=ar(s),o.c(),o.m(e,null)):o&&(o.d(1),o=null)},d(s){s&&U(e),r&&r.d(),o&&o.d()}}}function cr(t){let e,n;return{c(){e=C("img"),Ye(e.src,n=t[6].picture)||k(e,"src",n),k(e,"alt",""),k(e,"class","tw-w-10 tw-h-10 tw-rounded-full tw-border-solid tw-border-2 tw-border-transparent group-hover:tw-border-cyan-100")},m(r,o){H(r,e,o)},p(r,o){o[0]&64&&!Ye(e.src,n=r[6].picture)&&k(e,"src",n)},d(r){r&&U(e)}}}function ar(t){let e,n=t[6].name+"",r;return{c(){e=C("div"),r=Ee(n),k(e,"class","tw-text-3xl group-hover:tw-underline tw-decoration-2 tw-underline-offset-4")},m(o,s){H(o,e,s),R(e,r)},p(o,s){s[0]&64&&n!==(n=o[6].name+"")&&wt(r,n)},d(o){o&&U(e)}}}function lr(t){let e,n,r;return{c(){e=C("option"),k(e,"label",n=t[30].domain),e.__value=r=t[30],en(e,e.__value),k(e,"class","tw-px-2 tw-py-1 tw-text-lg")},m(o,s){H(o,e,s)},p(o,s){s[0]&128&&n!==(n=o[30].domain)&&k(e,"label",n),s[0]&128&&r!==(r=o[30])&&(e.__value=r,en(e,e.__value))},d(o){o&&U(e)}}}function ai(t){let e,n,r=(t[6].name||t[6].npub.slice(0,7)+"…"+t[6].npub.slice(-4))+"",o;function s(a,l){return a[6].picture?di:fi}let i=s(t),c=i(t);return{c(){e=C("div"),c.c(),n=Y(),o=Ee(r),k(e,"class","tw-flex tw-items-center")},m(a,l){H(a,e,l),c.m(e,null),R(e,n),R(e,o)},p(a,l){i===(i=s(a))&&c?c.p(a,l):(c.d(1),c=i(a),c&&(c.c(),c.m(e,n))),l[0]&64&&r!==(r=(a[6].name||a[6].npub.slice(0,7)+"…"+a[6].npub.slice(-4))+"")&&wt(o,r)},d(a){a&&U(e),c.d()}}}function li(t){let e;return{c(){e=Ee("Login with Nostr")},m(n,r){H(n,e,r)},p:K,d(n){n&&U(e)}}}function ui(t){let e;return{c(){e=C("div"),e.textContent="Connecting to bunker..."},m(n,r){H(n,e,r)},p:K,d(n){n&&U(e)}}}function fi(t){let e;return{c(){e=Ee("☉")},m(n,r){H(n,e,r)},p:K,d(n){n&&U(e)}}}function di(t){let e,n;return{c(){e=C("img"),Ye(e.src,n=t[6].picture)||k(e,"src",n),k(e,"alt",""),k(e,"class","tw-w-5 tw-h-5 tw-rounded-full tw-mr-2")},m(r,o){H(r,e,o)},p(r,o){o[0]&64&&!Ye(e.src,n=r[6].picture)&&k(e,"src",n)},d(r){r&&U(e)}}}function hi(t){let e,n,r;function o(c,a){return c[3]?ri:oi}let s=o(t),i=s(t);return{c(){e=C("div"),i.c(),k(e,"class","tw-text-white tw-font-sans"),nn(e,"tw-cursor-pointer",!t[6]&&!t[3])},m(c,a){H(c,e,a),i.m(e,null),n||(r=fe(ni,"click",t[8]),n=!0)},p(c,a){s===(s=o(c))&&i?i.p(c,a):(i.d(1),i=s(c),i&&(i.c(),i.m(e,null))),a[0]&72&&nn(e,"tw-cursor-pointer",!c[6]&&!c[3])},i:K,o:K,d(c){c&&U(e),i.d(),n=!1,r()}}}function wi(t,e,n){const r=window,o=new ds;let s,i,c,a;const l=localStorage.getItem("nip46ClientSecretKey");l?a=xt(l):(a=Fo(),localStorage.setItem("nip46ClientSecretKey",D(a)));let f,u,y,p,w,d,h,b,E=[];I();let S={isWnj:!0,async getPublicKey(){return!w&&!h&&n(3,f=!0),(await p).bp.pubkey},async signEvent(x){return!w&&!h&&n(3,f=!0),(await p).signEvent(x)},async getRelays(){return!w&&!h&&n(3,f=!0),(await p).getRelays()},nip04:{async encrypt(x,B){return!w&&!h&&n(3,f=!0),(await p).nip04Encrypt(x,B)},async decrypt(x,B){return!w&&!h&&n(3,f=!0),(await p).nip04Decrypt(x,B)}}};function I(){n(3,f=!1),u=null,p=new Promise(x=>{y=x}),n(4,w=!1),n(5,d=!1),n(6,h=null),b=null}const $={pool:o,onauth(x){window.open(x,"window.nostr","width=600,height=800,popup=yes")}};xr(()=>{let x=localStorage.getItem("nip46BunkerPointer");if(x&&(u=JSON.parse(x),n(4,w=!0),z(new Jt(a,u,$))),r.nostr&&!r.nostr.isWnj){r.destroyWnj();return}else Object.defineProperty(window,"nostr",{get(){return S},set(B){S=B,B.isWnj||r.destroyWnj()},configurable:!0});return()=>{b&&b.close()}});function _(x){x.composedPath().find(B=>B.id==="windowNostrModal")?n(3,f=!0):n(3,f=!1)}function A(x){n(3,f=!1),n(5,d=!1),x.stopPropagation()}async function O(x){if(x.preventDefault(),u=await Fs(s.value),!u){s.setCustomValidity('invalid NIP-05 "name@domain.com" address or bunker:// URI');return}s.setCustomValidity(""),z(new Jt(a,u,$))}async function J(x){x.preventDefault(),localStorage.removeItem("nip46BunkerPointer"),r.isWnj&&delete r.nostr,I()}async function P(x){x.preventDefault(),n(5,d=!0),E.length===0&&n(7,E=await Zs(o,["wss://relay.nostr.band"]))}async function N(x){if(x.preventDefault(),!c)return;let B=await Gs(c,$,i.value,c.domain);n(3,f=!0),n(5,d=!1),z(B)}const F=Rr(async()=>{c&&i.value.length>0&&(await Ys(i.value+"@"+c.domain)?i.setCustomValidity(`'${i.value}' is already taken.`):i.setCustomValidity(""))},500);async function z(x){await x.connect(),n(6,h={pubkey:x.bp.pubkey,npub:Xs(x.bp.pubkey),event:null}),n(4,w=!1),localStorage.setItem("nip46BunkerPointer",JSON.stringify(u)),b=o.subscribeMany(["wss://purplepag.es","wss://relay.snort.social","wss://relay.nos.social"],[{kinds:[0],authors:[x.bp.pubkey]}],{onevent(B){var T;if(!((((T=h.event)==null?void 0:T.created_at)||0)>=B.created_at))try{let{name:q,picture:G}=JSON.parse(B.content);n(6,h.event=B,h),n(6,h.name=q,h),n(6,h.picture=G,h)}catch{}}}),n(3,f=!1),y(x)}function oe(x){Qe[x?"unshift":"push"](()=>{i=x,n(1,i)})}function m(){c=br(this),n(2,c),n(7,E)}function v(x){Qe[x?"unshift":"push"](()=>{s=x,n(0,s)})}return[s,i,c,f,w,d,h,E,_,A,O,J,P,N,F,oe,m,v]}class pi extends Nr{constructor(e){super(),Ir(this,e,wi,hi,hr,{},null,[-1,-1])}}const ht=document.createElement("div");document.body.appendChild(ht),ht.id="windowNostrModal",ht.classList.add("tw-fixed","tw-top-6","tw-right-6");const yi=new pi({target:ht});window.destroyWnj=()=>{yi.$destroy()}})();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "window.nostr.js",
3
- "version": "0.0.2",
3
+ "version": "0.0.3",
4
4
  "type": "module",
5
5
  "devDependencies": {
6
6
  "@sveltejs/vite-plugin-svelte": "^3.0.2",
package/src/App.svelte CHANGED
@@ -51,6 +51,34 @@
51
51
  let providers: BunkerProfile[] = []
52
52
  reset()
53
53
 
54
+ let windowNostr = {
55
+ isWnj: true,
56
+ async getPublicKey(): Promise<string> {
57
+ if (!connecting && !connected) opened = true
58
+ return (await bunker).bp.pubkey
59
+ },
60
+ async signEvent(event: NostrEvent): Promise<VerifiedEvent> {
61
+ if (!connecting && !connected) opened = true
62
+ return (await bunker).signEvent(event)
63
+ },
64
+ async getRelays(): Promise<{
65
+ [url: string]: {read: boolean; write: boolean}
66
+ }> {
67
+ if (!connecting && !connected) opened = true
68
+ return (await bunker).getRelays()
69
+ },
70
+ nip04: {
71
+ async encrypt(pubkey: string, plaintext: string): Promise<string> {
72
+ if (!connecting && !connected) opened = true
73
+ return (await bunker).nip04Encrypt(pubkey, plaintext)
74
+ },
75
+ async decrypt(pubkey: string, ciphertext: string): Promise<string> {
76
+ if (!connecting && !connected) opened = true
77
+ return (await bunker).nip04Decrypt(pubkey, ciphertext)
78
+ }
79
+ }
80
+ }
81
+
54
82
  function reset() {
55
83
  opened = false
56
84
  bunkerPointer = null
@@ -80,24 +108,29 @@
80
108
  )
81
109
  }
82
110
 
83
- setTimeout(() => {
84
- if (win.nostr && !win.nostr.isWnj) {
85
- win.destroyWnj()
86
- return
87
- } else {
88
- win.nostr = {
89
- isWnj: true,
90
- async getPublicKey(): Promise<string> {
91
- if (!connecting) opened = true
92
- return (await bunker).bp.pubkey
93
- },
94
- async signEvent(event: NostrEvent): Promise<VerifiedEvent> {
95
- if (!connecting) opened = true
96
- return (await bunker).signEvent(event)
97
- }
98
- }
99
- }
100
- }, 3000)
111
+ if (win.nostr && !win.nostr.isWnj) {
112
+ // there is already a window.nostr
113
+ // (and it is not our own from a previous development hmr)
114
+ // so we just vanish
115
+ win.destroyWnj()
116
+ return
117
+ } else {
118
+ // there is no window.nostr, so we set this
119
+ // if an extension shows up later and sets this on top of ours we will vanish
120
+ Object.defineProperty(window, 'nostr', {
121
+ get: function () {
122
+ return windowNostr
123
+ },
124
+ set: function (v) {
125
+ // replace the internal object we have
126
+ windowNostr = v
127
+
128
+ // this is being set by an extension, so we vanish
129
+ if (!v.isWnj) win.destroyWnj()
130
+ },
131
+ configurable: true // this allows Object.defineProperty() to be called again
132
+ })
133
+ }
101
134
 
102
135
  return () => {
103
136
  if (metadataSub) metadataSub.close()
@@ -110,6 +143,12 @@
110
143
  else opened = false
111
144
  }
112
145
 
146
+ function handleCloseModal(ev: MouseEvent) {
147
+ opened = false
148
+ creating = false
149
+ ev.stopPropagation()
150
+ }
151
+
113
152
  async function handleConnect(ev: SubmitEvent) {
114
153
  ev.preventDefault()
115
154
  bunkerPointer = await parseBunkerInput(bunkerInput.value)
@@ -214,7 +253,7 @@
214
253
  <!-- Close status ################### -->
215
254
  {#if !opened}
216
255
  <div
217
- class="tw-px-4 tw-py-2 tw-transition-all tw-bg-cyan-700 hover:tw-bg-cyan-800 tw-shadow-xl tw-rounded tw-cursor-pointer"
256
+ class="tw-px-4 tw-py-2 tw-transition-all tw-bg-cyan-700 hover:tw-bg-cyan-800 tw-rounded tw-cursor-pointer tw-shadow-[0_0px_10px_0px_rgba(0,0,0,0.3)]"
218
257
  >
219
258
  <!-- Connecting view ################### -->
220
259
  {#if connecting}
@@ -222,16 +261,32 @@
222
261
  {:else if !connected}
223
262
  Login with Nostr
224
263
  {:else}
225
- {connected.name ||
226
- connected.npub.slice(0, 7) + '…' + connected.npub.slice(-4)}
264
+ <div class="tw-flex tw-items-center">
265
+ {#if connected.picture}
266
+ <img
267
+ src={connected.picture}
268
+ alt=""
269
+ class="tw-w-5 tw-h-5 tw-rounded-full tw-mr-2"
270
+ />
271
+ {:else}
272
+
273
+ {/if}
274
+ {connected.name ||
275
+ connected.npub.slice(0, 7) + '…' + connected.npub.slice(-4)}
276
+ </div>
227
277
  {/if}
228
278
  </div>
229
279
 
230
280
  <!-- Open status ################### -->
231
281
  {:else}
232
282
  <div
233
- class="tw-w-80 tw-px-6 tw-py-6 tw-transition-all tw-bg-cyan-700 tw-shadow-xl tw-rounded-md"
283
+ class="tw-w-80 tw-px-6 tw-py-8 tw-transition-all tw-bg-cyan-700 tw-rounded-md tw-shadow-[0_0px_30px_0px_rgba(0,0,0,0.6)]"
234
284
  >
285
+ <button
286
+ on:click={handleCloseModal}
287
+ class="tw-absolute tw-top-0 tw-right-0.5 tw-bg-transparent tw-border-none tw-cursor-pointer tw-text-cyan-950 tw-text-3xl"
288
+ >⤫</button
289
+ >
235
290
  <!-- Create account view ################### -->
236
291
  {#if creating}
237
292
  <div class="tw-text-lg tw-text-center">Create a new Nostr account</div>
@@ -292,16 +347,37 @@
292
347
  <!-- Connected view ################### -->
293
348
  {:else if connected}
294
349
  <div class="tw-text-center">
295
- <div class="tw-text-xs">You are currently connect to Nostr as</div>
350
+ <div class="tw-text-xs tw-mb-4">You are connected to Nostr as</div>
296
351
  <a
297
352
  target="_blank"
298
353
  href={'https://nosta.me/' + connected.npub}
299
- class="tw-block tw-text-white tw-mt-4 tw-break-all tw-no-underline hover:tw-underline"
300
- >{connected.npub}</a
354
+ class="tw-text-white tw-no-underline tw-group"
301
355
  >
356
+ {#if connected.picture || connected.name}
357
+ <div
358
+ class="tw-flex tw-items-center tw-justify-center tw-gap-2 tw-mb-2"
359
+ >
360
+ {#if connected.picture}
361
+ <img
362
+ src={connected.picture}
363
+ alt=""
364
+ class="tw-w-10 tw-h-10 tw-rounded-full tw-border-solid tw-border-2 tw-border-transparent group-hover:tw-border-cyan-100"
365
+ />
366
+ {/if}
367
+ {#if connected.name}
368
+ <div
369
+ class="tw-text-3xl group-hover:tw-underline tw-decoration-2 tw-underline-offset-4"
370
+ >
371
+ {connected.name}
372
+ </div>
373
+ {/if}
374
+ </div>
375
+ {/if}
376
+ <div class="tw-block tw-break-all">{connected.npub}</div>
377
+ </a>
302
378
  </div>
303
379
  <button
304
- class="tw-block tw-w-full tw-my-2 tw-mt-4 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white"
380
+ class="tw-block tw-w-full tw-my-2 tw-mt-6 tw-px-2 tw-py-1 tw-text-lg tw-rounded tw-border-0 tw-bg-cyan-900 hover:tw-bg-cyan-950 tw-hover:bg-indigo-900 tw-cursor-pointer tw-text-white"
305
381
  on:click={handleDisconnect}>Disconnect</button
306
382
  >
307
383
  {/if}