[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