add node/{node}/config api path
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
This commit is contained in:
parent
4088d5bc62
commit
09989d9963
|
@ -28,6 +28,7 @@ use crate::tools::ticket::{self, Empty, Ticket};
|
||||||
|
|
||||||
pub mod apt;
|
pub mod apt;
|
||||||
pub mod certificates;
|
pub mod certificates;
|
||||||
|
pub mod config;
|
||||||
pub mod disks;
|
pub mod disks;
|
||||||
pub mod dns;
|
pub mod dns;
|
||||||
pub mod network;
|
pub mod network;
|
||||||
|
@ -316,6 +317,7 @@ fn upgrade_to_websocket(
|
||||||
pub const SUBDIRS: SubdirMap = &[
|
pub const SUBDIRS: SubdirMap = &[
|
||||||
("apt", &apt::ROUTER),
|
("apt", &apt::ROUTER),
|
||||||
("certificates", &certificates::ROUTER),
|
("certificates", &certificates::ROUTER),
|
||||||
|
("config", &config::ROUTER),
|
||||||
("disks", &disks::ROUTER),
|
("disks", &disks::ROUTER),
|
||||||
("dns", &dns::ROUTER),
|
("dns", &dns::ROUTER),
|
||||||
("journal", &journal::ROUTER),
|
("journal", &journal::ROUTER),
|
||||||
|
|
|
@ -0,0 +1,80 @@
|
||||||
|
use anyhow::Error;
|
||||||
|
use serde_json::Value;
|
||||||
|
|
||||||
|
use proxmox::api::schema::Updatable;
|
||||||
|
use proxmox::api::{api, Permission, Router, RpcEnvironment};
|
||||||
|
|
||||||
|
use crate::api2::types::NODE_SCHEMA;
|
||||||
|
use crate::config::acl::PRIV_SYS_MODIFY;
|
||||||
|
use crate::config::node::NodeConfigUpdater;
|
||||||
|
|
||||||
|
pub const ROUTER: Router = Router::new()
|
||||||
|
.get(&API_METHOD_GET_NODE_CONFIG)
|
||||||
|
.put(&API_METHOD_UPDATE_NODE_CONFIG);
|
||||||
|
|
||||||
|
#[api(
|
||||||
|
input: {
|
||||||
|
properties: {
|
||||||
|
node: { schema: NODE_SCHEMA },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
access: {
|
||||||
|
permission: &Permission::Privilege(&["system"], PRIV_SYS_MODIFY, false),
|
||||||
|
},
|
||||||
|
)]
|
||||||
|
/// Create a new changer device.
|
||||||
|
pub fn get_node_config(mut rpcenv: &mut dyn RpcEnvironment) -> Result<Value, Error> {
|
||||||
|
let (config, digest) = crate::config::node::config()?;
|
||||||
|
rpcenv["digest"] = proxmox::tools::digest_to_hex(&digest).into();
|
||||||
|
Ok(serde_json::to_value(config)?)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[api(
|
||||||
|
input: {
|
||||||
|
properties: {
|
||||||
|
node: { schema: NODE_SCHEMA },
|
||||||
|
digest: {
|
||||||
|
description: "Digest to protect against concurrent updates",
|
||||||
|
optional: true,
|
||||||
|
},
|
||||||
|
updater: {
|
||||||
|
type: NodeConfigUpdater,
|
||||||
|
flatten: true,
|
||||||
|
},
|
||||||
|
delete: {
|
||||||
|
description: "Options to remove from the configuration",
|
||||||
|
optional: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
access: {
|
||||||
|
permission: &Permission::Privilege(&["system"], PRIV_SYS_MODIFY, false),
|
||||||
|
},
|
||||||
|
protected: true,
|
||||||
|
)]
|
||||||
|
/// Create a new changer device.
|
||||||
|
pub fn update_node_config(
|
||||||
|
updater: NodeConfigUpdater,
|
||||||
|
delete: Option<String>,
|
||||||
|
digest: Option<String>,
|
||||||
|
) -> Result<(), Error> {
|
||||||
|
let _lock = crate::config::node::lock()?;
|
||||||
|
let (mut config, expected_digest) = crate::config::node::config()?;
|
||||||
|
if let Some(digest) = digest {
|
||||||
|
// FIXME: GUI doesn't handle our non-inlined digest part here properly...
|
||||||
|
if !digest.is_empty() {
|
||||||
|
let digest = proxmox::tools::hex_to_digest(&digest)?;
|
||||||
|
crate::tools::detect_modified_configuration_file(&digest, &expected_digest)?;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let delete: Vec<&str> = delete
|
||||||
|
.as_deref()
|
||||||
|
.unwrap_or("")
|
||||||
|
.split(&[' ', ',', ';', '\0'][..])
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
config.update_from(updater, &delete)?;
|
||||||
|
|
||||||
|
crate::config::node::save_config(&config)
|
||||||
|
}
|
Loading…
Reference in New Issue