Blame src/wireless-security/eap-method-ttls.c

Packit Service d328f3
// SPDX-License-Identifier: GPL-2.0+
Packit Service d328f3
/* NetworkManager Applet -- allow user control over networking
Packit Service d328f3
 *
Packit Service d328f3
 * Dan Williams <dcbw@redhat.com>
Packit Service d328f3
 *
Packit Service d328f3
 * Copyright 2007 - 2017 Red Hat, Inc.
Packit Service d328f3
 */
Packit Service d328f3
Packit Service d328f3
#include "nm-default.h"
Packit Service d328f3
Packit Service d328f3
#include <ctype.h>
Packit Service d328f3
#include <string.h>
Packit Service d328f3
Packit Service d328f3
#include "eap-method.h"
Packit Service d328f3
#include "wireless-security.h"
Packit Service d328f3
#include "nma-cert-chooser.h"
Packit Service d328f3
#include "utils.h"
Packit Service d328f3
Packit Service d328f3
#define I_NAME_COLUMN   0
Packit Service d328f3
#define I_METHOD_COLUMN 1
Packit Service d328f3
Packit Service d328f3
struct _EAPMethodTTLS {
Packit Service d328f3
	EAPMethod parent;
Packit Service d328f3
Packit Service d328f3
	const char *password_flags_name;
Packit Service d328f3
	GtkSizeGroup *size_group;
Packit Service d328f3
	WirelessSecurity *sec_parent;
Packit Service d328f3
	gboolean is_editor;
Packit Service d328f3
Packit Service d328f3
        GtkWidget *ca_cert_chooser;
Packit Service d328f3
};
Packit Service d328f3
Packit Service d328f3
static void
Packit Service d328f3
destroy (EAPMethod *parent)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethodTTLS *method = (EAPMethodTTLS *) parent;
Packit Service d328f3
Packit Service d328f3
	if (method->size_group)
Packit Service d328f3
		g_object_unref (method->size_group);
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static gboolean
Packit Service d328f3
validate (EAPMethod *parent, GError **error)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethodTTLS *method = (EAPMethodTTLS *) parent;
Packit Service d328f3
	GtkWidget *widget;
Packit Service d328f3
	GtkTreeModel *model;
Packit Service d328f3
	GtkTreeIter iter;
Packit Service d328f3
	EAPMethod *eap = NULL;
Packit Service d328f3
	gboolean valid = FALSE;
Packit Service d328f3
Packit Service d328f3
	if (   gtk_widget_get_sensitive (method->ca_cert_chooser)
Packit Service d328f3
	    && !nma_cert_chooser_validate (NMA_CERT_CHOOSER (method->ca_cert_chooser), error))
Packit Service d328f3
		return FALSE;
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_combo"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
Packit Service d328f3
	model = gtk_combo_box_get_model (GTK_COMBO_BOX (widget));
Packit Service d328f3
	gtk_combo_box_get_active_iter (GTK_COMBO_BOX (widget), &iter);
Packit Service d328f3
	gtk_tree_model_get (model, &iter, I_METHOD_COLUMN, &eap, -1);
Packit Service d328f3
	g_assert (eap);
Packit Service d328f3
	valid = eap_method_validate (eap, error);
Packit Service d328f3
	eap_method_unref (eap);
Packit Service d328f3
	return valid;
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static void
Packit Service d328f3
ca_cert_not_required_toggled (GtkWidget *button, gpointer user_data)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethodTTLS *method = (EAPMethodTTLS *) user_data;
Packit Service d328f3
Packit Service d328f3
	gtk_widget_set_sensitive (method->ca_cert_chooser,
Packit Service d328f3
	                          !gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (button)));
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static void
Packit Service d328f3
add_to_size_group (EAPMethod *parent, GtkSizeGroup *group)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethodTTLS *method = (EAPMethodTTLS *) parent;
Packit Service d328f3
	GtkWidget *widget;
