From 278a3fe0080b22a7c4489993a4b49d3c95852df0 Mon Sep 17 00:00:00 2001 From: Federico Terzi Date: Sun, 1 Aug 2021 11:31:05 +0200 Subject: [PATCH] feat(core): improve secure input detection interval handling --- espanso/src/cli/worker/secure_input.rs | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/espanso/src/cli/worker/secure_input.rs b/espanso/src/cli/worker/secure_input.rs index 469afa4..242db85 100644 --- a/espanso/src/cli/worker/secure_input.rs +++ b/espanso/src/cli/worker/secure_input.rs @@ -40,14 +40,22 @@ pub fn initialize_and_spawn(secure_input_sender: Sender) -> Re .name("secure-input-monitor".to_string()) .spawn(move || { // TODO: pass interval from config parameter - secure_input_main(secure_input_sender, std::time::Duration::from_secs(5)); + secure_input_main( + secure_input_sender, + std::time::Duration::from_secs(3), + std::time::Duration::from_secs(1), + ); })?; Ok(()) } #[cfg(target_os = "macos")] -fn secure_input_main(secure_input_sender: Sender, watch_interval: Duration) { +fn secure_input_main( + secure_input_sender: Sender, + min_watch_interval: Duration, + max_watch_interval: Duration, +) { info!("monitoring the status of secure input"); let mut last_secure_input_pid: Option = None; @@ -91,7 +99,7 @@ fn secure_input_main(secure_input_sender: Sender, watch_interv // No app is currently keeping SecureInput // If there was an app with SecureInput, notify that is now free - if let Some(old_pid) = last_secure_input_pid { + if let Some(_) = last_secure_input_pid { info!("secure input has been disabled"); if let Err(error) = secure_input_sender.send(SecureInputEvent::Disabled) { @@ -102,6 +110,11 @@ fn secure_input_main(secure_input_sender: Sender, watch_interv last_secure_input_pid = None } - std::thread::sleep(watch_interval); + // If an application is currently keeping secure input, refresh the status more often + if pid.is_some() { + std::thread::sleep(max_watch_interval); + } else { + std::thread::sleep(min_watch_interval); + } } }