diff options
author | sommerfeld <sommerfeld@sommerfeld.dev> | 2024-07-05 16:39:51 +0100 |
---|---|---|
committer | sommerfeld <sommerfeld@sommerfeld.dev> | 2024-07-05 16:39:51 +0100 |
commit | 239562007942a79b2ee0198b2eb5ca5a431ea4b5 (patch) | |
tree | 935cda0fb28562b9b0e33f047731df655329c810 /src | |
parent | 1f6a894786527c0bbc6e55b28c32acad1b31a89c (diff) | |
download | viewercount-239562007942a79b2ee0198b2eb5ca5a431ea4b5.tar.gz viewercount-239562007942a79b2ee0198b2eb5ca5a431ea4b5.tar.bz2 viewercount-239562007942a79b2ee0198b2eb5ca5a431ea4b5.zip |
Fix nostrconnect on subsequent runs
Diffstat (limited to 'src')
-rw-r--r-- | src/main.rs | 31 |
1 files changed, 15 insertions, 16 deletions
diff --git a/src/main.rs b/src/main.rs index dfbbc25..9387d2f 100644 --- a/src/main.rs +++ b/src/main.rs @@ -74,7 +74,7 @@ struct ClientData { } impl ClientData { - async fn generate(use_nsecbunker: bool) -> Result<Self> { + async fn generate(use_nsecbunker: bool, nip46_timeout: Duration) -> Result<Self> { let keys = Keys::generate(); let nip46_uri = match use_nsecbunker { @@ -90,19 +90,20 @@ impl ClientData { keys.public_key(), [Url::parse("wss://relay.nsec.app")?], env!("CARGO_PKG_NAME"), - ) - .to_string(); + ); + let uri_str = uri.to_string(); println!( - "Use your NIP46 signer app (e.g. Amber) to connect by using this URI:\n{uri}" + "Use your NIP46 signer app (e.g. Amber) to connect by using this URI:\n{uri_str}" ); - let code = QrCode::new(uri.clone()).unwrap(); + let code = QrCode::new(uri_str).unwrap(); let image = code .render::<unicode::Dense1x2>() .dark_color(unicode::Dense1x2::Light) .light_color(unicode::Dense1x2::Dark) .build(); println!("{}", image); - uri + let signer = Nip46Signer::new(uri, keys.clone(), nip46_timeout, None).await?; + signer.nostr_connect_uri().await.to_string() } }; @@ -209,20 +210,18 @@ async fn create_signer( .ok_or(anyhow!("Cannot convert path to string"))?; let _ = rename(path_str, format!("{}.bak", path_str)); } - let client_data = get_or_generate_client_data(use_nsecbunker).await?; + let client_data = get_or_generate_client_data(use_nsecbunker, nip46_timeout).await?; let client_keys = Keys::parse(client_data.client_nsec)?; info!("setting up NIP46 signer"); - let signer = Nip46Signer::new( - NostrConnectURI::parse(client_data.nip46_uri)?, - client_keys, - nip46_timeout, - None, - ) - .await?; + let uri = NostrConnectURI::parse(client_data.nip46_uri)?; + let signer = Nip46Signer::new(uri, client_keys, nip46_timeout, None).await?; Ok(signer) } -async fn get_or_generate_client_data(use_nsecbunker: bool) -> Result<ClientData> { +async fn get_or_generate_client_data( + use_nsecbunker: bool, + nip46_timeout: Duration, +) -> Result<ClientData> { let path = get_client_data_path(); match File::open(&path) { Ok(file) => { @@ -231,7 +230,7 @@ async fn get_or_generate_client_data(use_nsecbunker: bool) -> Result<ClientData> .with_context(|| format!("cannot read client data from '{}'", path.display())) } Err(_) => { - let nostr_data = ClientData::generate(use_nsecbunker).await?; + let nostr_data = ClientData::generate(use_nsecbunker, nip46_timeout).await?; let mut file = File::create(&path)?; file.write_all(to_string(&nostr_data)?.as_bytes()) .with_context(|| format!("could not write client data to '{}'", path.display()))?; |