* Finch is the legal property of its developers, whose names are too numerous * to list here. Please refer to the COPYRIGHT file distributed with this * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA #include "tls-certificate.h" #include "tls-certificate-info.h" /* Pretty much Xerox of gtkcertmgr */ tls_peers_mgmt_import_ok2_cb(gpointer data, const char *result) GTlsCertificate *crt = data; /* TODO: Perhaps prompt if you're overwriting a cert? */ if (purple_tls_certificate_trust(id, crt, &error)) { gnt_tree_add_row_last(GNT_TREE(certmgr.tree), g_strdup(id), gnt_tree_create_row(GNT_TREE(certmgr.tree), id), purple_debug_error("gntcertmgr/tls_peers_mgmt", "Failure trusting peer certificate '%s': %s", tls_peers_mgmt_import_ok_cb(gpointer data, const char *filename) crt = g_tls_certificate_new_from_file(filename, &error); PurpleTlsCertificateInfo *info; info = purple_tls_certificate_get_info(crt); default_hostname = purple_tls_certificate_info_get_subject_name(info); purple_tls_certificate_info_free(info); purple_request_input(NULL, _("Type the host name this certificate is for."), default_hostname, FALSE, FALSE, NULL, _("OK"), G_CALLBACK(tls_peers_mgmt_import_ok2_cb), _("Cancel"), G_CALLBACK(g_object_unref), g_free(default_hostname); purple_debug_error("gntcertmgr/tls_peers_mgmt", "Failed to import certificate '%s': %s", filename, error->message); secondary = g_strdup_printf(_("File %s could not be imported.\nMake sure that the file is readable and in PEM format.\n"), filename); purple_notify_error(NULL, _("Certificate Import Error"), _("X.509 certificate import failed"), add_cert_cb(GntWidget *button, gpointer null) purple_request_file(NULL, _("Select a PEM certificate"), G_CALLBACK(tls_peers_mgmt_import_ok_cb), /* Save certs in some file */ tls_peers_mgmt_export_ok_cb(gpointer data, const char *filename) GTlsCertificate *crt = data; g_object_get(crt, "certificate-pem", &pem, NULL); g_return_if_fail(crt != NULL); if (!g_file_set_contents(filename, pem, -1, &error)) { purple_debug_error("gntcertmgr/tls_peers_mgmt", "Failed to export certificate '%s': %s", filename, error->message); secondary = g_strdup_printf(_("Export to file %s failed.\nCheck that you have write permission to the target path\n"), filename); purple_notify_error(NULL, _("Certificate Export Error"), _("X.509 certificate export failed"), save_cert_cb(GntWidget *button, gpointer null) key = gnt_tree_get_selection_data(GNT_TREE(certmgr.tree)); crt = purple_tls_certificate_new_from_id(key, &error); purple_debug_error("gntcertmgr/tls_peers_mgmt", "Failed to fetch trusted certificate '%s': %s", purple_request_file((void*)key, _("PEM X.509 Certificate Export"), G_CALLBACK(tls_peers_mgmt_export_ok_cb), G_CALLBACK(g_object_unref), /* Show information about a cert */ info_cert_cb(GntWidget *button, gpointer null) PurpleTlsCertificateInfo *info; gchar *primary, *secondary; key = gnt_tree_get_selection_data(GNT_TREE(certmgr.tree)); crt = purple_tls_certificate_new_from_id(key, NULL); primary = g_strdup_printf(_("Certificate for %s"), key); fpr_sha1 = purple_tls_certificate_get_fingerprint_sha1(crt); fpr_sha1_asc = purple_base16_encode_chunked(fpr_sha1->data, info = purple_tls_certificate_get_info(crt); subject = purple_tls_certificate_info_get_subject_name(info); purple_tls_certificate_info_free(info); secondary = g_strdup_printf(_("Common name: %s\n\nSHA1 fingerprint:\n%s"), subject, fpr_sha1_asc); _("SSL Host Certificate"), primary, secondary, NULL); g_byte_array_free(fpr_sha1, TRUE); tls_peers_mgmt_delete_confirm_cb(gchar *id, gint dontcare) if (!purple_tls_certificate_distrust(id, &error)) { purple_debug_warning("gntcertmgr/tls_peers_mgmt", "Deletion failed on id '%s': %s\n", purple_request_close_with_handle((void*)id); gnt_tree_remove(GNT_TREE(certmgr.tree), (void*)id); delete_cert_cb(GntWidget *button, gpointer null) key = gnt_tree_get_selection_data(GNT_TREE(certmgr.tree)); primary = g_strdup_printf(_("Really delete certificate for %s?"), key); purple_request_close_with_handle((void *)key); purple_request_yes_no((void *)key, _("Confirm certificate delete"), tls_peers_mgmt_delete_confirm_cb, gnt_tree_remove_all(GNT_TREE(certmgr.tree)); idlist = purple_tls_certificate_list_ids(); for (l = idlist; l; l = l->next) { gnt_tree_add_row_last(GNT_TREE(certmgr.tree), g_strdup(l->data), gnt_tree_create_row(GNT_TREE(certmgr.tree), l->data), NULL); purple_tls_certificate_free_ids(idlist); void finch_certmgr_show(void) GntWidget *win, *tree, *box, *button; gnt_window_present(certmgr.window); certmgr.window = win = gnt_vwindow_new(FALSE); gnt_box_set_title(GNT_BOX(win), _("Certificate Manager")); gnt_box_set_pad(GNT_BOX(win), 0); certmgr.tree = tree = gnt_tree_new(); gnt_tree_set_hash_fns(GNT_TREE(tree), g_str_hash, g_str_equal, g_free); gnt_tree_set_column_title(GNT_TREE(tree), 0, _("Hostname")); gnt_tree_set_show_title(GNT_TREE(tree), TRUE); gnt_box_add_widget(GNT_BOX(win), tree); box = gnt_hbox_new(FALSE); gnt_box_add_widget(GNT_BOX(win), box); button = gnt_button_new(_("Add")); gnt_box_add_widget(GNT_BOX(box), button); g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(add_cert_cb), NULL); gnt_util_set_trigger_widget(GNT_WIDGET(tree), GNT_KEY_INS, button); button = gnt_button_new(_("Save")); gnt_box_add_widget(GNT_BOX(box), button); g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(save_cert_cb), NULL); button = gnt_button_new(_("Info")); gnt_box_add_widget(GNT_BOX(box), button); g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(info_cert_cb), NULL); button = gnt_button_new(_("Delete")); gnt_box_add_widget(GNT_BOX(box), button); g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(delete_cert_cb), NULL); gnt_util_set_trigger_widget(GNT_WIDGET(tree), GNT_KEY_DEL, button); button = gnt_button_new(_("Close")); gnt_box_add_widget(GNT_BOX(box), button); g_signal_connect_swapped(G_OBJECT(button), "activate", G_CALLBACK(gnt_widget_destroy), win); g_signal_connect_swapped(G_OBJECT(win), "destroy", G_CALLBACK(g_nullify_pointer), &certmgr.window); g_signal_connect(G_OBJECT(win), "destroy", G_CALLBACK(purple_signals_disconnect_by_handle), NULL); gnt_widget_show(certmgr.window);