aboutsummaryrefslogblamecommitdiffstats
path: root/smime/gui/cert-trust-dialog.c
blob: 3148adfaa90504240a50d58e4eb66402e71b319c (plain) (tree)
























































































































































                                                                                                                                    
/* -*- 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;
}