Packit Service d328f3
	GtkTreeModel *model;
Packit Service d328f3
	GtkTreeIter iter;
Packit Service d328f3
	EAPMethod *eap;
Packit Service d328f3
Packit Service d328f3
	if (method->size_group)
Packit Service d328f3
		g_object_unref (method->size_group);
Packit Service d328f3
	method->size_group = g_object_ref (group);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_anon_identity_label"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
	gtk_size_group_add_widget (group, widget);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_domain_label"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
	gtk_size_group_add_widget (group, widget);
Packit Service d328f3
Packit Service d328f3
	nma_cert_chooser_add_to_size_group (NMA_CERT_CHOOSER (method->ca_cert_chooser), group);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_label"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
	gtk_size_group_add_widget (group, widget);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_combo"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
Packit Service d328f3
	model = gtk_combo_box_get_model (GTK_COMBO_BOX (widget));
Packit Service d328f3
	gtk_combo_box_get_active_iter (GTK_COMBO_BOX (widget), &iter);
Packit Service d328f3
	gtk_tree_model_get (model, &iter, I_METHOD_COLUMN, &eap, -1);
Packit Service d328f3
	g_assert (eap);
Packit Service d328f3
	eap_method_add_to_size_group (eap, group);
Packit Service d328f3
	eap_method_unref (eap);
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static void
Packit Service d328f3
fill_connection (EAPMethod *parent, NMConnection *connection)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethodTTLS *method = (EAPMethodTTLS *) parent;
Packit Service d328f3
	NMSetting8021x *s_8021x;
Packit Service d328f3
	NMSetting8021xCKFormat format = NM_SETTING_802_1X_CK_FORMAT_UNKNOWN;
Packit Service d328f3
	NMSettingSecretFlags secret_flags;
Packit Service d328f3
	GtkWidget *widget;
Packit Service d328f3
	const char *text;
Packit Service d328f3
	char *value = NULL;
Packit Service d328f3
	EAPMethod *eap = NULL;
Packit Service d328f3
	GtkTreeModel *model;
Packit Service d328f3
	GtkTreeIter iter;
Packit Service d328f3
	GError *error = NULL;
Packit Service d328f3
	NMSetting8021xCKScheme scheme = NM_SETTING_802_1X_CK_SCHEME_UNKNOWN;
Packit Service d328f3
	gboolean ca_cert_error = FALSE;
Packit Service d328f3
Packit Service d328f3
	s_8021x = nm_connection_get_setting_802_1x (connection);
Packit Service d328f3
	g_assert (s_8021x);
Packit Service d328f3
Packit Service d328f3
	nm_setting_802_1x_add_eap_method (s_8021x, "ttls");
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_anon_identity_entry"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
	text = gtk_entry_get_text (GTK_ENTRY (widget));
Packit Service d328f3
	if (text && strlen (text))
Packit Service d328f3
		g_object_set (s_8021x, NM_SETTING_802_1X_ANONYMOUS_IDENTITY, text, NULL);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_domain_entry"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
	text = gtk_entry_get_text (GTK_ENTRY (widget));
Packit Service d328f3
	if (text && strlen (text))
Packit Service d328f3
		g_object_set (s_8021x, NM_SETTING_802_1X_DOMAIN_SUFFIX_MATCH, text, NULL);
Packit Service d328f3
Packit Service d328f3
	/* Save CA certificate PIN and its flags to the connection */
Packit Service d328f3
	secret_flags = nma_cert_chooser_get_cert_password_flags (NMA_CERT_CHOOSER (method->ca_cert_chooser));
Packit Service d328f3
	nm_setting_set_secret_flags (NM_SETTING (s_8021x), NM_SETTING_802_1X_CA_CERT_PASSWORD,
Packit Service d328f3
	                             secret_flags, NULL);
