[pdm-devel] [PATCH datacenter-manager 1/5] server: api: add nodes config api
Dominik Csapak
d.csapak at proxmox.com
Fri Nov 28 11:18:22 CET 2025
just GET for now
Signed-off-by: Dominik Csapak <d.csapak at proxmox.com>
---
server/src/api/pve/node.rs | 22 +++++++++++++++++++++-
1 file changed, 21 insertions(+), 1 deletion(-)
diff --git a/server/src/api/pve/node.rs b/server/src/api/pve/node.rs
index 47bd5b31..1f2d889b 100644
--- a/server/src/api/pve/node.rs
+++ b/server/src/api/pve/node.rs
@@ -5,7 +5,7 @@ use proxmox_schema::api;
use proxmox_sortable_macro::sortable;
use pdm_api_types::{remotes::REMOTE_ID_SCHEMA, NODE_SCHEMA, PRIV_RESOURCE_AUDIT};
-use pve_api_types::StorageContent;
+use pve_api_types::{NodeConfig, StorageContent};
use crate::api::pve::storage;
@@ -29,6 +29,7 @@ const SUBDIRS: SubdirMap = &sorted!([
),
("storage", &STORAGE_ROUTER),
("status", &Router::new().get(&API_METHOD_GET_STATUS)),
+ ("config", &Router::new().get(&API_METHOD_GET_CONFIG))
]);
const STORAGE_ROUTER: Router = Router::new()
@@ -138,3 +139,22 @@ async fn get_status(remote: String, node: String) -> Result<pve_api_types::NodeS
let result = client.node_status(&node).await?;
Ok(result)
}
+
+#[api(
+ input: {
+ properties: {
+ remote: { schema: REMOTE_ID_SCHEMA },
+ node: { schema: NODE_SCHEMA },
+ },
+ },
+ access: {
+ permission: &Permission::Privilege(&["resource", "{remote}", "node", "{node}"], PRIV_RESOURCE_AUDIT, false),
+ },
+)]
+/// Get config for the node.
+async fn get_config(remote: String, node: String) -> Result<NodeConfig, Error> {
+ let (remotes, _) = pdm_config::remotes::config()?;
+ let client = super::connect_to_remote(&remotes, &remote)?;
+ let result = client.node_config(&node, None).await?;
+ Ok(result)
+}
--
2.47.3
More information about the pdm-devel
mailing list