[network-manager-applet/nma-1-0: 15/18] editor: remove "Always ask for this password every time" checkbox



commit 657904ffe88609100b272d32e9c61cb31e1d3370
Author: Jiří Klimeš <jklimes redhat com>
Date:   Mon Apr 20 18:07:19 2015 +0200

    editor: remove "Always ask for this password every time" checkbox
    
    The functionality is replaced by the corresponding menu item in password entry
    storage menu.

 src/wireless-security/eap-method-simple.c  |   99 ++++++++++++----------------
 src/wireless-security/eap-method-simple.ui |   18 +-----
 2 files changed, 43 insertions(+), 74 deletions(-)
---
diff --git a/src/wireless-security/eap-method-simple.c b/src/wireless-security/eap-method-simple.c
index 666086c..9402254 100644
--- a/src/wireless-security/eap-method-simple.c
+++ b/src/wireless-security/eap-method-simple.c
@@ -40,8 +40,8 @@ struct _EAPMethodSimple {
 
        GtkEntry *username_entry;
        GtkEntry *password_entry;
-       GtkToggleButton *always_ask;
        GtkToggleButton *show_password;
+       guint idle_func_id;
 };
 
 static void
@@ -54,6 +54,13 @@ show_toggled_cb (GtkToggleButton *button, EAPMethodSimple *method)
 }
 
 static gboolean
+always_ask_selected (GtkEntry *passwd_entry)
+{
+       return !!(  nma_utils_menu_to_secret_flags (GTK_WIDGET (passwd_entry))
+                 & NM_SETTING_SECRET_FLAG_NOT_SAVED);
+}
+
+static gboolean
 validate (EAPMethod *parent)
 {
        EAPMethodSimple *method = (EAPMethodSimple *)parent;
@@ -64,7 +71,7 @@ validate (EAPMethod *parent)
                return FALSE;
 
        /* Check if the password should always be requested */
-       if (gtk_toggle_button_get_active (method->always_ask))
+       if (always_ask_selected (method->password_entry))
                return TRUE;
 
        text = gtk_entry_get_text (method->password_entry);
@@ -110,7 +117,7 @@ fill_connection (EAPMethod *parent, NMConnection *connection, NMSettingSecretFla
        EAPMethodSimple *method = (EAPMethodSimple *) parent;
        NMSetting8021x *s_8021x;
        gboolean not_saved = FALSE;
-       NMSettingSecretFlags flags = prev_flags;
+       NMSettingSecretFlags flags;
        const EapType *eap_type;
 
        s_8021x = nm_connection_get_setting_802_1x (connection);
@@ -142,11 +149,8 @@ fill_connection (EAPMethod *parent, NMConnection *connection, NMSettingSecretFla
        g_object_set (s_8021x, NM_SETTING_802_1X_IDENTITY, gtk_entry_get_text (method->username_entry), NULL);
 
        /* Save the password always ask setting */
-       not_saved = gtk_toggle_button_get_active (method->always_ask);
-
-       flags &= ~(NM_SETTING_SECRET_FLAG_NOT_SAVED);
-       if (not_saved)
-               flags |= NM_SETTING_SECRET_FLAG_NOT_SAVED;
+       not_saved = always_ask_selected (method->password_entry);
+       flags = nma_utils_menu_to_secret_flags (GTK_WIDGET (method->password_entry));
        nm_setting_set_secret_flags (NM_SETTING (s_8021x), NM_SETTING_802_1X_PASSWORD, flags, NULL);
 
        /* Fill the connection's password if we're in the applet so that it'll get
@@ -177,43 +181,35 @@ update_secrets (EAPMethod *parent, NMConnection *connection)
                                  (HelperSecretFunc) nm_setting_802_1x_get_password);
 }
 
-static void
-g_free_str0 (gpointer mem)
+static gboolean
+stuff_changed (EAPMethodSimple *method)
 {
-       /* g_free a char pointer and set it to 0 before (for passwords). */
-       if (mem) {
-               char *p = mem;
-               memset (p, 0, strlen (p));
-               g_free (p);
-       }
+       wireless_security_changed_cb (NULL, method->ws_parent);
+       method->idle_func_id = 0;
+       return FALSE;
 }
 
 static void
-password_always_ask_changed (GtkToggleButton *button, EAPMethodSimple *method)
+password_storage_changed (GObject *entry,
+                          GParamSpec *pspec,
+                          EAPMethodSimple *method)
 {
-       char *password;
        gboolean always_ask;
+       gboolean secrets_only = method->flags & EAP_METHOD_SIMPLE_FLAG_SECRETS_ONLY;
 
-       always_ask = gtk_toggle_button_get_active (button);
-
-       if (always_ask) {
-               password = g_strdup (gtk_entry_get_text (method->password_entry));
-               gtk_entry_set_text (method->password_entry, "");
-               g_object_set_data_full (G_OBJECT (method->password_entry), "password-old", password, 
g_free_str0);
-       } else {
-               password = g_object_get_data (G_OBJECT (method->password_entry), "password-old");
-               gtk_entry_set_text (method->password_entry, password ? password : "");
-               g_object_set_data(G_OBJECT (method->password_entry), "password-old", NULL);
-       }
+       always_ask = always_ask_selected (method->password_entry);
 
-       if (always_ask) {
+       if (always_ask && !secrets_only) {
                /* we always clear this button and do not restore it
                 * (because we want to hide the password). */
                gtk_toggle_button_set_active (method->show_password, FALSE);
        }
 
-       gtk_widget_set_sensitive (GTK_WIDGET (method->password_entry), !always_ask);
-       gtk_widget_set_sensitive (GTK_WIDGET (method->show_password), !always_ask);
+       gtk_widget_set_sensitive (GTK_WIDGET (method->show_password),
+                                 !always_ask || secrets_only);
+
+       if (!method->idle_func_id)
+               method->idle_func_id = g_idle_add ((GSourceFunc) stuff_changed, method);
 }
 
 /* Set the UI fields for user, password, always_ask and show_password to the
@@ -231,7 +227,6 @@ set_userpass_ui (EAPMethodSimple *method)
        else
                gtk_entry_set_text (method->password_entry, "");
 
-       gtk_toggle_button_set_active (method->always_ask, method->ws_parent->always_ask);
        gtk_toggle_button_set_active (method->show_password, method->ws_parent->show_password);
 }
 
@@ -247,11 +242,8 @@ widgets_unrealized (GtkWidget *widget, EAPMethodSimple *method)
        wireless_security_set_userpass (method->ws_parent,
                                        gtk_entry_get_text (method->username_entry),
                                        gtk_entry_get_text (method->password_entry),
-                                       gtk_toggle_button_get_active (method->always_ask),
+                                       always_ask_selected (method->password_entry),
                                        gtk_toggle_button_get_active (method->show_password));
-
-       /* clear the remembered password. If the user changes the scheme, it's gone. */
-       g_object_set_data(G_OBJECT (method->password_entry), "password-old", NULL);
 }
 
 static void
@@ -270,6 +262,16 @@ destroy (EAPMethod *parent)
                                              (GCallback) widgets_unrealized,
                                              method);
 
+       widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_simple_password_entry"));
+       g_assert (widget);
+       g_signal_handlers_disconnect_by_func (G_OBJECT (widget),
+                                             (GCallback) password_storage_changed,
+                                             method);
+       if (method->idle_func_id > 0) {
+               g_source_remove (method->idle_func_id);
+               method->idle_func_id = 0;
+       }
+
        wireless_security_unref (method->ws_parent);
 }
 
