/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2003 Hiroyuki Yamamoto & the Sylpheed-Claws team
+ * Copyright (C) 1999-2006 Hiroyuki Yamamoto & the Sylpheed-Claws team
*
* 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
*
* 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 Place - Suite 330, Boston, MA 02111-1307, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#include <glib.h>
#include "procmime.h"
static GSList *systems = NULL;
+static gchar *privacy_last_error = NULL;
+void privacy_set_error(const gchar *format, ...)
+{
+ va_list args;
+ gchar buf[BUFSIZ];
+
+ va_start(args, format);
+ g_vsnprintf(buf, BUFSIZ, format, args);
+ va_end(args);
+ g_free(privacy_last_error);
+ privacy_last_error = g_strdup(buf);
+}
+
+static gchar tmp_privacy_error[BUFSIZ];
+
+const gchar *privacy_get_error (void)
+{
+ if (privacy_last_error) {
+ strncpy2(tmp_privacy_error, privacy_last_error, BUFSIZ-1);
+ g_free(privacy_last_error);
+ privacy_last_error = NULL;
+ return tmp_privacy_error;
+ } else {
+ return _("Unknown error");
+ }
+}
+
+PrivacySystem *privacy_data_get_system(PrivacyData *data)
+{
+ /* Make sure the cached system is still registered */
+ if (data->system && g_slist_find(systems, data->system))
+ return data->system;
+ else
+ return NULL;
+}
/**
* Register a new Privacy System
*
*/
void privacy_free_privacydata(PrivacyData *privacydata)
{
+ PrivacySystem *system = NULL;
+
g_return_if_fail(privacydata != NULL);
- privacydata->system->free_privacydata(privacydata);
+ system = privacy_data_get_system(privacydata);
+ if (!system)
+ return;
+ system->free_privacydata(privacydata);
}
/**
g_return_val_if_fail(mimeinfo != NULL, FALSE);
if (mimeinfo->privacy != NULL) {
- PrivacySystem *system = mimeinfo->privacy->system;
+ PrivacySystem *system =
+ privacy_data_get_system(mimeinfo->privacy);
+
+ if (system == NULL) {
+ mimeinfo->privacy = NULL;
+ goto try_others;
+ }
if (system->is_signed != NULL)
return system->is_signed(mimeinfo);
else
return FALSE;
}
-
+try_others:
for(cur = systems; cur != NULL; cur = g_slist_next(cur)) {
PrivacySystem *system = (PrivacySystem *) cur->data;
if (mimeinfo->privacy == NULL)
return -1;
- system = mimeinfo->privacy->system;
+ system = privacy_data_get_system(mimeinfo->privacy);
+ if (system == NULL)
+ return -1;
+
if (system->check_signature == NULL)
return -1;
if (mimeinfo->privacy == NULL)
return SIGNATURE_UNCHECKED;
- system = mimeinfo->privacy->system;
+ system = privacy_data_get_system(mimeinfo->privacy);
+ if (system == NULL)
+ return SIGNATURE_UNCHECKED;
if (system->get_sig_status == NULL)
return SIGNATURE_UNCHECKED;
if (mimeinfo->privacy == NULL)
return g_strdup(_("No signature found"));
- system = mimeinfo->privacy->system;
+ system = privacy_data_get_system(mimeinfo->privacy);
+ if (system == NULL)
+ return g_strdup(_("No signature found"));
if (system->get_sig_info_short == NULL)
return g_strdup(_("No information available"));
if (mimeinfo->privacy == NULL)
return g_strdup(_("No signature found"));
- system = mimeinfo->privacy->system;
+ system = privacy_data_get_system(mimeinfo->privacy);
+ if (system == NULL)
+ return g_strdup(_("No signature found"));
if (system->get_sig_info_full == NULL)
return g_strdup(_("No information available"));
g_return_val_if_fail(id != NULL, FALSE);
g_return_val_if_fail(mimeinfo != NULL, FALSE);
- g_return_val_if_fail(encdata != NULL, FALSE);
+ if (encdata == NULL) {
+ privacy_set_error(_("No recipient keys defined."));
+ return FALSE;
+ }
system = privacy_get_system(id);
if (system == NULL)