Blame SOURCES/firewalld-0.6.1-firewall.core.fw_nm-avoid-iterating-NM-devices-conne.patch

15ccd1
From 5f41f061390876f4c43c2306911d9b3482aed396 Mon Sep 17 00:00:00 2001
15ccd1
From: Lubomir Rintel <lkundrak@v3.sk>
15ccd1
Date: Mon, 16 Jul 2018 17:42:34 +0200
15ccd1
Subject: [PATCH 1/3] firewall.core.fw_nm: avoid iterating NM devices,
15ccd1
 connections
15ccd1
15ccd1
NetworkManager has an API to do the lookups.
15ccd1
15ccd1
(cherry picked from commit 65f92930a5d049404dac780c15eebe2d788e6285)
15ccd1
---
15ccd1
 src/firewall/core/fw_nm.py | 70 ++++++++++++++++++----------------------------
15ccd1
 1 file changed, 27 insertions(+), 43 deletions(-)
15ccd1
15ccd1
diff --git a/src/firewall/core/fw_nm.py b/src/firewall/core/fw_nm.py
15ccd1
index f75733fe65f6..76901cee2adf 100644
15ccd1
--- a/src/firewall/core/fw_nm.py
15ccd1
+++ b/src/firewall/core/fw_nm.py
15ccd1
@@ -73,22 +73,18 @@ def nm_get_zone_of_connection(connection):
15ccd1
     """
15ccd1
     check_nm_imported()
15ccd1
 
15ccd1
-    active_connections = nm_get_client().get_active_connections()
15ccd1
+    con = nm_get_client().get_connection_by_id(connection)
15ccd1
+    if con is None:
15ccd1
+        return False
15ccd1
 
15ccd1
-    for active_con in active_connections:
15ccd1
-        if active_con.get_id() == connection:
15ccd1
-            con = active_con.get_connection()
15ccd1
-            if con is None:
15ccd1
-                continue
15ccd1
-            setting_con = con.get_setting_connection()
15ccd1
-            if setting_con is None:
15ccd1
-                continue
15ccd1
-            zone = setting_con.get_zone()
15ccd1
-            if zone is None:
15ccd1
-                zone = ""
15ccd1
-            return zone
15ccd1
+    setting_con = con.get_setting_connection()
15ccd1
+    if setting_con is None:
15ccd1
+        return False
15ccd1
 
15ccd1
-    return None
15ccd1
+    zone = setting_con.get_zone()
15ccd1
+    if zone is None:
15ccd1
+        zone = ""
15ccd1
+    return zone
15ccd1
 
15ccd1
 def nm_set_zone_of_connection(zone, connection):
15ccd1
     """Set the zone for a connection
15ccd1
@@ -98,24 +94,18 @@ def nm_set_zone_of_connection(zone, connection):
15ccd1
     """
15ccd1
     check_nm_imported()
15ccd1
 
15ccd1
-    active_connections = nm_get_client().get_active_connections()
15ccd1
-
15ccd1
-    for active_con in active_connections:
15ccd1
-        con = active_con.get_connection()
15ccd1
-        if con is None:
15ccd1
-            continue
15ccd1
+    con = nm_get_client().get_connection_by_id(connection)
15ccd1
+    if con is None:
15ccd1
+        return False
15ccd1
 
15ccd1
-        if active_con.get_id() == connection:
15ccd1
-            setting_con = con.get_setting_connection()
15ccd1
-            if setting_con is None:
15ccd1
-                continue
15ccd1
-            if zone == "":
15ccd1
-                zone = None
15ccd1
-            setting_con.set_property("zone", zone)
15ccd1
-            con.commit_changes(True, None)
15ccd1
-            return True
15ccd1
+    setting_con = con.get_setting_connection()
15ccd1
+    if setting_con is None:
15ccd1
+        return False
15ccd1
 
15ccd1
-    return False
15ccd1
+    if zone == "":
15ccd1
+        zone = None
15ccd1
+    setting_con.set_property("zone", zone)
15ccd1
+    return con.commit_changes(True, None)
15ccd1
 
15ccd1
 def nm_get_connections(connections, connections_uuid):
15ccd1
     """Get active connections from NM
15ccd1
@@ -150,21 +140,15 @@ def nm_get_connection_of_interface(interface):
15ccd1
     """
15ccd1
     check_nm_imported()
15ccd1
 
15ccd1
-    active_connections = nm_get_client().get_active_connections()
15ccd1
-
15ccd1
-    for active_con in active_connections:
15ccd1
-        # ignore vpn devices for now
15ccd1
-        if active_con.get_vpn():
15ccd1
-            continue
15ccd1
-
15ccd1
-        devices = active_con.get_devices()
15ccd1
-
15ccd1
-        for dev in devices:
15ccd1
-            if dev.get_iface() == interface:
15ccd1
-                return active_con.get_id()
15ccd1
+    device = nm_get_client().get_device_by_iface(interface)
15ccd1
+    if device is None:
15ccd1
+        return None
15ccd1
 
15ccd1
+    active_con = device.get_active_connection()
15ccd1
+    if active_con is None:
15ccd1
+        return None
15ccd1
 
15ccd1
-    return None
15ccd1
+    return active_con.get_id()
15ccd1
 
15ccd1
 def nm_get_bus_name():
15ccd1
     if not _nm_imported:
15ccd1
-- 
15ccd1
2.16.3
15ccd1