Blame SOURCES/0001-network-Update-VPN-empty-label-status-after-removing.patch

a780b2
From 3f089ddbd8cc304c563b4ed8cfbc59d27ffadc00 Mon Sep 17 00:00:00 2001
a780b2
From: Carlos Garnacho <carlosg@gnome.org>
a780b2
Date: Thu, 12 Dec 2019 22:43:15 +0100
a780b2
Subject: [PATCH] network: Update VPN empty label status after removing VPN
a780b2
 connection
a780b2
a780b2
Being the VPN list actually a collection of listboxes, this function
a780b2
ensures it looks alright in other places. However the case of removing
a780b2
all VPN connections till we're back empty was missed.
a780b2
---
a780b2
 panels/network/cc-network-panel.c | 29 +++++++++++++++++++++++++++++
a780b2
 1 file changed, 29 insertions(+)
a780b2
a780b2
diff --git a/panels/network/cc-network-panel.c b/panels/network/cc-network-panel.c
a780b2
index 1a072a65a..f08d9b939 100644
a780b2
--- a/panels/network/cc-network-panel.c
a780b2
+++ b/panels/network/cc-network-panel.c
a780b2
@@ -761,6 +761,33 @@ notify_connection_added_cb (NMClient           *client,
a780b2
         add_connection (panel, NM_CONNECTION (connection));
a780b2
 }
a780b2
 
a780b2
+static void
a780b2
+notify_connection_removed_cb (NMClient           *client,
a780b2
+                              NMRemoteConnection *connection,
a780b2
+                              CcNetworkPanel     *panel)
a780b2
+{
a780b2
+        guint i;
a780b2
+
a780b2
+        for (i = 0; i < panel->devices->len; i++) {
a780b2
+                NetObject *object = g_ptr_array_index (panel->devices, i);
a780b2
+                NMConnection *vpn_conn;
a780b2
+                gboolean equal;
a780b2
+
a780b2
+                if (!NET_IS_VPN (object))
a780b2
+                        continue;
a780b2
+
a780b2
+                g_object_get (object, "connection", &vpn_conn, NULL);
a780b2
+                equal = vpn_conn == NM_CONNECTION (connection);
a780b2
+                g_object_unref (vpn_conn);
a780b2
+
a780b2
+                if (equal) {
a780b2
+                        g_ptr_array_remove (panel->devices, object);
a780b2
+                        update_vpn_section (panel);
a780b2
+                        return;
a780b2
+                }
a780b2
+        }
a780b2
+}
a780b2
+
a780b2
 static void
a780b2
 panel_check_network_manager_version (CcNetworkPanel *panel)
a780b2
 {
a780b2
@@ -912,6 +939,8 @@ cc_network_panel_init (CcNetworkPanel *panel)
a780b2
         /* add remote settings such as VPN settings as virtual devices */
a780b2
         g_signal_connect (panel->client, NM_CLIENT_CONNECTION_ADDED,
a780b2
                           G_CALLBACK (notify_connection_added_cb), panel);
a780b2
+        g_signal_connect (panel->client, NM_CLIENT_CONNECTION_REMOVED,
a780b2
+                          G_CALLBACK (notify_connection_removed_cb), panel);
a780b2
 
a780b2
         toplevel = gtk_widget_get_toplevel (GTK_WIDGET (panel));
a780b2
         g_signal_connect_after (toplevel, "map", G_CALLBACK (on_toplevel_map), panel);
a780b2
-- 
a780b2
2.23.0
a780b2