diff --git a/security-framework-sys/src/item.rs b/security-framework-sys/src/item.rs index 4b4c52ed..5ff36b57 100644 --- a/security-framework-sys/src/item.rs +++ b/security-framework-sys/src/item.rs @@ -12,6 +12,8 @@ extern "C" { pub static kSecMatchLimitAll: CFStringRef; pub static kSecMatchTrustedOnly: CFStringRef; + pub static kSecMatchCaseInsensitive: CFStringRef; + pub static kSecMatchSubjectWholeString: CFStringRef; pub static kSecReturnData: CFStringRef; pub static kSecReturnAttributes: CFStringRef; diff --git a/security-framework/src/item.rs b/security-framework/src/item.rs index c29f2d62..7e011be8 100644 --- a/security-framework/src/item.rs +++ b/security-framework/src/item.rs @@ -131,6 +131,7 @@ pub struct ItemSearchOptions { keychains: Option>, #[cfg(not(target_os = "macos"))] keychains: Option>, + case_insensitive: Option, class: Option, key_class: Option, load_refs: bool, @@ -140,6 +141,7 @@ pub struct ItemSearchOptions { trusted_only: Option, label: Option, service: Option, + subject: Option, account: Option, access_group: Option, pub_key_hash: Option, @@ -170,6 +172,13 @@ impl ItemSearchOptions { self } + /// Whether search for an item should be case insensitive or not. + #[inline(always)] + pub fn case_insensitive(&mut self, case_insensitive: Option) -> &mut Self { + self.case_insensitive = case_insensitive; + self + } + /// Search only for keys of the specified class. Also sets self.class to /// `ItemClass::key()`. #[inline(always)] @@ -232,6 +241,13 @@ impl ItemSearchOptions { self.service = Some(CFString::new(service)); self } + + /// Search for an item with exactly the given subject. + #[inline(always)] + pub fn subject(&mut self, subject: &str) -> &mut Self { + self.subject = Some(CFString::new(subject)); + self + } /// Search for an item with the given account. #[inline(always)] @@ -291,6 +307,13 @@ impl ItemSearchOptions { params.push((CFString::wrap_under_get_rule(kSecClass), class.to_value())); } + if let Some(case_insensitive) = self.case_insensitive { + params.push(( + CFString::wrap_under_get_rule(kSecMatchCaseInsensitive), + CFBoolean::from(case_insensitive).as_CFType() + )); + } + if let Some(key_class) = self.key_class { params.push((CFString::wrap_under_get_rule(kSecAttrKeyClass), key_class.to_value())); } @@ -343,6 +366,13 @@ impl ItemSearchOptions { service.as_CFType(), )); } + + if let Some(ref subject) = self.subject { + params.push(( + CFString::wrap_under_get_rule(kSecMatchSubjectWholeString), + subject.as_CFType(), + )); + } if let Some(ref account) = self.account { params.push((