Packit Service d328f3
	if (method->is_editor) {
Packit Service d328f3
		/* Update secret flags and popup when editing the connection */
Packit Service d328f3
		nma_cert_chooser_update_cert_password_storage (NMA_CERT_CHOOSER (method->ca_cert_chooser),
Packit Service d328f3
		                                               secret_flags, NM_SETTING (s_8021x),
Packit Service d328f3
		                                               NM_SETTING_802_1X_CA_CERT_PASSWORD);
Packit Service d328f3
		g_object_set (s_8021x, NM_SETTING_802_1X_CA_CERT_PASSWORD,
Packit Service d328f3
		              nma_cert_chooser_get_cert_password (NMA_CERT_CHOOSER (method->ca_cert_chooser)),
Packit Service d328f3
		              NULL);
Packit Service d328f3
	}
Packit Service d328f3
Packit Service d328f3
	/* TLS CA certificate */
Packit Service d328f3
	if (gtk_widget_get_sensitive (method->ca_cert_chooser))
Packit Service d328f3
		value = nma_cert_chooser_get_cert (NMA_CERT_CHOOSER (method->ca_cert_chooser), &scheme);
Packit Service d328f3
	format = NM_SETTING_802_1X_CK_FORMAT_UNKNOWN;
Packit Service d328f3
	if (!nm_setting_802_1x_set_ca_cert (s_8021x, value, scheme, &format, &error)) {
Packit Service d328f3
		g_warning ("Couldn't read CA certificate '%s': %s", value, error ? error->message : "(unknown)");
Packit Service d328f3
		g_clear_error (&error);
Packit Service d328f3
		ca_cert_error = TRUE;
Packit Service d328f3
	}
Packit Service d328f3
	eap_method_ca_cert_ignore_set (parent, connection, value, ca_cert_error);
Packit Service d328f3
	g_free (value);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_combo"));
Packit Service d328f3
	model = gtk_combo_box_get_model (GTK_COMBO_BOX (widget));
Packit Service d328f3
	gtk_combo_box_get_active_iter (GTK_COMBO_BOX (widget), &iter);
Packit Service d328f3
	gtk_tree_model_get (model, &iter, I_METHOD_COLUMN, &eap, -1);
Packit Service d328f3
	g_assert (eap);
Packit Service d328f3
Packit Service d328f3
	eap_method_fill_connection (eap, connection);
Packit Service d328f3
	eap_method_unref (eap);
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static void
Packit Service d328f3
inner_auth_combo_changed_cb (GtkWidget *combo, gpointer user_data)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethod *parent = (EAPMethod *) user_data;
Packit Service d328f3
	EAPMethodTTLS *method = (EAPMethodTTLS *) parent;
Packit Service d328f3
	GtkWidget *vbox;
Packit Service d328f3
	EAPMethod *eap = NULL;
Packit Service d328f3
	GList *elt, *children;
Packit Service d328f3
	GtkTreeModel *model;
Packit Service d328f3
	GtkTreeIter iter;
Packit Service d328f3
	GtkWidget *eap_widget;
Packit Service d328f3
Packit Service d328f3
	vbox = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_vbox"));
Packit Service d328f3
	g_assert (vbox);
Packit Service d328f3
Packit Service d328f3
	/* Remove any previous wireless security widgets */
Packit Service d328f3
	children = gtk_container_get_children (GTK_CONTAINER (vbox));
Packit Service d328f3
	for (elt = children; elt; elt = g_list_next (elt))
Packit Service d328f3
		gtk_container_remove (GTK_CONTAINER (vbox), GTK_WIDGET (elt->data));
Packit Service d328f3
	g_list_free (children);
Packit Service d328f3
Packit Service d328f3
	model = gtk_combo_box_get_model (GTK_COMBO_BOX (combo));
Packit Service d328f3
	gtk_combo_box_get_active_iter (GTK_COMBO_BOX (combo), &iter);
Packit Service d328f3
	gtk_tree_model_get (model, &iter, I_METHOD_COLUMN, &eap, -1);
Packit Service d328f3
	g_assert (eap);
