From mboxrd@z Thu Jan  1 00:00:00 1970
Return-Path: <pdm-devel-bounces@lists.proxmox.com>
Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68])
	by lore.proxmox.com (Postfix) with ESMTPS id B8A1E1FF19E
	for <inbox@lore.proxmox.com>; Fri, 11 Apr 2025 15:44:51 +0200 (CEST)
Received: from firstgate.proxmox.com (localhost [127.0.0.1])
	by firstgate.proxmox.com (Proxmox) with ESMTP id 1D5BA1B3C9;
	Fri, 11 Apr 2025 15:44:44 +0200 (CEST)
From: Shannon Sterz <s.sterz@proxmox.com>
To: pdm-devel@lists.proxmox.com
Date: Fri, 11 Apr 2025 15:44:30 +0200
Message-Id: <20250411134435.269524-7-s.sterz@proxmox.com>
X-Mailer: git-send-email 2.39.5
In-Reply-To: <20250411134435.269524-1-s.sterz@proxmox.com>
References: <20250411134435.269524-1-s.sterz@proxmox.com>
MIME-Version: 1.0
X-SPAM-LEVEL: Spam detection results:  0
 AWL 0.018 Adjusted score from AWL reputation of From: address
 BAYES_00                 -1.9 Bayes spam probability is 0 to 1%
 DMARC_MISSING             0.1 Missing DMARC policy
 KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment
 SPF_HELO_NONE           0.001 SPF: HELO does not publish an SPF Record
 SPF_PASS               -0.001 SPF: sender matches SPF record
Subject: [pdm-devel] [PATCH proxmox v2 6/6] access-control: api: refactor
 extract_acl_node_data to be non-recursive
X-BeenThere: pdm-devel@lists.proxmox.com
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Proxmox Datacenter Manager development discussion
 <pdm-devel.lists.proxmox.com>
List-Unsubscribe: <https://lists.proxmox.com/cgi-bin/mailman/options/pdm-devel>, 
 <mailto:pdm-devel-request@lists.proxmox.com?subject=unsubscribe>
List-Archive: <http://lists.proxmox.com/pipermail/pdm-devel/>
List-Post: <mailto:pdm-devel@lists.proxmox.com>
List-Help: <mailto:pdm-devel-request@lists.proxmox.com?subject=help>
List-Subscribe: <https://lists.proxmox.com/cgi-bin/mailman/listinfo/pdm-devel>, 
 <mailto:pdm-devel-request@lists.proxmox.com?subject=subscribe>
Reply-To: Proxmox Datacenter Manager development discussion
 <pdm-devel@lists.proxmox.com>
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: 7bit
Errors-To: pdm-devel-bounces@lists.proxmox.com
Sender: "pdm-devel" <pdm-devel-bounces@lists.proxmox.com>

this should help reduce the memory foot print of this helper when
parsing deeply nested acl trees, as only one vector for return values
and no addtional stack frames are allocated.

Signed-off-by: Shannon Sterz <s.sterz@proxmox.com>
---
 proxmox-access-control/src/api.rs | 81 ++++++++++++++++---------------
 1 file changed, 43 insertions(+), 38 deletions(-)

diff --git a/proxmox-access-control/src/api.rs b/proxmox-access-control/src/api.rs
index bf3ffb21..0194d517 100644
--- a/proxmox-access-control/src/api.rs
+++ b/proxmox-access-control/src/api.rs
@@ -251,51 +251,56 @@ fn extract_acl_node_data(
         }
     }
 
-    let mut list = Vec::new();
-    let path_str = path.unwrap_or("/");
+    let mut to_return = Vec::new();
+    let mut nodes = vec![(path.unwrap_or("").to_string(), node)];
 
-    for (user, roles) in &node.users {
-        if let Some(auth_id_filter) = auth_id_filter {
-            if !user.is_token() || user.user() != auth_id_filter.user() {
-                continue;
+    while let Some((path, node)) = nodes.pop() {
+        let path_str = if path.is_empty() { "/" } else { &path };
+
+        for (user, roles) in &node.users {
+            if let Some(auth_id_filter) = auth_id_filter {
+                if !user.is_token() || user.user() != auth_id_filter.user() {
+                    continue;
+                }
+            }
+
+            for (role, propagate) in roles {
+                to_return.push(AclListItem {
+                    path: path_str.to_owned(),
+                    propagate: *propagate,
+                    ugid_type: AclUgidType::User,
+                    ugid: user.to_string(),
+                    roleid: role.to_string(),
+                });
             }
         }
 
-        for (role, propagate) in roles {
-            list.push(AclListItem {
-                path: path_str.to_owned(),
-                propagate: *propagate,
-                ugid_type: AclUgidType::User,
-                ugid: user.to_string(),
-                roleid: role.to_string(),
-            });
+        for (group, roles) in &node.groups {
+            if auth_id_filter.is_some() {
+                continue;
+            }
+
+            for (role, propagate) in roles {
+                to_return.push(AclListItem {
+                    path: path_str.to_owned(),
+                    propagate: *propagate,
+                    ugid_type: AclUgidType::Group,
+                    ugid: group.to_string(),
+                    roleid: role.to_string(),
+                });
+            }
+        }
+
+        if !exact {
+            nodes.extend(
+                node.children
+                    .iter()
+                    .map(|(comp, child)| (format!("{}/{comp}", path), child)),
+            );
         }
     }
 
-    for (group, roles) in &node.groups {
-        if auth_id_filter.is_some() {
-            continue;
-        }
-
-        for (role, propagate) in roles {
-            list.push(AclListItem {
-                path: path_str.to_owned(),
-                propagate: *propagate,
-                ugid_type: AclUgidType::Group,
-                ugid: group.to_string(),
-                roleid: role.to_string(),
-            });
-        }
-    }
-
-    if !exact {
-        list.extend(node.children.iter().flat_map(|(comp, child)| {
-            let new_path = format!("{}/{comp}", path.unwrap_or(""));
-            extract_acl_node_data(child, Some(&new_path), exact, auth_id_filter)
-        }));
-    }
-
-    list
+    to_return
 }
 
 pub const ACL_ROUTER: Router = Router::new()
-- 
2.39.5



_______________________________________________
pdm-devel mailing list
pdm-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pdm-devel