From 977580ac8c3cd1a1795da2c3d0c0fba343c55509 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Fri, 20 Dec 2024 20:40:27 -0500 Subject: [PATCH 1/8] fix(secrets): Reduce keychain unlock prompts on MacOS Signed-off-by: Timothy Johnson --- packages/secrets/CHANGELOG.md | 4 + packages/secrets/core/Cargo.lock | 173 ++++++++++++++++++++-- packages/secrets/core/Cargo.toml | 3 +- packages/secrets/core/src/os/mac/mod.rs | 26 ++++ packages/secrets/src/keyring/Cargo.lock | 183 ++++++++++++++++++++++-- 5 files changed, 368 insertions(+), 21 deletions(-) diff --git a/packages/secrets/CHANGELOG.md b/packages/secrets/CHANGELOG.md index 8e88d6b1ca..caa18af4ea 100644 --- a/packages/secrets/CHANGELOG.md +++ b/packages/secrets/CHANGELOG.md @@ -2,6 +2,10 @@ All notable changes to the Zowe Secrets SDK package will be documented in this file. +## Recent Changes + +- BugFix: Reduced number of keychain unlock prompts on MacOS for simultaneous access to secrets by the same process. + ## `8.1.2` - BugFix: Updated dependencies for technical currency. [#2289](https://github.com/zowe/zowe-cli/pull/2289) diff --git a/packages/secrets/core/Cargo.lock b/packages/secrets/core/Cargo.lock index 42f00a8154..ffa8dccf8c 100644 --- a/packages/secrets/core/Cargo.lock +++ b/packages/secrets/core/Cargo.lock @@ -1,6 +1,6 @@ # This file is automatically @generated by Cargo. # It is not intended for manual editing. -version = 3 +version = 4 [[package]] name = "autocfg" @@ -259,18 +259,64 @@ dependencies = [ "system-deps", ] +[[package]] +name = "lock_api" +version = "0.4.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07af8b9cdd281b7915f413fa73f29ebd5d55d0d3f0155584dade1ff18cea1b17" +dependencies = [ + "autocfg", + "scopeguard", +] + [[package]] name = "memchr" version = "2.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167" +[[package]] +name = "named-lock" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "988ce9f7411c058a1d6788e60897a949dcdf5aa66202d789da045a03b4e4f406" +dependencies = [ + "libc", + "once_cell", + "parking_lot", + "thiserror", + "windows", +] + [[package]] name = "once_cell" version = "1.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" +[[package]] +name = "parking_lot" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1bf18183cf54e8d6059647fc3063646a1801cf30896933ec2311622cc4b9a27" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e401f977ab385c9e4e3ab30627d6f26d00e2c73eef317493c4ec6d468726cf8" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets 0.52.6", +] + [[package]] name = "pin-project-lite" version = "0.2.13" @@ -341,6 +387,21 @@ dependencies = [ "proc-macro2", ] +[[package]] +name = "redox_syscall" +version = "0.5.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "03a862b389f93e68874fbf580b9de08dd02facb9a788ebadaf4a3fd33cf58834" +dependencies = [ + "bitflags", +] + +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + [[package]] name = "secrets_core" version = "0.1.0" @@ -353,6 +414,7 @@ dependencies = [ "glib-sys", "libsecret", "libsecret-sys", + "named-lock", "thiserror", "windows-sys", ] @@ -546,13 +608,42 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" +[[package]] +name = "windows" +version = "0.53.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "efc5cf48f83140dcaab716eeaea345f9e93d0018fb81162753a3f76c3397b538" +dependencies = [ + "windows-core", + "windows-targets 0.52.6", +] + +[[package]] +name = "windows-core" +version = "0.53.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9dcc5b895a6377f1ab9fa55acedab1fd5ac0db66ad1e6c7f47e28a22e446a5dd" +dependencies = [ + "windows-result", + "windows-targets 0.52.6", +] + +[[package]] +name = "windows-result" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5e383302e8ec8515204254685643de10811af0ed97ea37210dc26fb0032647f8" +dependencies = [ + "windows-targets 0.52.6", +] + [[package]] name = "windows-sys" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets", + "windows-targets 0.48.5", ] [[package]] @@ -561,13 +652,29 @@ version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" dependencies = [ - "windows_aarch64_gnullvm", - "windows_aarch64_msvc", - "windows_i686_gnu", - "windows_i686_msvc", - "windows_x86_64_gnu", - "windows_x86_64_gnullvm", - "windows_x86_64_msvc", + "windows_aarch64_gnullvm 0.48.5", + "windows_aarch64_msvc 0.48.5", + "windows_i686_gnu 0.48.5", + "windows_i686_msvc 0.48.5", + "windows_x86_64_gnu 0.48.5", + "windows_x86_64_gnullvm 0.48.5", + "windows_x86_64_msvc 0.48.5", +] + +[[package]] +name = "windows-targets" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" +dependencies = [ + "windows_aarch64_gnullvm 0.52.6", + "windows_aarch64_msvc 0.52.6", + "windows_i686_gnu 0.52.6", + "windows_i686_gnullvm", + "windows_i686_msvc 0.52.6", + "windows_x86_64_gnu 0.52.6", + "windows_x86_64_gnullvm 0.52.6", + "windows_x86_64_msvc 0.52.6", ] [[package]] @@ -576,42 +683,90 @@ version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" + [[package]] name = "windows_aarch64_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" +[[package]] +name = "windows_aarch64_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" + [[package]] name = "windows_i686_gnu" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" +[[package]] +name = "windows_i686_gnu" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" + +[[package]] +name = "windows_i686_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" + [[package]] name = "windows_i686_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" +[[package]] +name = "windows_i686_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" + [[package]] name = "windows_x86_64_gnu" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" +[[package]] +name = "windows_x86_64_gnu" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" + [[package]] name = "windows_x86_64_gnullvm" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" + [[package]] name = "windows_x86_64_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" +[[package]] +name = "windows_x86_64_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" + [[package]] name = "winnow" version = "0.5.17" diff --git a/packages/secrets/core/Cargo.toml b/packages/secrets/core/Cargo.toml index b178909c50..5a89935d1a 100644 --- a/packages/secrets/core/Cargo.toml +++ b/packages/secrets/core/Cargo.toml @@ -22,10 +22,11 @@ version = "0.48.0" [target.'cfg(target_os = "macos")'.dependencies] core-foundation = "0.9.3" core-foundation-sys = "0.8.4" +named-lock = "0.4.1" [target.'cfg(any(target_os = "freebsd", target_os = "linux"))'.dependencies] glib = "0.18.2" glib-sys = "0.18.1" gio = "0.18.2" libsecret = "0.4.0" -libsecret-sys = "0.4.0" \ No newline at end of file +libsecret-sys = "0.4.0" diff --git a/packages/secrets/core/src/os/mac/mod.rs b/packages/secrets/core/src/os/mac/mod.rs index 8e4554d06e..a767281f02 100644 --- a/packages/secrets/core/src/os/mac/mod.rs +++ b/packages/secrets/core/src/os/mac/mod.rs @@ -12,6 +12,7 @@ use error::Error; use crate::os::mac::error::ERR_SEC_ITEM_NOT_FOUND; use crate::os::mac::keychain_search::{KeychainSearch, SearchResult}; use keychain::SecKeychain; +use named_lock::NamedLock; impl From for KeyringError { fn from(error: Error) -> Self { @@ -22,6 +23,26 @@ impl From for KeyringError { } } +impl From for KeyringError { + fn from(error: named_lock::Error) -> Self { + KeyringError::Library { + name: "named-lock".to_owned(), + details: error.to_string(), + } + } +} + +fn keyring_mutex() -> Result { + // MacOS shows keychain prompt after secret has been modified by another process. We use cross-process mutex to + // block keychain access if there are multiple concurrent keychain operations invoked by the same process. This + // prevents multiple instances of the same app (e.g. VS Code) from triggering several keychain prompts at once. + let exe_path = std::env::current_exe() + .unwrap() + .to_string_lossy() + .replace(std::path::MAIN_SEPARATOR, "_"); + NamedLock::create(format!("keyring_{}", exe_path).as_str()).map_err(|e| KeyringError::from(e)) +} + /// /// Attempts to set a password for a given service and account. /// @@ -38,6 +59,7 @@ pub fn set_password( password: &String, ) -> Result { let keychain = SecKeychain::default().unwrap(); + let _lock = keyring_mutex()?.lock().unwrap(); match keychain.set_password(service.as_str(), account.as_str(), password.as_bytes()) { Ok(()) => Ok(true), Err(err) => Err(KeyringError::from(err)), @@ -56,6 +78,7 @@ pub fn set_password( /// pub fn get_password(service: &String, account: &String) -> Result, KeyringError> { let keychain = SecKeychain::default().unwrap(); + let _lock = keyring_mutex()?.lock().unwrap(); match keychain.find_password(service.as_str(), account.as_str()) { Ok((pw, _)) => Ok(Some(String::from_utf8(pw.to_owned())?)), Err(err) if err.code() == ERR_SEC_ITEM_NOT_FOUND => Ok(None), @@ -83,6 +106,7 @@ pub fn find_password(service: &String) -> Result, KeyringError> { } let keychain = SecKeychain::default().unwrap(); + let _lock = keyring_mutex()?.lock().unwrap(); match keychain.find_password(cred_attrs[0], cred_attrs[1]) { Ok((pw, _)) => { let pw_str = String::from_utf8(pw.to_owned())?; @@ -104,6 +128,7 @@ pub fn find_password(service: &String) -> Result, KeyringError> { /// pub fn delete_password(service: &String, account: &String) -> Result { let keychain = SecKeychain::default().unwrap(); + let _lock = keyring_mutex()?.lock().unwrap(); match keychain.find_password(service.as_str(), account.as_str()) { Ok((_, item)) => { item.delete()?; @@ -128,6 +153,7 @@ pub fn find_credentials( service: &String, credentials: &mut Vec<(String, String)>, ) -> Result { + let _lock = keyring_mutex()?.lock().unwrap(); match KeychainSearch::new() .label(service.as_str()) .with_attrs() diff --git a/packages/secrets/src/keyring/Cargo.lock b/packages/secrets/src/keyring/Cargo.lock index e1b77b0474..d2b7edefa9 100644 --- a/packages/secrets/src/keyring/Cargo.lock +++ b/packages/secrets/src/keyring/Cargo.lock @@ -1,6 +1,6 @@ # This file is automatically @generated by Cargo. # It is not intended for manual editing. -version = 3 +version = 4 [[package]] name = "aho-corasick" @@ -17,6 +17,12 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + [[package]] name = "bitflags" version = "2.3.3" @@ -181,7 +187,7 @@ version = "0.18.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1c316afb01ce8067c5eaab1fc4f2cd47dc21ce7b6296358605e2ffab23ccbd19" dependencies = [ - "bitflags", + "bitflags 2.3.3", "futures-channel", "futures-core", "futures-executor", @@ -307,19 +313,42 @@ dependencies = [ "system-deps", ] +[[package]] +name = "lock_api" +version = "0.4.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07af8b9cdd281b7915f413fa73f29ebd5d55d0d3f0155584dade1ff18cea1b17" +dependencies = [ + "autocfg", + "scopeguard", +] + [[package]] name = "memchr" version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2dffe52ecf27772e601905b7522cb4ef790d2cc203488bbd0e2fe85fcb74566d" +[[package]] +name = "named-lock" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "988ce9f7411c058a1d6788e60897a949dcdf5aa66202d789da045a03b4e4f406" +dependencies = [ + "libc", + "once_cell", + "parking_lot", + "thiserror", + "windows", +] + [[package]] name = "napi" version = "2.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0ede2d12cd6fce44da537a4be1f5510c73be2506c2e32dfaaafd1f36968f3a0e" dependencies = [ - "bitflags", + "bitflags 2.3.3", "ctor", "napi-derive", "napi-sys", @@ -376,6 +405,29 @@ version = "1.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" +[[package]] +name = "parking_lot" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1bf18183cf54e8d6059647fc3063646a1801cf30896933ec2311622cc4b9a27" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets 0.48.1", +] + [[package]] name = "pin-project-lite" version = "0.2.10" @@ -446,6 +498,15 @@ dependencies = [ "proc-macro2", ] +[[package]] +name = "redox_syscall" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" +dependencies = [ + "bitflags 1.3.2", +] + [[package]] name = "regex" version = "1.9.1" @@ -475,6 +536,12 @@ version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e5ea92a5b6195c6ef2a0295ea818b312502c6fc94dde986c5553242e18fd4ce2" +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + [[package]] name = "secrets_core" version = "0.1.0" @@ -487,6 +554,7 @@ dependencies = [ "glib-sys", "libsecret", "libsecret-sys", + "named-lock", "thiserror", "windows-sys", ] @@ -668,13 +736,42 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" +[[package]] +name = "windows" +version = "0.53.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "efc5cf48f83140dcaab716eeaea345f9e93d0018fb81162753a3f76c3397b538" +dependencies = [ + "windows-core", + "windows-targets 0.52.6", +] + +[[package]] +name = "windows-core" +version = "0.53.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9dcc5b895a6377f1ab9fa55acedab1fd5ac0db66ad1e6c7f47e28a22e446a5dd" +dependencies = [ + "windows-result", + "windows-targets 0.52.6", +] + +[[package]] +name = "windows-result" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5e383302e8ec8515204254685643de10811af0ed97ea37210dc26fb0032647f8" +dependencies = [ + "windows-targets 0.52.6", +] + [[package]] name = "windows-sys" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets", + "windows-targets 0.48.1", ] [[package]] @@ -683,13 +780,29 @@ version = "0.48.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "05d4b17490f70499f20b9e791dcf6a299785ce8af4d709018206dc5b4953e95f" dependencies = [ - "windows_aarch64_gnullvm", - "windows_aarch64_msvc", - "windows_i686_gnu", - "windows_i686_msvc", - "windows_x86_64_gnu", - "windows_x86_64_gnullvm", - "windows_x86_64_msvc", + "windows_aarch64_gnullvm 0.48.0", + "windows_aarch64_msvc 0.48.0", + "windows_i686_gnu 0.48.0", + "windows_i686_msvc 0.48.0", + "windows_x86_64_gnu 0.48.0", + "windows_x86_64_gnullvm 0.48.0", + "windows_x86_64_msvc 0.48.0", +] + +[[package]] +name = "windows-targets" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" +dependencies = [ + "windows_aarch64_gnullvm 0.52.6", + "windows_aarch64_msvc 0.52.6", + "windows_i686_gnu 0.52.6", + "windows_i686_gnullvm", + "windows_i686_msvc 0.52.6", + "windows_x86_64_gnu 0.52.6", + "windows_x86_64_gnullvm 0.52.6", + "windows_x86_64_msvc 0.52.6", ] [[package]] @@ -698,42 +811,90 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" + [[package]] name = "windows_aarch64_msvc" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" +[[package]] +name = "windows_aarch64_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" + [[package]] name = "windows_i686_gnu" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" +[[package]] +name = "windows_i686_gnu" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" + +[[package]] +name = "windows_i686_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" + [[package]] name = "windows_i686_msvc" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" +[[package]] +name = "windows_i686_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" + [[package]] name = "windows_x86_64_gnu" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" +[[package]] +name = "windows_x86_64_gnu" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" + [[package]] name = "windows_x86_64_gnullvm" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" + [[package]] name = "windows_x86_64_msvc" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" +[[package]] +name = "windows_x86_64_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" + [[package]] name = "winnow" version = "0.5.2" From 9475e1637959b4849fb77119c52ba27a19313014 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Sat, 21 Dec 2024 07:16:50 -0500 Subject: [PATCH 2/8] Pin Docker image to Alpine 3.20 for keyring build Signed-off-by: Timothy Johnson --- packages/secrets/src/keyring/Cross.toml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/secrets/src/keyring/Cross.toml b/packages/secrets/src/keyring/Cross.toml index 106f07ec29..5a5f5826f8 100644 --- a/packages/secrets/src/keyring/Cross.toml +++ b/packages/secrets/src/keyring/Cross.toml @@ -15,11 +15,11 @@ passthrough = [ image = "ghcr.io/cross-rs/aarch64-unknown-linux-gnu:main" [target.aarch64-unknown-linux-musl] -image = "rust:alpine" +image = "rust:alpine3.20" pre-build = [ "wget -qO- https://musl.cc/aarch64-linux-musl-cross.tgz | tar -xzC / && export PATH=\"/aarch64-linux-musl-cross/bin:$PATH\"", "apk add --no-cache musl-dev pkgconfig", - "apk add -p /aarch64-linux-musl-cross --initdb --arch aarch64 --allow-untrusted -X \"https://dl-cdn.alpinelinux.org/alpine/latest-stable/main/\" --no-cache --no-scripts libsecret-dev", + "apk add -p /aarch64-linux-musl-cross --initdb --arch aarch64 --allow-untrusted -X $(head -n 1 /etc/apk/repositories) --no-cache --no-scripts libsecret-dev", "rustup target add aarch64-unknown-linux-musl" ] @@ -33,5 +33,5 @@ image = "ghcr.io/cross-rs/i686-unknown-linux-gnu:main" image = "ghcr.io/cross-rs/x86_64-unknown-linux-gnu:main" [target.x86_64-unknown-linux-musl] -image = "rust:alpine" +image = "rust:alpine3.20" pre-build = ["apk add libsecret-dev musl-dev"] From 7c0a0d72b281f1bb604f33ae3f743b222463f726 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Mon, 23 Dec 2024 08:15:28 -0500 Subject: [PATCH 3/8] Use low-level package for keyring mutex Signed-off-by: Timothy Johnson --- packages/secrets/core/Cargo.lock | 181 +++------------------- packages/secrets/core/Cargo.toml | 4 +- packages/secrets/core/src/os/error.rs | 1 - packages/secrets/core/src/os/mac/mod.rs | 29 ++-- packages/secrets/src/keyring/Cargo.lock | 191 +++--------------------- 5 files changed, 55 insertions(+), 351 deletions(-) diff --git a/packages/secrets/core/Cargo.lock b/packages/secrets/core/Cargo.lock index ffa8dccf8c..6057e22729 100644 --- a/packages/secrets/core/Cargo.lock +++ b/packages/secrets/core/Cargo.lock @@ -52,6 +52,15 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" +[[package]] +name = "fmutex" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "01e84c17070603126a7b0cd07d0ecc8e8cca4d15b67934ac2740286a84f3086c" +dependencies = [ + "libc", +] + [[package]] name = "futures-channel" version = "0.3.29" @@ -259,64 +268,18 @@ dependencies = [ "system-deps", ] -[[package]] -name = "lock_api" -version = "0.4.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07af8b9cdd281b7915f413fa73f29ebd5d55d0d3f0155584dade1ff18cea1b17" -dependencies = [ - "autocfg", - "scopeguard", -] - [[package]] name = "memchr" version = "2.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167" -[[package]] -name = "named-lock" -version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "988ce9f7411c058a1d6788e60897a949dcdf5aa66202d789da045a03b4e4f406" -dependencies = [ - "libc", - "once_cell", - "parking_lot", - "thiserror", - "windows", -] - [[package]] name = "once_cell" version = "1.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" -[[package]] -name = "parking_lot" -version = "0.12.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1bf18183cf54e8d6059647fc3063646a1801cf30896933ec2311622cc4b9a27" -dependencies = [ - "lock_api", - "parking_lot_core", -] - -[[package]] -name = "parking_lot_core" -version = "0.9.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e401f977ab385c9e4e3ab30627d6f26d00e2c73eef317493c4ec6d468726cf8" -dependencies = [ - "cfg-if", - "libc", - "redox_syscall", - "smallvec", - "windows-targets 0.52.6", -] - [[package]] name = "pin-project-lite" version = "0.2.13" @@ -387,21 +350,6 @@ dependencies = [ "proc-macro2", ] -[[package]] -name = "redox_syscall" -version = "0.5.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "03a862b389f93e68874fbf580b9de08dd02facb9a788ebadaf4a3fd33cf58834" -dependencies = [ - "bitflags", -] - -[[package]] -name = "scopeguard" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" - [[package]] name = "secrets_core" version = "0.1.0" @@ -409,12 +357,12 @@ dependencies = [ "cfg-if", "core-foundation", "core-foundation-sys", + "fmutex", "gio", "glib", "glib-sys", "libsecret", "libsecret-sys", - "named-lock", "thiserror", "windows-sys", ] @@ -608,42 +556,13 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" -[[package]] -name = "windows" -version = "0.53.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "efc5cf48f83140dcaab716eeaea345f9e93d0018fb81162753a3f76c3397b538" -dependencies = [ - "windows-core", - "windows-targets 0.52.6", -] - -[[package]] -name = "windows-core" -version = "0.53.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9dcc5b895a6377f1ab9fa55acedab1fd5ac0db66ad1e6c7f47e28a22e446a5dd" -dependencies = [ - "windows-result", - "windows-targets 0.52.6", -] - -[[package]] -name = "windows-result" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e383302e8ec8515204254685643de10811af0ed97ea37210dc26fb0032647f8" -dependencies = [ - "windows-targets 0.52.6", -] - [[package]] name = "windows-sys" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets 0.48.5", + "windows-targets", ] [[package]] @@ -652,29 +571,13 @@ version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" dependencies = [ - "windows_aarch64_gnullvm 0.48.5", - "windows_aarch64_msvc 0.48.5", - "windows_i686_gnu 0.48.5", - "windows_i686_msvc 0.48.5", - "windows_x86_64_gnu 0.48.5", - "windows_x86_64_gnullvm 0.48.5", - "windows_x86_64_msvc 0.48.5", -] - -[[package]] -name = "windows-targets" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" -dependencies = [ - "windows_aarch64_gnullvm 0.52.6", - "windows_aarch64_msvc 0.52.6", - "windows_i686_gnu 0.52.6", - "windows_i686_gnullvm", - "windows_i686_msvc 0.52.6", - "windows_x86_64_gnu 0.52.6", - "windows_x86_64_gnullvm 0.52.6", - "windows_x86_64_msvc 0.52.6", + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", ] [[package]] @@ -683,90 +586,42 @@ version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" - [[package]] name = "windows_aarch64_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" -[[package]] -name = "windows_aarch64_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" - [[package]] name = "windows_i686_gnu" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" -[[package]] -name = "windows_i686_gnu" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" - -[[package]] -name = "windows_i686_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" - [[package]] name = "windows_i686_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" -[[package]] -name = "windows_i686_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" - [[package]] name = "windows_x86_64_gnu" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" -[[package]] -name = "windows_x86_64_gnu" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" - [[package]] name = "windows_x86_64_gnullvm" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" - [[package]] name = "windows_x86_64_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" -[[package]] -name = "windows_x86_64_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" - [[package]] name = "winnow" version = "0.5.17" diff --git a/packages/secrets/core/Cargo.toml b/packages/secrets/core/Cargo.toml index 5a89935d1a..30c0a4125f 100644 --- a/packages/secrets/core/Cargo.toml +++ b/packages/secrets/core/Cargo.toml @@ -22,11 +22,11 @@ version = "0.48.0" [target.'cfg(target_os = "macos")'.dependencies] core-foundation = "0.9.3" core-foundation-sys = "0.8.4" -named-lock = "0.4.1" +fmutex = "0.1.0" [target.'cfg(any(target_os = "freebsd", target_os = "linux"))'.dependencies] +gio = "0.18.2" glib = "0.18.2" glib-sys = "0.18.1" -gio = "0.18.2" libsecret = "0.4.0" libsecret-sys = "0.4.0" diff --git a/packages/secrets/core/src/os/error.rs b/packages/secrets/core/src/os/error.rs index 7d7c251d32..572ca2489d 100644 --- a/packages/secrets/core/src/os/error.rs +++ b/packages/secrets/core/src/os/error.rs @@ -11,7 +11,6 @@ pub enum KeyringError { #[error("[keyring] {name:?} library returned an error:\n\n{details:?}")] Library { name: String, details: String }, - #[cfg(not(target_os = "macos"))] #[error("[keyring] An OS error has occurred:\n\n{0}")] Os(String), diff --git a/packages/secrets/core/src/os/mac/mod.rs b/packages/secrets/core/src/os/mac/mod.rs index a767281f02..35041ae6c9 100644 --- a/packages/secrets/core/src/os/mac/mod.rs +++ b/packages/secrets/core/src/os/mac/mod.rs @@ -11,8 +11,8 @@ use error::Error; use crate::os::mac::error::ERR_SEC_ITEM_NOT_FOUND; use crate::os::mac::keychain_search::{KeychainSearch, SearchResult}; +use fmutex::Guard; use keychain::SecKeychain; -use named_lock::NamedLock; impl From for KeyringError { fn from(error: Error) -> Self { @@ -23,16 +23,13 @@ impl From for KeyringError { } } -impl From for KeyringError { - fn from(error: named_lock::Error) -> Self { - KeyringError::Library { - name: "named-lock".to_owned(), - details: error.to_string(), - } +impl From for KeyringError { + fn from(error: std::io::Error) -> Self { + KeyringError::Os(error.to_string()) } } -fn keyring_mutex() -> Result { +fn keyring_mutex() -> Result { // MacOS shows keychain prompt after secret has been modified by another process. We use cross-process mutex to // block keychain access if there are multiple concurrent keychain operations invoked by the same process. This // prevents multiple instances of the same app (e.g. VS Code) from triggering several keychain prompts at once. @@ -40,7 +37,11 @@ fn keyring_mutex() -> Result { .unwrap() .to_string_lossy() .replace(std::path::MAIN_SEPARATOR, "_"); - NamedLock::create(format!("keyring_{}", exe_path).as_str()).map_err(|e| KeyringError::from(e)) + let lock_path = std::env::temp_dir() + .join(format!("keyring_{}.lock", exe_path)); + std::fs::OpenOptions::new().create(true).write(true).open(&lock_path) + .and_then(|_| fmutex::lock(lock_path)) + .map_err(KeyringError::from) } /// @@ -59,7 +60,7 @@ pub fn set_password( password: &String, ) -> Result { let keychain = SecKeychain::default().unwrap(); - let _lock = keyring_mutex()?.lock().unwrap(); + let _lock = keyring_mutex().unwrap(); match keychain.set_password(service.as_str(), account.as_str(), password.as_bytes()) { Ok(()) => Ok(true), Err(err) => Err(KeyringError::from(err)), @@ -78,7 +79,7 @@ pub fn set_password( /// pub fn get_password(service: &String, account: &String) -> Result, KeyringError> { let keychain = SecKeychain::default().unwrap(); - let _lock = keyring_mutex()?.lock().unwrap(); + let _lock = keyring_mutex().unwrap(); match keychain.find_password(service.as_str(), account.as_str()) { Ok((pw, _)) => Ok(Some(String::from_utf8(pw.to_owned())?)), Err(err) if err.code() == ERR_SEC_ITEM_NOT_FOUND => Ok(None), @@ -106,7 +107,7 @@ pub fn find_password(service: &String) -> Result, KeyringError> { } let keychain = SecKeychain::default().unwrap(); - let _lock = keyring_mutex()?.lock().unwrap(); + let _lock = keyring_mutex().unwrap(); match keychain.find_password(cred_attrs[0], cred_attrs[1]) { Ok((pw, _)) => { let pw_str = String::from_utf8(pw.to_owned())?; @@ -128,7 +129,7 @@ pub fn find_password(service: &String) -> Result, KeyringError> { /// pub fn delete_password(service: &String, account: &String) -> Result { let keychain = SecKeychain::default().unwrap(); - let _lock = keyring_mutex()?.lock().unwrap(); + let _lock = keyring_mutex().unwrap(); match keychain.find_password(service.as_str(), account.as_str()) { Ok((_, item)) => { item.delete()?; @@ -153,7 +154,7 @@ pub fn find_credentials( service: &String, credentials: &mut Vec<(String, String)>, ) -> Result { - let _lock = keyring_mutex()?.lock().unwrap(); + let _lock = keyring_mutex().unwrap(); match KeychainSearch::new() .label(service.as_str()) .with_attrs() diff --git a/packages/secrets/src/keyring/Cargo.lock b/packages/secrets/src/keyring/Cargo.lock index d2b7edefa9..cb6ec93e33 100644 --- a/packages/secrets/src/keyring/Cargo.lock +++ b/packages/secrets/src/keyring/Cargo.lock @@ -17,12 +17,6 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" -[[package]] -name = "bitflags" -version = "1.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" - [[package]] name = "bitflags" version = "2.3.3" @@ -86,6 +80,15 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" +[[package]] +name = "fmutex" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "01e84c17070603126a7b0cd07d0ecc8e8cca4d15b67934ac2740286a84f3086c" +dependencies = [ + "libc", +] + [[package]] name = "futures-channel" version = "0.3.28" @@ -187,7 +190,7 @@ version = "0.18.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1c316afb01ce8067c5eaab1fc4f2cd47dc21ce7b6296358605e2ffab23ccbd19" dependencies = [ - "bitflags 2.3.3", + "bitflags", "futures-channel", "futures-core", "futures-executor", @@ -313,42 +316,19 @@ dependencies = [ "system-deps", ] -[[package]] -name = "lock_api" -version = "0.4.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07af8b9cdd281b7915f413fa73f29ebd5d55d0d3f0155584dade1ff18cea1b17" -dependencies = [ - "autocfg", - "scopeguard", -] - [[package]] name = "memchr" version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2dffe52ecf27772e601905b7522cb4ef790d2cc203488bbd0e2fe85fcb74566d" -[[package]] -name = "named-lock" -version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "988ce9f7411c058a1d6788e60897a949dcdf5aa66202d789da045a03b4e4f406" -dependencies = [ - "libc", - "once_cell", - "parking_lot", - "thiserror", - "windows", -] - [[package]] name = "napi" version = "2.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0ede2d12cd6fce44da537a4be1f5510c73be2506c2e32dfaaafd1f36968f3a0e" dependencies = [ - "bitflags 2.3.3", + "bitflags", "ctor", "napi-derive", "napi-sys", @@ -405,29 +385,6 @@ version = "1.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" -[[package]] -name = "parking_lot" -version = "0.12.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1bf18183cf54e8d6059647fc3063646a1801cf30896933ec2311622cc4b9a27" -dependencies = [ - "lock_api", - "parking_lot_core", -] - -[[package]] -name = "parking_lot_core" -version = "0.9.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" -dependencies = [ - "cfg-if", - "libc", - "redox_syscall", - "smallvec", - "windows-targets 0.48.1", -] - [[package]] name = "pin-project-lite" version = "0.2.10" @@ -498,15 +455,6 @@ dependencies = [ "proc-macro2", ] -[[package]] -name = "redox_syscall" -version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" -dependencies = [ - "bitflags 1.3.2", -] - [[package]] name = "regex" version = "1.9.1" @@ -536,12 +484,6 @@ version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e5ea92a5b6195c6ef2a0295ea818b312502c6fc94dde986c5553242e18fd4ce2" -[[package]] -name = "scopeguard" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" - [[package]] name = "secrets_core" version = "0.1.0" @@ -549,12 +491,12 @@ dependencies = [ "cfg-if", "core-foundation", "core-foundation-sys", + "fmutex", "gio", "glib", "glib-sys", "libsecret", "libsecret-sys", - "named-lock", "thiserror", "windows-sys", ] @@ -736,42 +678,13 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" -[[package]] -name = "windows" -version = "0.53.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "efc5cf48f83140dcaab716eeaea345f9e93d0018fb81162753a3f76c3397b538" -dependencies = [ - "windows-core", - "windows-targets 0.52.6", -] - -[[package]] -name = "windows-core" -version = "0.53.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9dcc5b895a6377f1ab9fa55acedab1fd5ac0db66ad1e6c7f47e28a22e446a5dd" -dependencies = [ - "windows-result", - "windows-targets 0.52.6", -] - -[[package]] -name = "windows-result" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e383302e8ec8515204254685643de10811af0ed97ea37210dc26fb0032647f8" -dependencies = [ - "windows-targets 0.52.6", -] - [[package]] name = "windows-sys" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets 0.48.1", + "windows-targets", ] [[package]] @@ -780,29 +693,13 @@ version = "0.48.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "05d4b17490f70499f20b9e791dcf6a299785ce8af4d709018206dc5b4953e95f" dependencies = [ - "windows_aarch64_gnullvm 0.48.0", - "windows_aarch64_msvc 0.48.0", - "windows_i686_gnu 0.48.0", - "windows_i686_msvc 0.48.0", - "windows_x86_64_gnu 0.48.0", - "windows_x86_64_gnullvm 0.48.0", - "windows_x86_64_msvc 0.48.0", -] - -[[package]] -name = "windows-targets" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" -dependencies = [ - "windows_aarch64_gnullvm 0.52.6", - "windows_aarch64_msvc 0.52.6", - "windows_i686_gnu 0.52.6", - "windows_i686_gnullvm", - "windows_i686_msvc 0.52.6", - "windows_x86_64_gnu 0.52.6", - "windows_x86_64_gnullvm 0.52.6", - "windows_x86_64_msvc 0.52.6", + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", ] [[package]] @@ -811,90 +708,42 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" - [[package]] name = "windows_aarch64_msvc" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" -[[package]] -name = "windows_aarch64_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" - [[package]] name = "windows_i686_gnu" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" -[[package]] -name = "windows_i686_gnu" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" - -[[package]] -name = "windows_i686_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" - [[package]] name = "windows_i686_msvc" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" -[[package]] -name = "windows_i686_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" - [[package]] name = "windows_x86_64_gnu" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" -[[package]] -name = "windows_x86_64_gnu" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" - [[package]] name = "windows_x86_64_gnullvm" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" - [[package]] name = "windows_x86_64_msvc" version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" -[[package]] -name = "windows_x86_64_msvc" -version = "0.52.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" - [[package]] name = "winnow" version = "0.5.2" From 7076848e7255c5322ab3bb26bea9e4bdba590b5d Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Mon, 23 Dec 2024 10:37:20 -0500 Subject: [PATCH 4/8] Disable Ava worker threads to fix keyring tests Signed-off-by: Timothy Johnson --- packages/secrets/package.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/packages/secrets/package.json b/packages/secrets/package.json index 88df5e6fa8..62d4fdebba 100644 --- a/packages/secrets/package.json +++ b/packages/secrets/package.json @@ -28,7 +28,8 @@ "ava": "^6.0.0" }, "ava": { - "timeout": "3m" + "timeout": "3m", + "workerThreads": false }, "engines": { "node": ">=14" From fadf4e85a27b0a8ecd80963fd3ab1ca4d3179712 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Tue, 24 Dec 2024 08:44:34 -0500 Subject: [PATCH 5/8] Switch back to ubuntu-latest and add Node 22 in workflow Signed-off-by: Timothy Johnson --- .github/workflows/secrets-sdk.yml | 29 +++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/.github/workflows/secrets-sdk.yml b/.github/workflows/secrets-sdk.yml index 83459803e8..04a63d99d8 100644 --- a/.github/workflows/secrets-sdk.yml +++ b/.github/workflows/secrets-sdk.yml @@ -38,27 +38,27 @@ jobs: npm run build -- --target i686-pc-windows-msvc npm run test target: i686-pc-windows-msvc - - host: ubuntu-22.04 + - host: ubuntu-latest target: x86_64-unknown-linux-gnu use-cross: true build: | set -e CARGO=cross npm run build -- --target x86_64-unknown-linux-gnu - - host: ubuntu-22.04 + - host: ubuntu-latest target: i686-unknown-linux-gnu use-cross: true build: | set -e source scripts/configure-cross.sh i686-unknown-linux-gnu CARGO=cross npm run build -- --target i686-unknown-linux-gnu - - host: ubuntu-22.04 + - host: ubuntu-latest target: armv7-unknown-linux-gnueabihf use-cross: true build: | set -e source scripts/configure-cross.sh armv7-unknown-linux-gnueabihf CARGO=cross npm run build -- --target armv7-unknown-linux-gnueabihf - - host: ubuntu-22.04 + - host: ubuntu-latest target: x86_64-unknown-linux-musl use-cross: true build: | @@ -67,14 +67,14 @@ jobs: - host: macos-latest target: aarch64-apple-darwin build: npm run build -- --target aarch64-apple-darwin - - host: ubuntu-22.04 + - host: ubuntu-latest target: aarch64-unknown-linux-gnu use-cross: true build: | set -e source scripts/configure-cross.sh aarch64-unknown-linux-gnu CARGO=cross npm run build -- --target aarch64-unknown-linux-gnu - - host: ubuntu-22.04 + - host: ubuntu-latest target: aarch64-unknown-linux-musl use-cross: true build: | @@ -208,22 +208,23 @@ jobs: - host: macos-latest target: x86_64-apple-darwin architecture: x64 - - host: ubuntu-22.04 + - host: ubuntu-latest target: x86_64-unknown-linux-gnu - - host: ubuntu-22.04 + - host: ubuntu-latest target: x86_64-unknown-linux-musl - - host: ubuntu-22.04 + - host: ubuntu-latest target: aarch64-unknown-linux-gnu platform: linux/arm64 - - host: ubuntu-22.04 + - host: ubuntu-latest target: aarch64-unknown-linux-musl platform: linux/arm64 - - host: ubuntu-22.04 + - host: ubuntu-latest target: armv7-unknown-linux-gnueabihf platform: linux/arm/v7 node: - "18" - "20" + - "22" runs-on: ${{ matrix.settings.host }} steps: - uses: actions/checkout@v4 @@ -250,10 +251,10 @@ jobs: if: ${{ matrix.settings.platform }} - name: Test bindings run: npm run test - if: ${{ matrix.settings.host != 'ubuntu-22.04' }} + if: ${{ matrix.settings.host != 'ubuntu-latest' }} - name: Setup and run tests uses: addnab/docker-run-action@v3 - if: ${{ matrix.settings.host == 'ubuntu-22.04' && !endsWith(matrix.settings.target, 'musl') }} + if: ${{ matrix.settings.host == 'ubuntu-latest' && !endsWith(matrix.settings.target, 'musl') }} with: image: ${{ format('node:{0}-slim', matrix.node) }} options: "-v ${{ github.workspace }}:/build -w /build --cap-add=IPC_LOCK ${{ matrix.settings.platform && format('--platform={0}', matrix.settings.platform) }}" @@ -263,7 +264,7 @@ jobs: cd packages/secrets && dbus-run-session -- bash scripts/linux-test.sh - name: Setup and run tests (MUSL) uses: addnab/docker-run-action@v3 - if: ${{ matrix.settings.host == 'ubuntu-22.04' && endsWith(matrix.settings.target, 'musl') }} + if: ${{ matrix.settings.host == 'ubuntu-latest' && endsWith(matrix.settings.target, 'musl') }} with: image: ${{ format('node:{0}-alpine', matrix.node) }} options: "-v ${{ github.workspace }}:/build -w /build --cap-add=IPC_LOCK ${{ matrix.settings.platform && format('--platform={0}', matrix.settings.platform) }}" From a2251be5a2b81576418d8bfee41b5b01dfa13fd4 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Mon, 6 Jan 2025 13:48:44 -0500 Subject: [PATCH 6/8] Update CHANGELOG.md Signed-off-by: Timothy Johnson --- packages/secrets/CHANGELOG.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/secrets/CHANGELOG.md b/packages/secrets/CHANGELOG.md index caa18af4ea..89cc2fc854 100644 --- a/packages/secrets/CHANGELOG.md +++ b/packages/secrets/CHANGELOG.md @@ -4,7 +4,7 @@ All notable changes to the Zowe Secrets SDK package will be documented in this f ## Recent Changes -- BugFix: Reduced number of keychain unlock prompts on MacOS for simultaneous access to secrets by the same process. +- BugFix: Reduced number of keychain unlock prompts on MacOS for simultaneous access to secrets by multiple instances of the same application. ## `8.1.2` @@ -56,4 +56,4 @@ All notable changes to the Zowe Secrets SDK package will be documented in this f ## `7.18.0` - Initial release. -- `keyring` module added for interacting with OS-specific keyring/credential vaults. See [src/keyring](src/keyring/README.md) for information on this native module and how it can be used. \ No newline at end of file +- `keyring` module added for interacting with OS-specific keyring/credential vaults. See [src/keyring](src/keyring/README.md) for information on this native module and how it can be used. From 265f087632d093ad42db0ff2608baf55f1f25d71 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Tue, 7 Jan 2025 13:36:01 -0500 Subject: [PATCH 7/8] Make name of lockfile more informative Signed-off-by: Timothy Johnson --- packages/secrets/core/src/os/mac/mod.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/secrets/core/src/os/mac/mod.rs b/packages/secrets/core/src/os/mac/mod.rs index 35041ae6c9..57587f1d4c 100644 --- a/packages/secrets/core/src/os/mac/mod.rs +++ b/packages/secrets/core/src/os/mac/mod.rs @@ -38,7 +38,7 @@ fn keyring_mutex() -> Result { .to_string_lossy() .replace(std::path::MAIN_SEPARATOR, "_"); let lock_path = std::env::temp_dir() - .join(format!("keyring_{}.lock", exe_path)); + .join(format!("zowe_{}_{}.lock", env!("CARGO_PKG_NAME"), exe_path)); std::fs::OpenOptions::new().create(true).write(true).open(&lock_path) .and_then(|_| fmutex::lock(lock_path)) .map_err(KeyringError::from) From 904000858f255a6da75122dcd3b4c1799bb0ccc7 Mon Sep 17 00:00:00 2001 From: Timothy Johnson Date: Tue, 7 Jan 2025 15:34:01 -0500 Subject: [PATCH 8/8] Add PR link to changelog Signed-off-by: Timothy Johnson --- packages/secrets/CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/secrets/CHANGELOG.md b/packages/secrets/CHANGELOG.md index 89cc2fc854..e7ea7e74d9 100644 --- a/packages/secrets/CHANGELOG.md +++ b/packages/secrets/CHANGELOG.md @@ -4,7 +4,7 @@ All notable changes to the Zowe Secrets SDK package will be documented in this f ## Recent Changes -- BugFix: Reduced number of keychain unlock prompts on MacOS for simultaneous access to secrets by multiple instances of the same application. +- BugFix: Reduced number of keychain unlock prompts on MacOS for simultaneous access to secrets by multiple instances of the same application. [#2394](https://github.com/zowe/zowe-cli/pull/2394) ## `8.1.2`