Packit Service d328f3
Packit Service d328f3
	eap_widget = eap_method_get_widget (eap);
Packit Service d328f3
	g_assert (eap_widget);
Packit Service d328f3
	gtk_widget_unparent (eap_widget);
Packit Service d328f3
Packit Service d328f3
	if (method->size_group)
Packit Service d328f3
		eap_method_add_to_size_group (eap, method->size_group);
Packit Service d328f3
	gtk_container_add (GTK_CONTAINER (vbox), eap_widget);
Packit Service d328f3
Packit Service d328f3
	eap_method_unref (eap);
Packit Service d328f3
Packit Service d328f3
	wireless_security_changed_cb (combo, method->sec_parent);
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static GtkWidget *
Packit Service d328f3
inner_auth_combo_init (EAPMethodTTLS *method,
Packit Service d328f3
                       NMConnection *connection,
Packit Service d328f3
                       NMSetting8021x *s_8021x,
Packit Service d328f3
                       gboolean secrets_only)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethod *parent = (EAPMethod *) method;
Packit Service d328f3
	GtkWidget *combo;
Packit Service d328f3
	GtkListStore *auth_model;
Packit Service d328f3
	GtkTreeIter iter;
Packit Service d328f3
	EAPMethodSimple *em_pap;
Packit Service d328f3
	EAPMethodSimple *em_mschap;
Packit Service d328f3
	EAPMethodSimple *em_mschap_v2;
Packit Service d328f3
	EAPMethodSimple *em_plain_mschap_v2;
Packit Service d328f3
	EAPMethodSimple *em_chap;
Packit Service d328f3
	EAPMethodSimple *em_md5;
Packit Service d328f3
	EAPMethodSimple *em_gtc;
Packit Service d328f3
	guint32 active = 0;
Packit Service d328f3
	const char *phase2_auth = NULL;
Packit Service d328f3
	EAPMethodSimpleFlags simple_flags;
Packit Service d328f3
Packit Service d328f3
	auth_model = gtk_list_store_new (2, G_TYPE_STRING, eap_method_get_type ());
Packit Service d328f3
Packit Service d328f3
	if (s_8021x) {
Packit Service d328f3
		if (nm_setting_802_1x_get_phase2_auth (s_8021x))
Packit Service d328f3
			phase2_auth = nm_setting_802_1x_get_phase2_auth (s_8021x);
Packit Service d328f3
		else if (nm_setting_802_1x_get_phase2_autheap (s_8021x))
Packit Service d328f3
			phase2_auth = nm_setting_802_1x_get_phase2_autheap (s_8021x);
Packit Service d328f3
	}
Packit Service d328f3
Packit Service d328f3
	simple_flags = EAP_METHOD_SIMPLE_FLAG_PHASE2 | EAP_METHOD_SIMPLE_FLAG_AUTHEAP_ALLOWED;
Packit Service d328f3
	if (method->is_editor)
Packit Service d328f3
		simple_flags |= EAP_METHOD_SIMPLE_FLAG_IS_EDITOR;
Packit Service d328f3
	if (secrets_only)
Packit Service d328f3
		simple_flags |= EAP_METHOD_SIMPLE_FLAG_SECRETS_ONLY;
Packit Service d328f3
Packit Service d328f3
	em_pap = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                connection,
Packit Service d328f3
	                                EAP_METHOD_SIMPLE_TYPE_PAP,
Packit Service d328f3
	                                simple_flags,
Packit Service d328f3
	                                NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("PAP"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_pap,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_pap));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to PAP */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "pap"))
Packit Service d328f3
		active = 0;
Packit Service d328f3
Packit Service d328f3
	em_mschap = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                   connection,
Packit Service d328f3
	                                   EAP_METHOD_SIMPLE_TYPE_MSCHAP,
Packit Service d328f3
	                                   simple_flags,
Packit Service d328f3
	                                   NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("MSCHAP"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_mschap,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_mschap));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to MSCHAP */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "mschap"))
