aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMilan Crha <mcrha@redhat.com>2010-12-15 23:03:00 +0800
committerMilan Crha <mcrha@redhat.com>2010-12-15 23:03:00 +0800
commite91dcae7c683d65b5789a79161f1998f43a2b425 (patch)
treee13a64af5c7116ae868d055b237e8baf6d8ba33e
parente32cf32a6c7a563dda590cbad727f693088cfea0 (diff)
downloadgsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.tar
gsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.tar.gz
gsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.tar.bz2
gsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.tar.lz
gsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.tar.xz
gsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.tar.zst
gsoc2013-evolution-e91dcae7c683d65b5789a79161f1998f43a2b425.zip
Bug #634385 - Crash in smtp_connect
-rw-r--r--mail/mail-ops.c6
-rw-r--r--mail/mail-session.c6
2 files changed, 11 insertions, 1 deletions
diff --git a/mail/mail-ops.c b/mail/mail-ops.c
index 7f84b3bc8d..9fa7671d42 100644
--- a/mail/mail-ops.c
+++ b/mail/mail-ops.c
@@ -495,9 +495,13 @@ mail_send_message (struct _send_queue_msg *m,
if ((account = e_get_account_by_uid (name))
/* 'old' x-evolution-account stored the name, how silly */
|| (account = e_get_account_by_name (name))) {
- if (account->transport && account->transport->url)
+ if (account->transport && account->transport->url) {
transport_url = g_strdup (account->transport->url);
+ /* to reprompt password on sending if needed */
+ account->transport->get_password_canceled = FALSE;
+ }
+
sent_folder_uri = g_strdup (account->sent_folder_uri);
}
g_free(name);
diff --git a/mail/mail-session.c b/mail/mail-session.c
index 4e4850b3d2..80f2c78825 100644
--- a/mail/mail-session.c
+++ b/mail/mail-session.c
@@ -207,6 +207,9 @@ get_password (CamelSession *session,
if (ret == NULL || (flags & CAMEL_SESSION_PASSWORD_REPROMPT)) {
gboolean remember;
+ g_free (ret);
+ ret = NULL;
+
if (url) {
if ((account = mail_config_get_account_by_source_url(url)))
config_service = account->source;
@@ -255,6 +258,9 @@ get_password (CamelSession *session,
ret = e_passwords_ask_password(title, domain, key, prompt, eflags, &remember, NULL);
+ if (!ret)
+ e_passwords_forget_password (domain, key);
+
g_free(title);
if (ret && config_service)