From 2d7600e6230377f2f527184ea0e8e3e641feb615 Mon Sep 17 00:00:00 2001 From: Nikolay Arhipov Date: Sun, 28 Apr 2024 15:03:38 +0300 Subject: [PATCH] Added unlock_all method --- src/blocking/mod.rs | 14 +++++++++++++- src/lib.rs | 12 ++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/src/blocking/mod.rs b/src/blocking/mod.rs index 4d87197..7703aa8 100644 --- a/src/blocking/mod.rs +++ b/src/blocking/mod.rs @@ -17,10 +17,10 @@ //! [zbus's blocking documentation]: https://docs.rs/zbus/latest/zbus/blocking/index.html //! [async `SecretService`]: crate::SecretService -use crate::proxy::service::ServiceProxyBlocking; use crate::session::Session; use crate::ss::SS_COLLECTION_LABEL; use crate::util; +use crate::{proxy::service::ServiceProxyBlocking, util::exec_prompt_blocking}; use crate::{EncryptionType, Error, SearchItemsResult}; use std::collections::HashMap; use zbus::zvariant::{ObjectPath, Value}; @@ -178,6 +178,18 @@ impl<'a> SecretService<'a> { locked: object_paths_to_items(items.locked)?, }) } + + /// Unlock all items in a batch + pub fn unlock_all(&self, items: &[&Item<'_>]) -> Result<(), Error> { + let objects = items.iter().map(|i| &*i.item_path).collect(); + let lock_action_res = self.service_proxy.unlock(objects)?; + + if lock_action_res.object_paths.is_empty() { + exec_prompt_blocking(self.conn.clone(), &lock_action_res.prompt)?; + } + + Ok(()) + } } #[cfg(test)] diff --git a/src/lib.rs b/src/lib.rs index d686732..23a3afe 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -326,6 +326,18 @@ impl<'a> SecretService<'a> { .collect::>()?, }) } + + /// Unlock all items in a batch + pub async fn unlock_all(&self, items: &[&Item<'_>]) -> Result<(), Error> { + let objects = items.iter().map(|i| &*i.item_path).collect(); + let lock_action_res = self.service_proxy.unlock(objects).await?; + + if lock_action_res.object_paths.is_empty() { + exec_prompt(self.conn.clone(), &lock_action_res.prompt).await?; + } + + Ok(()) + } } #[cfg(test)]