Packit Service d328f3
		active = 1;
Packit Service d328f3
Packit Service d328f3
	em_mschap_v2 = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                      connection,
Packit Service d328f3
	                                      EAP_METHOD_SIMPLE_TYPE_MSCHAP_V2,
Packit Service d328f3
	                                      simple_flags,
Packit Service d328f3
	                                      NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("MSCHAPv2"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_mschap_v2,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_mschap_v2));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to MSCHAPv2 */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "mschapv2") &&
Packit Service d328f3
	    nm_setting_802_1x_get_phase2_autheap (s_8021x) != NULL)
Packit Service d328f3
		active = 2;
Packit Service d328f3
Packit Service d328f3
	em_plain_mschap_v2 = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                            connection,
Packit Service d328f3
	                                            EAP_METHOD_SIMPLE_TYPE_PLAIN_MSCHAP_V2,
Packit Service d328f3
	                                            simple_flags,
Packit Service d328f3
	                                            NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("MSCHAPv2 (no EAP)"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_plain_mschap_v2,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_plain_mschap_v2));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to plain MSCHAPv2 */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "mschapv2") &&
Packit Service d328f3
	    nm_setting_802_1x_get_phase2_auth (s_8021x) != NULL)
Packit Service d328f3
		active = 3;
Packit Service d328f3
Packit Service d328f3
	em_chap = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                 connection,
Packit Service d328f3
	                                 EAP_METHOD_SIMPLE_TYPE_CHAP,
Packit Service d328f3
	                                 simple_flags,
Packit Service d328f3
	                                 NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("CHAP"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_chap,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_chap));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to CHAP */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "chap"))
Packit Service d328f3
		active = 4;
Packit Service d328f3
Packit Service d328f3
	em_md5 = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                connection,
Packit Service d328f3
	                                EAP_METHOD_SIMPLE_TYPE_MD5,
Packit Service d328f3
	                                simple_flags,
Packit Service d328f3
	                                NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("MD5"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_md5,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_md5));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to MD5 */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "md5"))
Packit Service d328f3
		active = 5;
Packit Service d328f3
Packit Service d328f3
	em_gtc = eap_method_simple_new (method->sec_parent,
Packit Service d328f3
	                                connection,
Packit Service d328f3
	                                EAP_METHOD_SIMPLE_TYPE_GTC,
Packit Service d328f3
	                                simple_flags,
Packit Service d328f3
	                                NULL);
Packit Service d328f3
	gtk_list_store_append (auth_model, &iter);
Packit Service d328f3
	gtk_list_store_set (auth_model, &iter,
Packit Service d328f3
	                    I_NAME_COLUMN, _("GTC"),
Packit Service d328f3
	                    I_METHOD_COLUMN, em_gtc,
Packit Service d328f3
	                    -1);
Packit Service d328f3
	eap_method_unref (EAP_METHOD (em_gtc));
Packit Service d328f3
Packit Service d328f3
	/* Check for defaulting to GTC */
Packit Service d328f3
	if (phase2_auth && !strcasecmp (phase2_auth, "gtc"))
Packit Service d328f3
		active = 6;
Packit Service d328f3
Packit Service d328f3
	combo = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_combo"));
Packit Service d328f3
	g_assert (combo);
Packit Service d328f3
Packit Service d328f3
	gtk_combo_box_set_model (GTK_COMBO_BOX (combo), GTK_TREE_MODEL (auth_model));
Packit Service d328f3
	g_object_unref (G_OBJECT (auth_model));
Packit Service d328f3
	gtk_combo_box_set_active (GTK_COMBO_BOX (combo), active);
Packit Service d328f3
Packit Service d328f3
	g_signal_connect (G_OBJECT (combo), "changed",
Packit Service d328f3
	                  (GCallback) inner_auth_combo_changed_cb,
Packit Service d328f3
	                  method);
