aboutsummaryrefslogtreecommitdiffstats
path: root/smime/gui/cert-trust-dialog.c
diff options
context:
space:
mode:
Diffstat (limited to 'smime/gui/cert-trust-dialog.c')
-rw-r--r--smime/gui/cert-trust-dialog.c153
1 files changed, 153 insertions, 0 deletions
diff --git a/smime/gui/cert-trust-dialog.c b/smime/gui/cert-trust-dialog.c
new file mode 100644
index 0000000000..3148adfaa9
--- /dev/null
+++ b/smime/gui/cert-trust-dialog.c
@@ -0,0 +1,153 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+/*
+ * Authors: Chris Toshok <toshok@ximian.com>
+ * Michael Zucchi <notzed@ximian.com>
+ *
+ * Copyright (C) 2004 Novell, Inc. (www.novell.com)
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Street #330, Boston, MA 02111-1307, USA.
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include "e-cert.h"
+#include "e-cert-trust.h"
+#include "e-cert-db.h"
+#include "cert-trust-dialog.h"
+#include "ca-trust-dialog.h"
+
+#include <gtk/gtkwidget.h>
+#include <gtk/gtkradiobutton.h>
+#include <gtk/gtkdialog.h>
+#include <gtk/gtklabel.h>
+
+#include <libgnome/gnome-i18n.h>
+#include <glade/glade.h>
+
+#define GLADE_FILE_NAME "smime-ui.glade"
+
+typedef struct {
+ GladeXML *gui;
+ GtkWidget *dialog;
+ GtkWidget *trust_button;
+ GtkWidget *notrust_button;
+ GtkWidget *label;
+
+ ECert *cert, *cacert;
+} CertTrustDialogData;
+
+static void
+free_data (void *data)
+{
+ CertTrustDialogData *ctd = data;
+
+ g_object_unref (ctd->cert);
+ g_object_unref (ctd->cacert);
+ g_object_unref (ctd->gui);
+ g_free (ctd);
+}
+
+static void
+ctd_response(GtkWidget *w, guint id, CertTrustDialogData *data)
+{
+ CERTCertTrust trust;
+ CERTCertificate *icert;
+
+ switch (id) {
+ case GTK_RESPONSE_OK:
+ icert = e_cert_get_internal_cert(data->cert);
+ e_cert_trust_init(&trust);
+ e_cert_trust_set_valid_peer(&trust);
+ e_cert_trust_add_peer_trust (&trust, FALSE,
+ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON (data->trust_button)),
+ FALSE);
+ CERT_ChangeCertTrust (CERT_GetDefaultCertDB(), icert, &trust);
+ break;
+ case GTK_RESPONSE_ACCEPT: {
+ g_signal_stop_emission_by_name(w, "response");
+
+ /* just *what on earth* was chris thinking here!?!?! copied from certificate-manager.c */
+ GtkWidget *dialog = ca_trust_dialog_show (data->cacert, FALSE);
+ CERTCertificate *icert = e_cert_get_internal_cert (data->cacert);
+
+ ca_trust_dialog_set_trust (dialog,
+ e_cert_trust_has_trusted_ca (icert->trust, TRUE, FALSE, FALSE),
+ e_cert_trust_has_trusted_ca (icert->trust, FALSE, TRUE, FALSE),
+ e_cert_trust_has_trusted_ca (icert->trust, FALSE, FALSE, TRUE));
+
+ if (gtk_dialog_run (GTK_DIALOG (dialog)) == GTK_RESPONSE_OK) {
+ gboolean trust_ssl, trust_email, trust_objsign;
+
+ ca_trust_dialog_get_trust (dialog,
+ &trust_ssl, &trust_email, &trust_objsign);
+
+ e_cert_trust_init (&trust);
+ e_cert_trust_set_valid_ca (&trust);
+ e_cert_trust_add_ca_trust (&trust,
+ trust_ssl,
+ trust_email,
+ trust_objsign);
+
+ CERT_ChangeCertTrust(CERT_GetDefaultCertDB(), icert, &trust);
+ }
+
+ gtk_widget_destroy (dialog);
+ break; }
+ }
+}
+
+GtkWidget*
+cert_trust_dialog_show (ECert *cert)
+{
+ CertTrustDialogData *ctd_data;
+ CERTCertificate *icert;
+
+ ctd_data = g_new0 (CertTrustDialogData, 1);
+ ctd_data->gui = glade_xml_new (EVOLUTION_GLADEDIR "/" GLADE_FILE_NAME, NULL, NULL);
+
+ ctd_data->dialog = glade_xml_get_widget (ctd_data->gui, "cert-trust-dialog");
+ ctd_data->cert = g_object_ref (cert);
+ ctd_data->cacert = e_cert_get_ca_cert(cert);
+ ctd_data->trust_button = glade_xml_get_widget(ctd_data->gui, "cert-trust");
+ ctd_data->notrust_button = glade_xml_get_widget(ctd_data->gui, "cert-notrust");
+
+ ctd_data->label = glade_xml_get_widget(ctd_data->gui, "trust-label");
+
+ g_signal_connect(ctd_data->dialog, "response", G_CALLBACK(ctd_response), ctd_data);
+
+ g_object_set_data_full (G_OBJECT (ctd_data->dialog), "CertTrustDialogData", ctd_data, free_data);
+
+ icert = e_cert_get_internal_cert(cert);
+ if (e_cert_trust_has_trusted_peer(icert->trust, FALSE, TRUE, FALSE))
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON (ctd_data->trust_button), TRUE);
+ else
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON (ctd_data->notrust_button), TRUE);
+
+
+ icert = e_cert_get_internal_cert(ctd_data->cacert);
+ if (e_cert_trust_has_trusted_ca(icert->trust, FALSE, TRUE, FALSE))
+ gtk_label_set_text((GtkLabel *)ctd_data->label,
+ _("Because you trust the certificate authority that issued this certificate, "
+ "then you trust the authenticity of this certificate unless otherwise indicated here"));
+ else
+ gtk_label_set_text((GtkLabel *)ctd_data->label,
+ _("Because you do not trust the certificate authority that issued this certificate, "
+ "then you do not trust the authenticity of this certificate unless otherwise indicated here"));
+
+ return ctd_data->dialog;
+}