From 0887a7afc51e178f28feddc0c1f3612626e97805 Mon Sep 17 00:00:00 2001 From: Pavel Hrdina Date: Wed, 9 Sep 2020 16:43:32 +0200 Subject: [PATCH] src/network/bridge_driver: convert to use GLib DBus Signed-off-by: Pavel Hrdina Reviewed-by: Michal Privoznik --- src/network/bridge_driver.c | 81 ++++++++++++++++++------------------- src/network/meson.build | 2 - 2 files changed, 39 insertions(+), 44 deletions(-) diff --git a/src/network/bridge_driver.c b/src/network/bridge_driver.c index 87d7acab06..5d9b9eaa4f 100644 --- a/src/network/bridge_driver.c +++ b/src/network/bridge_driver.c @@ -59,7 +59,7 @@ #include "virnetdevtap.h" #include "virnetdevvportprofile.h" #include "virpci.h" -#include "virdbus.h" +#include "virgdbus.h" #include "virfile.h" #include "virstring.h" #include "viraccessapicheck.h" @@ -638,33 +638,29 @@ networkAutostartConfig(virNetworkObjPtr obj, #ifdef WITH_FIREWALLD -static DBusHandlerResult -firewalld_dbus_filter_bridge(DBusConnection *connection G_GNUC_UNUSED, - DBusMessage *message, - void *user_data) +static void +firewalld_dbus_signal_callback(GDBusConnection *connection G_GNUC_UNUSED, + const char *senderName G_GNUC_UNUSED, + const char *objectPath G_GNUC_UNUSED, + const char *interfaceName, + const char *signalName, + GVariant *parameters, + gpointer user_data) { virNetworkDriverStatePtr driver = user_data; bool reload = false; - if (dbus_message_is_signal(message, - "org.fedoraproject.FirewallD1", "Reloaded")) { + if (STREQ(interfaceName, "org.fedoraproject.FirewallD1") && + STREQ(signalName, "Reloaded")) { reload = true; + } else if (STREQ(interfaceName, "org.freedesktop.DBus") && + STREQ(signalName, "NameOwnerChanged")) { + char *name = NULL; + char *old_owner = NULL; + char *new_owner = NULL; - } else if (dbus_message_is_signal(message, - DBUS_INTERFACE_DBUS, "NameOwnerChanged")) { + g_variant_get(parameters, "(&s&s&s)", &name, &old_owner, &new_owner); - g_autofree char *name = NULL; - g_autofree char *old_owner = NULL; - g_autofree char *new_owner = NULL; - - if (virDBusMessageDecode(message, "sss", &name, &old_owner, &new_owner) < 0) { - VIR_WARN("Failed to decode DBus NameOwnerChanged message"); - return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; - } - /* - * if new_owner is empty, firewalld is shutting down. If it is - * non-empty, then it is starting - */ if (new_owner && *new_owner) reload = true; } @@ -673,8 +669,6 @@ firewalld_dbus_filter_bridge(DBusConnection *connection G_GNUC_UNUSED, VIR_DEBUG("Reload in bridge_driver because of firewalld."); networkReloadFirewallRules(driver, false, true); } - - return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } #endif @@ -694,7 +688,7 @@ networkStateInitialize(bool privileged, g_autofree char *rundir = NULL; bool autostart = true; #ifdef WITH_FIREWALLD - DBusConnection *sysbus = NULL; + GDBusConnection *sysbus = NULL; #endif if (root != NULL) { @@ -793,27 +787,30 @@ networkStateInitialize(bool privileged, network_driver->networkEventState = virObjectEventStateNew(); #ifdef WITH_FIREWALLD - if (!(sysbus = virDBusGetSystemBus())) { + if (!(sysbus = virGDBusGetSystemBus())) { VIR_WARN("DBus not available, disabling firewalld support " "in bridge_network_driver: %s", virGetLastErrorMessage()); } else { - /* add matches for - * NameOwnerChanged on org.freedesktop.DBus for firewalld start/stop - * Reloaded on org.fedoraproject.FirewallD1 for firewalld reload - */ - dbus_bus_add_match(sysbus, - "type='signal'" - ",interface='"DBUS_INTERFACE_DBUS"'" - ",member='NameOwnerChanged'" - ",arg0='org.fedoraproject.FirewallD1'", - NULL); - dbus_bus_add_match(sysbus, - "type='signal'" - ",interface='org.fedoraproject.FirewallD1'" - ",member='Reloaded'", - NULL); - dbus_connection_add_filter(sysbus, firewalld_dbus_filter_bridge, - network_driver, NULL); + g_dbus_connection_signal_subscribe(sysbus, + NULL, + "org.freedesktop.DBus", + "NameOwnerChanged", + NULL, + "org.fedoraproject.FirewallD1", + G_DBUS_SIGNAL_FLAGS_NONE, + firewalld_dbus_signal_callback, + network_driver, + NULL); + g_dbus_connection_signal_subscribe(sysbus, + NULL, + "org.fedoraproject.FirewallD1", + "Reloaded", + NULL, + NULL, + G_DBUS_SIGNAL_FLAGS_NONE, + firewalld_dbus_signal_callback, + network_driver, + NULL); } #endif diff --git a/src/network/meson.build b/src/network/meson.build index ae2848697a..13dd2c26b2 100644 --- a/src/network/meson.build +++ b/src/network/meson.build @@ -18,7 +18,6 @@ if conf.has('WITH_NETWORK') ], dependencies: [ access_dep, - dbus_dep, libnl_dep, src_dep, ], @@ -30,7 +29,6 @@ if conf.has('WITH_NETWORK') virt_modules += { 'name': 'virt_driver_network', 'deps': [ - dbus_dep, libnl_dep, ], 'link_whole': [