Packit Service d328f3
	return combo;
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
static void
Packit Service d328f3
update_secrets (EAPMethod *parent, NMConnection *connection)
Packit Service d328f3
{
Packit Service d328f3
	eap_method_phase2_update_secrets_helper (parent,
Packit Service d328f3
	                                         connection,
Packit Service d328f3
	                                         "eap_ttls_inner_auth_combo",
Packit Service d328f3
	                                         I_METHOD_COLUMN);
Packit Service d328f3
}
Packit Service d328f3
Packit Service d328f3
EAPMethodTTLS *
Packit Service d328f3
eap_method_ttls_new (WirelessSecurity *ws_parent,
Packit Service d328f3
                     NMConnection *connection,
Packit Service d328f3
                     gboolean is_editor,
Packit Service d328f3
                     gboolean secrets_only)
Packit Service d328f3
{
Packit Service d328f3
	EAPMethod *parent;
Packit Service d328f3
	EAPMethodTTLS *method;
Packit Service d328f3
	GtkWidget *widget;
Packit Service d328f3
	NMSetting8021x *s_8021x = NULL;
Packit Service d328f3
	gboolean ca_not_required = FALSE;
Packit Service d328f3
Packit Service d328f3
	parent = eap_method_init (sizeof (EAPMethodTTLS),
Packit Service d328f3
	                          validate,
Packit Service d328f3
	                          add_to_size_group,
Packit Service d328f3
	                          fill_connection,
Packit Service d328f3
	                          update_secrets,
Packit Service d328f3
	                          destroy,
Packit Service d328f3
	                          "/org/freedesktop/network-manager-applet/eap-method-ttls.ui",
Packit Service d328f3
	                          "eap_ttls_notebook",
Packit Service d328f3
	                          "eap_ttls_anon_identity_entry",
Packit Service d328f3
	                          FALSE);
Packit Service d328f3
	if (!parent)
Packit Service d328f3
		return NULL;
Packit Service d328f3
Packit Service d328f3
	method = (EAPMethodTTLS *) parent;
Packit Service d328f3
	method->password_flags_name = NM_SETTING_802_1X_PASSWORD;
Packit Service d328f3
	method->sec_parent = ws_parent;
Packit Service d328f3
	method->is_editor = is_editor;
Packit Service d328f3
Packit Service d328f3
	if (connection)
Packit Service d328f3
		s_8021x = nm_connection_get_setting_802_1x (connection);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_grid"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
Packit Service d328f3
	method->ca_cert_chooser = nma_cert_chooser_new ("CA",
Packit Service d328f3
	                                                  NMA_CERT_CHOOSER_FLAG_CERT
Packit Service d328f3
	                                                | (secrets_only ? NMA_CERT_CHOOSER_FLAG_PASSWORDS : 0));
Packit Service d328f3
	gtk_grid_attach (GTK_GRID (widget), method->ca_cert_chooser, 0, 2, 2, 1);
Packit Service d328f3
	gtk_widget_show (method->ca_cert_chooser);
Packit Service d328f3
Packit Service d328f3
	g_signal_connect (method->ca_cert_chooser,
Packit Service d328f3
	                  "cert-validate",
Packit Service d328f3
	                  G_CALLBACK (eap_method_ca_cert_validate_cb),
Packit Service d328f3
	                  NULL);
Packit Service d328f3
	g_signal_connect (method->ca_cert_chooser,
Packit Service d328f3
	                  "changed",
Packit Service d328f3
	                  G_CALLBACK (wireless_security_changed_cb),
Packit Service d328f3
	                  ws_parent);
Packit Service d328f3
Packit Service d328f3
	eap_method_setup_cert_chooser (NMA_CERT_CHOOSER (method->ca_cert_chooser), s_8021x,
Packit Service d328f3
	                               nm_setting_802_1x_get_ca_cert_scheme,
Packit Service d328f3
	                               nm_setting_802_1x_get_ca_cert_path,
Packit Service d328f3
	                               nm_setting_802_1x_get_ca_cert_uri,
Packit Service d328f3
	                               nm_setting_802_1x_get_ca_cert_password,
Packit Service d328f3
	                               NULL,
Packit Service d328f3
	                               NULL,
Packit Service d328f3
	                               NULL,
Packit Service d328f3
	                               NULL);
Packit Service d328f3
Packit Service d328f3
	if (connection && eap_method_ca_cert_ignore_get (parent, connection)) {
Packit Service d328f3
		gchar *ca_cert;
Packit Service d328f3
		NMSetting8021xCKScheme scheme;
Packit Service d328f3
Packit Service d328f3
		ca_cert = nma_cert_chooser_get_cert (NMA_CERT_CHOOSER (method->ca_cert_chooser), &scheme);
Packit Service d328f3
		if (ca_cert)
Packit Service d328f3
			g_free (ca_cert);
Packit Service d328f3
		else
Packit Service d328f3
			ca_not_required = TRUE;
Packit Service d328f3
	}
Packit Service d328f3
Packit Service d328f3
	if (secrets_only)
Packit Service d328f3
		ca_not_required = TRUE;
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_ca_cert_not_required_checkbox"));
Packit Service d328f3
	g_assert (widget);
Packit Service d328f3
	g_signal_connect (G_OBJECT (widget), "toggled",
Packit Service d328f3
	                  (GCallback) ca_cert_not_required_toggled,
Packit Service d328f3
	                  parent);
Packit Service d328f3
	g_signal_connect (G_OBJECT (widget), "toggled",
Packit Service d328f3
	                  (GCallback) wireless_security_changed_cb,
Packit Service d328f3
	                  ws_parent);
Packit Service d328f3
	gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), ca_not_required);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_anon_identity_entry"));
