From bee63ed7dfeb485ac7fe0b1d36d4a0015e6cdb95 Mon Sep 17 00:00:00 2001 From: Jordan Herzstein <63795875+jherzstein@users.noreply.github.com> Date: Thu, 12 Dec 2024 12:35:26 -0500 Subject: [PATCH] qr code generation optional argument (#277) hide qr code by default unless made explicit --- cli/src/main.rs | 52 ++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 43 insertions(+), 9 deletions(-) diff --git a/cli/src/main.rs b/cli/src/main.rs index 2e0134dc..c15aeba7 100644 --- a/cli/src/main.rs +++ b/cli/src/main.rs @@ -89,6 +89,9 @@ struct CommonLeaderArgs { /// Length of code (in bytes/words) #[arg(short = 'c', long, value_name = "NUMWORDS", default_value = "2")] code_length: usize, + /// Suppress QR code generation from send link + #[arg(long)] + no_qr: bool, } // receive @@ -289,7 +292,12 @@ async fn main() -> eyre::Result<()> { match app.command { WormholeCommand::Send { common, - common_leader: CommonLeaderArgs { code, code_length }, + common_leader: + CommonLeaderArgs { + code, + code_length, + no_qr, + }, common_send: CommonSenderArgs { file_name, files }, .. } => { @@ -302,6 +310,7 @@ async fn main() -> eyre::Result<()> { common, code, Some(code_length), + no_qr, true, transfer::APP_CONFIG, Some(&sender_print_code), @@ -328,7 +337,12 @@ async fn main() -> eyre::Result<()> { tries, timeout, common, - common_leader: CommonLeaderArgs { code, code_length }, + common_leader: + CommonLeaderArgs { + code, + code_length, + no_qr, + }, common_send: CommonSenderArgs { file_name, files }, .. } => { @@ -339,6 +353,7 @@ async fn main() -> eyre::Result<()> { common, code, Some(code_length), + no_qr, true, transfer::APP_CONFIG, Some(&sender_print_code), @@ -379,6 +394,7 @@ async fn main() -> eyre::Result<()> { code, None, false, + false, transfer::APP_CONFIG, None, )); @@ -401,7 +417,12 @@ async fn main() -> eyre::Result<()> { WormholeCommand::Forward(ForwardCommand::Serve { targets, common, - common_leader: CommonLeaderArgs { code, code_length }, + common_leader: + CommonLeaderArgs { + code, + code_length, + no_qr, + }, .. }) => { // TODO make fancy @@ -451,6 +472,7 @@ async fn main() -> eyre::Result<()> { common.clone(), code.clone(), Some(code_length), + no_qr, true, app_config, Some(&server_print_code), @@ -481,8 +503,10 @@ async fn main() -> eyre::Result<()> { tracing::warn!("This is an unstable feature. Make sure that your peer is running the exact same version of the program as you. Also, please report all bugs and crashes."); let mut app_config = forwarding::APP_CONFIG; app_config.app_version.transit_abilities = parse_transit_args(&common); - let (wormhole, _code, relay_hints) = - parse_and_connect(&mut term, common, code, None, false, app_config, None).await?; + let (wormhole, _code, relay_hints) = parse_and_connect( + &mut term, common, code, None, false, false, app_config, None, + ) + .await?; let offer = forwarding::connect( wormhole, @@ -548,7 +572,8 @@ fn parse_transit_args(args: &CommonArgs) -> transit::Abilities { } } -type PrintCodeFn = dyn Fn(&mut Term, &magic_wormhole::Code, &Option) -> eyre::Result<()>; +type PrintCodeFn = + dyn Fn(&mut Term, &magic_wormhole::Code, &Option, bool) -> eyre::Result<()>; /** * Parse the necessary command line arguments to establish an initial server connection. @@ -563,6 +588,7 @@ async fn parse_and_connect( common_args: CommonArgs, mut code: Option, code_length: Option, + no_qr: bool, is_send: bool, mut app_config: magic_wormhole::AppConfig, print_code: Option<&PrintCodeFn>, @@ -637,6 +663,7 @@ async fn parse_and_connect( term, &code, &uri_rendezvous, + no_qr, )?; } MailboxConnection::connect(app_config, code, true).await? @@ -667,6 +694,7 @@ async fn parse_and_connect( term, mailbox_connection.code(), &uri_rendezvous, + no_qr, )?; } mailbox_connection @@ -764,6 +792,7 @@ fn sender_print_code( term: &mut Term, code: &magic_wormhole::Code, rendezvous_server: &Option, + no_qr: bool, ) -> eyre::Result<()> { let uri = magic_wormhole::uri::WormholeTransferUri { code: code.clone(), @@ -783,9 +812,13 @@ fn sender_print_code( } writeln!(term, "This is equivalent to the following link: \u{001B}]8;;{}\u{001B}\\{}\u{001B}]8;;\u{001B}\\", &uri, &uri)?; - let qr = - qr2term::generate_qr_string(&uri).context("Failed to generate QR code for send link")?; - writeln!(term, "{}", qr)?; + if no_qr { + tracing::debug!("QR option not enabled. Skipping QR code generation."); + } else { + let qr_code = qr2term::generate_qr_string(&uri) + .context("Failed to generate QR code for send link")?; + writeln!(term, "{}", qr_code)?; + } writeln!( term, @@ -805,6 +838,7 @@ fn server_print_code( term: &mut Term, code: &magic_wormhole::Code, _: &Option, + _qr: bool, ) -> eyre::Result<()> { if cfg!(feature = "clipboard") { writeln!(