|
|
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 |
|