Packit Service d328f3
	if (s_8021x && nm_setting_802_1x_get_anonymous_identity (s_8021x))
Packit Service d328f3
		gtk_entry_set_text (GTK_ENTRY (widget), nm_setting_802_1x_get_anonymous_identity (s_8021x));
Packit Service d328f3
	g_signal_connect (G_OBJECT (widget), "changed",
Packit Service d328f3
	                  (GCallback) wireless_security_changed_cb,
Packit Service d328f3
	                  ws_parent);
Packit Service d328f3
Packit Service d328f3
	widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_domain_entry"));
Packit Service d328f3
	if (s_8021x && nm_setting_802_1x_get_domain_suffix_match (s_8021x))
Packit Service d328f3
		gtk_entry_set_text (GTK_ENTRY (widget), nm_setting_802_1x_get_domain_suffix_match (s_8021x));
Packit Service d328f3
	g_signal_connect (G_OBJECT (widget), "changed",
Packit Service d328f3
	                  (GCallback) wireless_security_changed_cb,
Packit Service d328f3
	                  ws_parent);
Packit Service d328f3
Packit Service d328f3
	widget = inner_auth_combo_init (method, connection, s_8021x, secrets_only);
Packit Service d328f3
	inner_auth_combo_changed_cb (widget, (gpointer) method);
Packit Service d328f3
Packit Service d328f3
	if (secrets_only) {
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_anon_identity_label"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_anon_identity_entry"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_domain_label"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_domain_entry"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_ca_cert_not_required_checkbox"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_label"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
		widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_ttls_inner_auth_combo"));
Packit Service d328f3
		gtk_widget_hide (widget);
Packit Service d328f3
	}
Packit Service d328f3
Packit Service d328f3
	nma_cert_chooser_setup_cert_password_storage (NMA_CERT_CHOOSER (method->ca_cert_chooser),
Packit Service d328f3
	                                              0, (NMSetting *) s_8021x, NM_SETTING_802_1X_CA_CERT_PASSWORD,
Packit Service d328f3
	                                              FALSE, secrets_only);
Packit Service d328f3
Packit Service d328f3
	return method;
Packit Service d328f3
}
Packit Service d328f3