@@ -335,26 +337,9 @@ eap_method_simple_new (WirelessSecurity *ws_parent,
                s_8021x = nm_connection_get_setting_802_1x (connection);
        nma_utils_setup_password_storage (widget, 0, (NMSetting *) s_8021x, parent->password_flags_name, 
FALSE);
 
-       widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_password_always_ask"));
-       g_assert (widget);
-       method->always_ask = GTK_TOGGLE_BUTTON (widget);
-       g_signal_connect (G_OBJECT (widget), "toggled",
-                         (GCallback) wireless_security_changed_cb,
-                         ws_parent);
-       if (flags & EAP_METHOD_SIMPLE_FLAG_IS_EDITOR) {
-               /* We only desensitize the password entry from the editor, because
-                * from nm-applet if the entry was desensitized, there'd be no way to
-                * get the password back to NetworkManager when NM asked for it.  Since
-                * the editor only sets up the initial connection though, it's safe to
-                * do there.
-                */
-               g_signal_connect (G_OBJECT (widget), "toggled",
-                                 G_CALLBACK (password_always_ask_changed),
-                                 method);
-       }
-
-       if (flags & EAP_METHOD_SIMPLE_FLAG_SECRETS_ONLY)
-               gtk_widget_hide (widget);
+       g_signal_connect (method->password_entry, "notify::secondary-icon-name",
+                         G_CALLBACK (password_storage_changed),
+                         method);
 
        widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "show_checkbutton_eapsimple"));
        g_assert (widget);
diff --git a/src/wireless-security/eap-method-simple.ui b/src/wireless-security/eap-method-simple.ui
index b449ba1..0a1d8ed 100644
--- a/src/wireless-security/eap-method-simple.ui
+++ b/src/wireless-security/eap-method-simple.ui
@@ -84,22 +84,6 @@
                 <property name="visible">True</property>
                 <property name="can_focus">False</property>
                 <child>
-                  <object class="GtkCheckButton" id="eap_password_always_ask">
-                    <property name="label" translatable="yes">As_k for this password every time</property>
-                    <property name="visible">True</property>
-                    <property name="can_focus">True</property>
-                    <property name="receives_default">False</property>
-                    <property name="use_underline">True</property>
-                    <property name="xalign">0</property>
-                    <property name="draw_indicator">True</property>
-                  </object>
-                  <packing>
-                    <property name="expand">True</property>
-                    <property name="fill">True</property>
-                    <property name="position">0</property>
-                  </packing>
-                </child>
-                <child>
                   <object class="GtkCheckButton" id="show_checkbutton_eapsimple">
                     <property name="label" translatable="yes">Sho_w password</property>
                     <property name="visible">True</property>
@@ -112,7 +96,7 @@
                   <packing>
                     <property name="expand">True</property>
                     <property name="fill">True</property>
-                    <property name="position">1</property>
+                    <property name="position">0</property>
                   </packing>
                 </child>
                 <child>


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]