don't call contains_key() before remove()

HashMap::remove() returns the value it removes as an Option<>, so
instead of first checking if the key exists before removing it, just
try to remove it and use the returned Option<> to test whether we
should bail!().

Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
This commit is contained in:
Wolfgang Bumiller 2024-06-28 09:33:23 +02:00
parent f4130d531f
commit 42c6224f92
4 changed files with 5 additions and 15 deletions

View File

@ -371,9 +371,7 @@ pub fn delete_user(userid: Userid, digest: Option<String>) -> Result<(), Error>
crate::tools::detect_modified_configuration_file(&digest, &expected_digest)?;
}
if config.sections.contains_key(userid.as_str()) {
config.sections.remove(userid.as_str());
} else {
if config.sections.remove(userid.as_str()).is_none() {
bail!("user '{}' does not exist.", userid);
}
@ -649,9 +647,7 @@ pub fn delete_token(
let tokenid = Authid::from((userid.clone(), Some(token_name.clone())));
let tokenid_string = tokenid.to_string();
if config.sections.contains_key(&tokenid_string) {
config.sections.remove(&tokenid_string);
} else {
if config.sections.remove(&tokenid_string).is_none() {
bail!(
"token '{}' of user '{}' does not exist.",
token_name.as_str(),

View File

@ -225,9 +225,7 @@ pub fn delete_pool(name: String) -> Result<(), Error> {
let (mut config, _digest) = pbs_config::media_pool::config()?;
if config.sections.contains_key(&name) {
config.sections.remove(&name);
} else {
if config.sections.remove(&name).is_none() {
http_bail!(NOT_FOUND, "delete pool '{}' failed - no such pool", name);
}

View File

@ -288,9 +288,7 @@ pub fn delete_remote(name: String, digest: Option<String>) -> Result<(), Error>
crate::tools::detect_modified_configuration_file(&digest, &expected_digest)?;
}
if config.sections.contains_key(&name) {
config.sections.remove(&name);
} else {
if config.sections.remove(&name).is_none() {
http_bail!(NOT_FOUND, "remote '{}' does not exist.", name);
}

View File

@ -258,9 +258,7 @@ pub fn delete_traffic_control(name: String, digest: Option<String>) -> Result<()
crate::tools::detect_modified_configuration_file(&digest, &expected_digest)?;
}
if config.sections.contains_key(&name) {
config.sections.remove(&name);
} else {
if config.sections.remove(&name).is_none() {
http_bail!(NOT_FOUND, "traffic control rule '{}' does not exist.", name);
}