use anyhow::{bail, Error};
use serde_json::Value;
+use ::serde::{Deserialize, Serialize};
use proxmox::api::{api, ApiMethod, Router, RpcEnvironment, Permission};
let (config, digest) = remote::config()?;
let value = config.convert_to_array("name", Some(&digest), &["password"]);
-
+
Ok(value.into())
}
.insert("digest".into(), proxmox::tools::digest_to_hex(&digest).into());
Ok(data)
}
+#[api()]
+#[derive(Serialize, Deserialize)]
+#[allow(non_camel_case_types)]
+/// Deletable property name
+pub enum DeletableProperty {
+ /// Delete the comment property.
+ comment,
+ /// Delete the fingerprint property.
+ fingerprint,
+}
#[api(
protected: true,
optional: true,
schema: CERT_FINGERPRINT_SHA256_SCHEMA,
},
+ delete: {
+ description: "List of properties to delete.",
+ type: Array,
+ optional: true,
+ items: {
+ type: DeletableProperty,
+ }
+ },
digest: {
optional: true,
schema: PROXMOX_CONFIG_DIGEST_SCHEMA,
userid: Option<String>,
password: Option<String>,
fingerprint: Option<String>,
+ delete: Option<Vec<DeletableProperty>>,
digest: Option<String>,
) -> Result<(), Error> {
let mut data: remote::Remote = config.lookup("remote", &name)?;
+ if let Some(delete) = delete {
+ for delete_prop in delete {
+ match delete_prop {
+ DeletableProperty::comment => { data.comment = None; },
+ DeletableProperty::fingerprint => { data.fingerprint = None; },
+ }
+ }
+ }
+
if let Some(comment) = comment {
let comment = comment.trim().to_string();
if comment.is_empty() {
if let Some(userid) = userid { data.userid = userid; }
if let Some(password) = password { data.password = password; }
- // fixme: howto delete a fingeprint?
if let Some(fingerprint) = fingerprint { data.fingerprint = Some(fingerprint); }
config.set_data(&name, "remote", &data)?;