aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2003-02-15 04:10:15 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2003-02-15 04:10:15 +0800
commit4d98f14113b8cdf72226361d6904a6829a15f0e7 (patch)
tree50956ad5d1636f44b5e596ff03509b67d4fbf339
parentb498fc007f35fbc1693004b6b0cc07ffd0696ce8 (diff)
downloadgsoc2013-evolution-4d98f14113b8cdf72226361d6904a6829a15f0e7.tar.gz
gsoc2013-evolution-4d98f14113b8cdf72226361d6904a6829a15f0e7.tar.zst
gsoc2013-evolution-4d98f14113b8cdf72226361d6904a6829a15f0e7.zip
Change the logic here slightly. Instead of only reprompting the user if
2003-02-14 Jeffrey Stedfast <fejj@ximian.com> * mail-session.c (do_get_pass): Change the logic here slightly. Instead of only reprompting the user if the cache is empty, also reprompt the user if the backend is forcing a reprompt. (request_password): If we have a cached passwd string for the account, fill-in the GtkEntry box with that value by default. This, together with the camel changes, fixes the "Evolution forgets my POP passwd if it gets a -ERR response during the login phase" bug. svn path=/trunk/; revision=19911
-rw-r--r--mail/ChangeLog12
-rw-r--r--mail/mail-session.c29
2 files changed, 32 insertions, 9 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 74c1566e3a..d6e10d9062 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,15 @@
+2003-02-14 Jeffrey Stedfast <fejj@ximian.com>
+
+ * mail-session.c (do_get_pass): Change the logic here
+ slightly. Instead of only reprompting the user if the cache is
+ empty, also reprompt the user if the backend is forcing a
+ reprompt.
+ (request_password): If we have a cached passwd string for the
+ account, fill-in the GtkEntry box with that value by
+ default. This, together with the camel changes, fixes the
+ "Evolution forgets my POP passwd if it gets a -ERR response during
+ the login phase" bug.
+
2003-02-13 Jeffrey Stedfast <fejj@ximian.com>
* e-searching-tokenizer.c: #include <stdio.h>
diff --git a/mail/mail-session.c b/mail/mail-session.c
index f0ee9b04d9..16e7fc6d1b 100644
--- a/mail/mail-session.c
+++ b/mail/mail-session.c
@@ -80,7 +80,7 @@ typedef struct _MailSessionClass {
} MailSessionClass;
-static char *get_password(CamelSession *session, const char *prompt, gboolean secret, CamelService *service, const char *item, CamelException *ex);
+static char *get_password(CamelSession *session, const char *prompt, gboolean reprompt, gboolean secret, CamelService *service, const char *item, CamelException *ex);
static void forget_password(CamelSession *session, CamelService *service, const char *item, CamelException *ex);
static gboolean alert_user(CamelSession *session, CamelSessionAlertType type, const char *prompt, gboolean cancel);
static guint register_timeout(CamelSession *session, guint32 interval, CamelTimeoutCallback cb, gpointer camel_data);
@@ -159,6 +159,7 @@ struct _pass_msg {
CamelSession *session;
const char *prompt;
+ gboolean reprompt;
gboolean secret;
CamelService *service;
const char *item;
@@ -189,7 +190,8 @@ pass_response (GtkDialog *dialog, int button, void *data)
struct _pass_msg *m = data;
switch (button) {
- case GTK_RESPONSE_OK: {
+ case GTK_RESPONSE_OK:
+ {
gboolean cache, remember;
m->result = g_strdup (gtk_entry_get_text ((GtkEntry *) m->entry));
@@ -217,7 +219,8 @@ pass_response (GtkDialog *dialog, int button, void *data)
if (remember)
e_passwords_remember_password ("Mail", m->key);
}
- break; }
+ break;
+ }
default:
camel_exception_set (m->ex, CAMEL_EXCEPTION_USER_CANCEL, _("User canceled operation."));
break;
@@ -269,6 +272,12 @@ request_password (struct _pass_msg *m)
gtk_box_pack_start (GTK_BOX (GTK_DIALOG (password_dialog)->vbox), m->entry, TRUE, FALSE, 0);
gtk_widget_show (m->entry);
+ if (m->reprompt && m->result) {
+ gtk_entry_set_text ((GtkEntry *) m->entry, m->result);
+ g_free (m->result);
+ m->result = NULL;
+ }
+
if (m->service_url == NULL || m->service != NULL) {
m->check = gtk_check_button_new_with_mnemonic (m->service_url? _("_Remember this password") :
_("_Remember this password for the remainder of this session"));
@@ -298,7 +307,7 @@ do_get_pass(struct _mail_msg *mm)
m->result = g_strdup(account->source->url);
} else if (m->key) {
m->result = e_passwords_get_password ("Mail", m->key);
- if (m->result == NULL) {
+ if (m->result == NULL || m->reprompt) {
if (mail_session->interactive) {
request_password(m);
return;
@@ -326,12 +335,13 @@ static struct _mail_msg_op get_pass_op = {
};
static char *
-get_password (CamelSession *session, const char *prompt, gboolean secret, CamelService *service, const char *item, CamelException *ex)
+get_password (CamelSession *session, const char *prompt, gboolean reprompt, gboolean secret,
+ CamelService *service, const char *item, CamelException *ex)
{
struct _pass_msg *m, *r;
EMsgPort *pass_reply;
char *ret;
-
+
/* We setup an async request and send it off, and wait for it to return */
/* If we're really in main, we dont of course ...
... but this shouldn't be allowed because of locking issues */
@@ -340,6 +350,7 @@ get_password (CamelSession *session, const char *prompt, gboolean secret, CamelS
m->ismain = pthread_self() == mail_gui_thread;
m->session = session;
m->prompt = prompt;
+ m->reprompt = reprompt;
m->secret = secret;
m->service = service;
m->item = item;
@@ -348,11 +359,11 @@ get_password (CamelSession *session, const char *prompt, gboolean secret, CamelS
m->service_url = camel_url_to_string (service->url, CAMEL_URL_HIDE_ALL);
m->key = make_key(service, item);
- if (m->ismain)
+ if (m->ismain) {
do_get_pass((struct _mail_msg *)m);
- else {
+ } else {
extern EMsgPort *mail_gui_port2;
-
+
e_msgport_put(mail_gui_port2, (EMsg *)m);
}