2006-04-20 [colin] 2.1.1cvs20
[claws.git] / src / prefs_account.c
index ffce665ae4952fd7c729e860c876e62cd9d18cba..db38949db016e7604e31a504e4d15fa94daf02fc 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2002 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2006 Hiroyuki Yamamoto and 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
@@ -14,7 +14,7 @@
  *
  * 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.
  */
 
 #ifdef HAVE_CONFIG_H
 
 #include "defs.h"
 
+#include <glib.h>
+#include <glib/gi18n.h>
 #include <gtk/gtk.h>
 #include <gdk/gdkkeysyms.h>
+#include <gtk/filesel.h>
 #include <stdio.h>
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <stdlib.h>
 #include <ctype.h>
 
-#include "intl.h"
 #include "main.h"
-#include "prefs.h"
+#include "prefs_gtk.h"
 #include "prefs_account.h"
+#include "prefs_common.h"
 #include "prefs_customheader.h"
 #include "account.h"
 #include "mainwindow.h"
 #include "utils.h"
 #include "alertpanel.h"
 #include "colorlabel.h"
+#include "smtp.h"
+#include "imap.h"
+#include "remotefolder.h"
+#include "base64.h"
 
 static gboolean cancelled;
+static gboolean new_account;
 
 static PrefsAccount tmp_ac_prefs;
 
-static PrefsDialog dialog;
+static GtkWidget *notebook;
+static GtkWidget *sigfile_radiobtn;
+static GtkWidget *sigcmd_radiobtn;
+static GtkWidget *entry_sigpath;
+static GtkWidget *signature_browse_button;
+static GtkWidget *signature_edit_button;
+
+static GSList *prefs_pages = NULL;
 
 static struct Basic {
        GtkWidget *acname_entry;
@@ -74,6 +89,7 @@ static struct Basic {
        GtkWidget *smtpserv_entry;
        GtkWidget *nntpserv_entry;
        GtkWidget *nntpauth_chkbtn;
+       GtkWidget *nntpauth_onconnect_chkbtn;
        GtkWidget *localmbox_entry;
        GtkWidget *mailcmd_chkbtn;
        GtkWidget *mailcmd_entry;
@@ -85,34 +101,54 @@ static struct Basic {
 
 static struct Receive {
        GtkWidget *pop3_frame;
+       GtkWidget *use_apop_chkbtn;
        GtkWidget *rmmail_chkbtn;
        GtkWidget *leave_time_entry;
        GtkWidget *getall_chkbtn;
        GtkWidget *size_limit_chkbtn;
        GtkWidget *size_limit_entry;
-       GtkWidget *filter_on_recv_chkbtn;
        GtkWidget *inbox_label;
        GtkWidget *inbox_entry;
        GtkWidget *inbox_btn;
 
+       GtkWidget *local_frame;
+       GtkWidget *local_inbox_label;
+       GtkWidget *local_inbox_entry;
+       GtkWidget *local_inbox_btn;
+
+       GtkWidget *filter_on_recv_chkbtn;
        GtkWidget *recvatgetall_chkbtn;
+       
+       GtkWidget *imap_frame;
+       GtkWidget *imap_auth_type_optmenu;
+       GtkWidget *imapdir_label;
+       GtkWidget *imapdir_entry;
+
+       GtkWidget *frame_maxarticle;
+       GtkWidget *maxarticle_label;
+       GtkWidget *maxarticle_spinbtn;
+       GtkObject *maxarticle_spinbtn_adj;
 } receive;
 
 static struct Send {
        GtkWidget *date_chkbtn;
        GtkWidget *msgid_chkbtn;
-
        GtkWidget *customhdr_chkbtn;
-
        GtkWidget *smtp_auth_chkbtn;
+       GtkWidget *smtp_auth_type_optmenu;
        GtkWidget *smtp_uid_entry;
        GtkWidget *smtp_pass_entry;
        GtkWidget *pop_bfr_smtp_chkbtn;
-} send;
+       GtkWidget *pop_bfr_smtp_tm_entry;
+       GtkWidget *pop_auth_timeout_lbl;
+       GtkWidget *pop_auth_minutes_lbl;
+} p_send;
 
 static struct Compose {
-       GtkWidget *sigpath_entry;
-
+       GtkWidget *sigfile_radiobtn;
+       GtkWidget *entry_sigpath;
+       GtkWidget *checkbtn_autosig;
+       GtkWidget *entry_sigsep;
        GtkWidget *autocc_chkbtn;
        GtkWidget *autocc_entry;
        GtkWidget *autobcc_chkbtn;
@@ -121,41 +157,39 @@ static struct Compose {
        GtkWidget *autoreplyto_entry;
 } compose;
 
-#if USE_GPGME
 static struct Privacy {
-       GtkWidget *checkbtn_default_encrypt;
-       GtkWidget *checkbtn_ascii_armored;
-       GtkWidget *checkbtn_default_sign;
-       GtkWidget *defaultkey_radiobtn;
-       GtkWidget *emailkey_radiobtn;
-       GtkWidget *customkey_radiobtn;
-       GtkWidget *customkey_entry;
+       GtkWidget *default_privacy_system;
+       GtkWidget *default_encrypt_chkbtn;
+       GtkWidget *default_encrypt_reply_chkbtn;
+       GtkWidget *default_sign_chkbtn;
+       GtkWidget *save_clear_text_chkbtn;
+       GtkWidget *encrypt_to_self_chkbtn;
 } privacy;
-#endif /* USE_GPGME */
 
-#if USE_SSL
+#if USE_OPENSSL
 static struct SSLPrefs {
        GtkWidget *pop_frame;
        GtkWidget *pop_nossl_radiobtn;
        GtkWidget *pop_ssltunnel_radiobtn;
        GtkWidget *pop_starttls_radiobtn;
 
-       GtkWidget *nntp_frame;
-       GtkWidget *nntp_nossl_radiobtn;
-       GtkWidget *nntp_ssltunnel_radiobtn;
-       GtkWidget *nntp_starttls_radiobtn;
-
        GtkWidget *imap_frame;
        GtkWidget *imap_nossl_radiobtn;
        GtkWidget *imap_ssltunnel_radiobtn;
        GtkWidget *imap_starttls_radiobtn;
 
+       GtkWidget *nntp_frame;
+       GtkWidget *nntp_nossl_radiobtn;
+       GtkWidget *nntp_ssltunnel_radiobtn;
+
        GtkWidget *send_frame;
        GtkWidget *smtp_nossl_radiobtn;
        GtkWidget *smtp_ssltunnel_radiobtn;
        GtkWidget *smtp_starttls_radiobtn;
+
+       GtkWidget *use_nonblocking_ssl_chkbtn;
 } ssl;
-#endif /* USE_SSL */
+#endif /* USE_OPENSSL */
 
 static struct Advanced {
        GtkWidget *smtpport_chkbtn;
@@ -171,16 +205,16 @@ static struct Advanced {
        GtkWidget *nntpport_entry;
        GtkWidget *domain_chkbtn;
        GtkWidget *domain_entry;
-       GtkWidget *tunnelcmd_chkbtn;
-       GtkWidget *tunnelcmd_entry;
        GtkWidget *crosspost_chkbtn;
        GtkWidget *crosspost_colormenu;
 
-       GtkWidget *imap_frame;
-       GtkWidget *imapdir_entry;
+       GtkWidget *tunnelcmd_chkbtn;
+       GtkWidget *tunnelcmd_entry;
 
        GtkWidget *sent_folder_chkbtn;
        GtkWidget *sent_folder_entry;
+       GtkWidget *queue_folder_chkbtn;
+       GtkWidget *queue_folder_entry;
        GtkWidget *draft_folder_chkbtn;
        GtkWidget *draft_folder_entry;
        GtkWidget *trash_folder_chkbtn;
@@ -192,12 +226,20 @@ static void prefs_account_fix_size                        (void);
 static void prefs_account_protocol_set_data_from_optmenu(PrefParam *pparam);
 static void prefs_account_protocol_set_optmenu         (PrefParam *pparam);
 static void prefs_account_protocol_activated           (GtkMenuItem *menuitem);
-#if USE_GPGME || USE_SSL
+
+static void prefs_account_set_string_from_optmenu      (PrefParam *pparam);
+static void prefs_account_set_optmenu_from_string      (PrefParam *pparam);
+
+static void prefs_account_imap_auth_type_set_data_from_optmenu
+                                                       (PrefParam *pparam);
+static void prefs_account_imap_auth_type_set_optmenu   (PrefParam *pparam);
+static void prefs_account_smtp_auth_type_set_data_from_optmenu
+                                                       (PrefParam *pparam);
+static void prefs_account_smtp_auth_type_set_optmenu   (PrefParam *pparam);
+
 static void prefs_account_enum_set_data_from_radiobtn  (PrefParam *pparam);
 static void prefs_account_enum_set_radiobtn            (PrefParam *pparam);
-static void prefs_account_ascii_armored_warning(GtkWidget* widget, 
-                                              gpointer unused);
-#endif /* USE_GPGME || USE_SSL */
+
 static void prefs_account_crosspost_set_data_from_colormenu(PrefParam *pparam);
 static void prefs_account_crosspost_set_colormenu(PrefParam *pparam);
 
@@ -205,8 +247,8 @@ static void prefs_account_nntpauth_toggled(GtkToggleButton *button,
                                           gpointer user_data);
 static void prefs_account_mailcmd_toggled(GtkToggleButton *button,
                                          gpointer user_data);
-static void prefs_account_smtp_userid_cb(GtkEditable *editable,
-                                        gpointer smtp_passwd);
+
+static gchar *privacy_prefs;
 
 static PrefParam param[] = {
        /* Basic */
@@ -240,34 +282,45 @@ static PrefParam param[] = {
        {"nntp_server", NULL, &tmp_ac_prefs.nntp_server, P_STRING,
         &basic.nntpserv_entry, prefs_set_data_from_entry, prefs_set_entry},
 
-       {"local_mbox", NULL, &tmp_ac_prefs.local_mbox, P_STRING,
+       {"local_mbox", "/var/mail", &tmp_ac_prefs.local_mbox, P_STRING,
         &basic.localmbox_entry, prefs_set_data_from_entry, prefs_set_entry},
 
        {"use_mail_command", "FALSE", &tmp_ac_prefs.use_mail_command, P_BOOL,
         &basic.mailcmd_chkbtn, prefs_set_data_from_toggle, prefs_set_toggle},
 
-       {"mail_command", "/usr/sbin/sendmail -t", &tmp_ac_prefs.mail_command, P_STRING,
+       {"mail_command", DEFAULT_SENDMAIL_CMD, &tmp_ac_prefs.mail_command, P_STRING,
         &basic.mailcmd_entry, prefs_set_data_from_entry, prefs_set_entry},
 
        {"use_nntp_auth", "FALSE", &tmp_ac_prefs.use_nntp_auth, P_BOOL,
         &basic.nntpauth_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
+       
+       {"use_nntp_auth_onconnect", "FALSE", &tmp_ac_prefs.use_nntp_auth_onconnect, P_BOOL,
+        &basic.nntpauth_onconnect_chkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
 
        {"user_id", "ENV_USER", &tmp_ac_prefs.userid, P_STRING,
         &basic.uid_entry, prefs_set_data_from_entry, prefs_set_entry},
 
-       {"password", NULL, &tmp_ac_prefs.passwd, P_STRING,
+       {"password", NULL, &tmp_ac_prefs.passwd, P_PASSWORD,
         &basic.pass_entry, prefs_set_data_from_entry, prefs_set_entry},
 
-       {"inbox", "inbox", &tmp_ac_prefs.inbox, P_STRING,
+       {"inbox", "#mh/Mailbox/inbox", &tmp_ac_prefs.inbox, P_STRING,
         &receive.inbox_entry, prefs_set_data_from_entry, prefs_set_entry},
 
+       {"local_inbox", "#mh/Mailbox/inbox", &tmp_ac_prefs.local_inbox, P_STRING,
+        &receive.local_inbox_entry, prefs_set_data_from_entry, prefs_set_entry},
+
        /* Receive */
+       {"use_apop_auth", "FALSE", &tmp_ac_prefs.use_apop_auth, P_BOOL,
+        &receive.use_apop_chkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+
        {"remove_mail", "TRUE", &tmp_ac_prefs.rmmail, P_BOOL,
         &receive.rmmail_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
-       
-       {"leave_mail_time", "0", &tmp_ac_prefs.leave_time, P_STRING,
+
+       {"message_leave_time", "7", &tmp_ac_prefs.msg_leave_time, P_INT,
         &receive.leave_time_entry,
         prefs_set_data_from_entry, prefs_set_entry},
 
@@ -286,39 +339,69 @@ static PrefParam param[] = {
         &receive.filter_on_recv_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
+       {"imap_auth_method", "0", &tmp_ac_prefs.imap_auth_type, P_ENUM,
+        &receive.imap_auth_type_optmenu,
+        prefs_account_imap_auth_type_set_data_from_optmenu,
+        prefs_account_imap_auth_type_set_optmenu},
+
        {"receive_at_get_all", "TRUE", &tmp_ac_prefs.recv_at_getall, P_BOOL,
         &receive.recvatgetall_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
+       {"max_news_articles", "300", &tmp_ac_prefs.max_articles, P_INT,
+        &receive.maxarticle_spinbtn,
+        prefs_set_data_from_spinbtn, prefs_set_spinbtn},
+
        /* Send */
        {"add_date", "TRUE", &tmp_ac_prefs.add_date, P_BOOL,
-        &send.date_chkbtn,
+        &p_send.date_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
        {"generate_msgid", "TRUE", &tmp_ac_prefs.gen_msgid, P_BOOL,
-        &send.msgid_chkbtn,
+        &p_send.msgid_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
        {"add_custom_header", "FALSE", &tmp_ac_prefs.add_customhdr, P_BOOL,
-        &send.customhdr_chkbtn,
+        &p_send.customhdr_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
        {"use_smtp_auth", "FALSE", &tmp_ac_prefs.use_smtp_auth, P_BOOL,
-        &send.smtp_auth_chkbtn,
+        &p_send.smtp_auth_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
+       {"smtp_auth_method", "0", &tmp_ac_prefs.smtp_auth_type, P_ENUM,
+        &p_send.smtp_auth_type_optmenu,
+        prefs_account_smtp_auth_type_set_data_from_optmenu,
+        prefs_account_smtp_auth_type_set_optmenu},
+
        {"smtp_user_id", NULL, &tmp_ac_prefs.smtp_userid, P_STRING,
-        &send.smtp_uid_entry, prefs_set_data_from_entry, prefs_set_entry},
-       {"smtp_password", NULL, &tmp_ac_prefs.smtp_passwd, P_STRING,
-        &send.smtp_pass_entry, prefs_set_data_from_entry, prefs_set_entry},
+        &p_send.smtp_uid_entry, prefs_set_data_from_entry, prefs_set_entry},
+       {"smtp_password", NULL, &tmp_ac_prefs.smtp_passwd, P_PASSWORD,
+        &p_send.smtp_pass_entry, prefs_set_data_from_entry, prefs_set_entry},
 
        {"pop_before_smtp", "FALSE", &tmp_ac_prefs.pop_before_smtp, P_BOOL,
-        &send.pop_bfr_smtp_chkbtn,
+        &p_send.pop_bfr_smtp_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
 
+       {"pop_before_smtp_timeout", "5", &tmp_ac_prefs.pop_before_smtp_timeout, P_INT,
+        &p_send.pop_bfr_smtp_tm_entry,
+        prefs_set_data_from_entry, prefs_set_entry},
+
        /* Compose */
-       {"signature_path", "~/"DEFAULT_SIGNATURE, &tmp_ac_prefs.sig_path, P_STRING,
-        &compose.sigpath_entry,
+       {"signature_type", "0", &tmp_ac_prefs.sig_type, P_ENUM,
+        &compose.sigfile_radiobtn,
+        prefs_account_enum_set_data_from_radiobtn,
+        prefs_account_enum_set_radiobtn},
+       {"signature_path", "~" G_DIR_SEPARATOR_S DEFAULT_SIGNATURE,
+        &tmp_ac_prefs.sig_path, P_STRING, &compose.entry_sigpath,
+        prefs_set_data_from_entry, prefs_set_entry},
+
+       {"auto_signature", "TRUE", &tmp_ac_prefs.auto_sig, P_BOOL,
+        &compose.checkbtn_autosig,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+        
+       {"signature_separator", "-- ", &tmp_ac_prefs.sig_sep, P_STRING,
+        &compose.entry_sigsep, 
         prefs_set_data_from_entry, prefs_set_entry},
 
        {"set_autocc", "FALSE", &tmp_ac_prefs.set_autocc, P_BOOL,
@@ -343,30 +426,30 @@ static PrefParam param[] = {
 
        {"auto_replyto", NULL, &tmp_ac_prefs.auto_replyto, P_STRING,
         &compose.autoreplyto_entry,
-
         prefs_set_data_from_entry, prefs_set_entry},
 
-#if USE_GPGME
        /* Privacy */
+       {"default_privacy_system", "", &tmp_ac_prefs.default_privacy_system, P_STRING,
+        &privacy.default_privacy_system,
+        prefs_account_set_string_from_optmenu, prefs_account_set_optmenu_from_string},
        {"default_encrypt", "FALSE", &tmp_ac_prefs.default_encrypt, P_BOOL,
-        &privacy.checkbtn_default_encrypt,
+        &privacy.default_encrypt_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
-       {"ascii_armored", "FALSE", &tmp_ac_prefs.ascii_armored, P_BOOL,
-        &privacy.checkbtn_ascii_armored,
+       {"default_encrypt_reply", "TRUE", &tmp_ac_prefs.default_encrypt_reply, P_BOOL,
+        &privacy.default_encrypt_reply_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
        {"default_sign", "FALSE", &tmp_ac_prefs.default_sign, P_BOOL,
-        &privacy.checkbtn_default_sign,
+        &privacy.default_sign_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
-       {"sign_key", NULL, &tmp_ac_prefs.sign_key, P_ENUM,
-        &privacy.defaultkey_radiobtn,
-        prefs_account_enum_set_data_from_radiobtn,
-        prefs_account_enum_set_radiobtn},
-       {"sign_key_id", NULL, &tmp_ac_prefs.sign_key_id, P_STRING,
-        &privacy.customkey_entry,
-        prefs_set_data_from_entry, prefs_set_entry},
-#endif /* USE_GPGME */
-
-#if USE_SSL
+       {"save_clear_text", "FALSE", &tmp_ac_prefs.save_encrypted_as_clear_text, P_BOOL,
+        &privacy.save_clear_text_chkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+       {"encrypt_to_self", "FALSE", &tmp_ac_prefs.encrypt_to_self, P_BOOL,
+        &privacy.encrypt_to_self_chkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+       {"privacy_prefs", "", &privacy_prefs, P_STRING,
+        NULL, NULL, NULL},
+#if USE_OPENSSL
        /* SSL */
        {"ssl_pop", "0", &tmp_ac_prefs.ssl_pop, P_ENUM,
         &ssl.pop_nossl_radiobtn,
@@ -376,16 +459,32 @@ static PrefParam param[] = {
         &ssl.imap_nossl_radiobtn,
         prefs_account_enum_set_data_from_radiobtn,
         prefs_account_enum_set_radiobtn},
+       {"ssl_nntp", "0", &tmp_ac_prefs.ssl_nntp, P_ENUM,
+        &ssl.nntp_nossl_radiobtn,
+        prefs_account_enum_set_data_from_radiobtn,
+        prefs_account_enum_set_radiobtn},
        {"ssl_smtp", "0", &tmp_ac_prefs.ssl_smtp, P_ENUM,
         &ssl.smtp_nossl_radiobtn,
         prefs_account_enum_set_data_from_radiobtn,
         prefs_account_enum_set_radiobtn},
-       {"ssl_nntp", "FALSE", &tmp_ac_prefs.ssl_nntp, P_BOOL,
-        &ssl.nntp_nossl_radiobtn,
-       prefs_account_enum_set_data_from_radiobtn,
-        prefs_account_enum_set_radiobtn},
 
-#endif /* USE_SSL */
+       {"use_nonblocking_ssl", "1", &tmp_ac_prefs.use_nonblocking_ssl, P_BOOL,
+        &ssl.use_nonblocking_ssl_chkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+#else
+       /* SSL */
+       {"ssl_pop", "0", &tmp_ac_prefs.ssl_pop, P_ENUM,
+        NULL, NULL, NULL},
+       {"ssl_imap", "0", &tmp_ac_prefs.ssl_imap, P_ENUM,
+        NULL, NULL, NULL},
+       {"ssl_nntp", "0", &tmp_ac_prefs.ssl_nntp, P_ENUM,
+        NULL, NULL, NULL},
+       {"ssl_smtp", "0", &tmp_ac_prefs.ssl_smtp, P_ENUM,
+        NULL, NULL, NULL},
+
+       {"use_nonblocking_ssl", "1", &tmp_ac_prefs.use_nonblocking_ssl, P_BOOL,
+        NULL, NULL, NULL},
+#endif /* USE_OPENSSL */
 
        /* Advanced */
        {"set_smtpport", "FALSE", &tmp_ac_prefs.set_smtpport, P_BOOL,
@@ -446,7 +545,7 @@ static PrefParam param[] = {
         prefs_account_crosspost_set_colormenu},
 
        {"imap_directory", NULL, &tmp_ac_prefs.imap_dir, P_STRING,
-        &advanced.imapdir_entry, prefs_set_data_from_entry, prefs_set_entry},
+        &receive.imapdir_entry, prefs_set_data_from_entry, prefs_set_entry},
 
        {"set_sent_folder", "FALSE", &tmp_ac_prefs.set_sent_folder, P_BOOL,
         &advanced.sent_folder_chkbtn,
@@ -455,6 +554,13 @@ static PrefParam param[] = {
         &advanced.sent_folder_entry,
         prefs_set_data_from_entry, prefs_set_entry},
 
+       {"set_queue_folder", "FALSE", &tmp_ac_prefs.set_queue_folder, P_BOOL,
+        &advanced.queue_folder_chkbtn,
+        prefs_set_data_from_toggle, prefs_set_toggle},
+       {"queue_folder", NULL, &tmp_ac_prefs.queue_folder, P_STRING,
+        &advanced.queue_folder_entry,
+        prefs_set_data_from_entry, prefs_set_entry},
+
        {"set_draft_folder", "FALSE", &tmp_ac_prefs.set_draft_folder, P_BOOL,
         &advanced.draft_folder_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
@@ -472,64 +578,277 @@ static PrefParam param[] = {
        {NULL, NULL, NULL, P_OTHER, NULL, NULL, NULL}
 };
 
+static gint prefs_account_get_new_id           (void);
+
 static void prefs_account_create               (void);
 static void prefs_account_basic_create         (void);
 static void prefs_account_receive_create       (void);
 static void prefs_account_send_create          (void);
 static void prefs_account_compose_create       (void);
-#if USE_GPGME
 static void prefs_account_privacy_create       (void);
-#endif /* USE_GPGME */
-#if USE_SSL
+#if USE_OPENSSL
 static void prefs_account_ssl_create           (void);
-#endif /* USE_SSL */
+#endif /* USE_OPENSSL */
 static void prefs_account_advanced_create      (void);
 
 static void prefs_account_select_folder_cb     (GtkWidget      *widget,
                                                 gpointer        data);
-static void prefs_account_edit_custom_header   (void);
 
-static gint prefs_account_deleted              (GtkWidget      *widget,
-                                                GdkEventAny    *event,
+static void prefs_account_sigfile_radiobtn_cb  (GtkWidget      *widget,
                                                 gpointer        data);
-static void prefs_account_key_pressed          (GtkWidget      *widget,
-                                                GdkEventKey    *event,
+
+static void prefs_account_sigcmd_radiobtn_cb   (GtkWidget      *widget,
+                                                gpointer        data);
+
+static void prefs_account_signature_browse_cb  (GtkWidget      *widget,
+                                                gpointer        data);
+
+static void prefs_account_signature_edit_cb    (GtkWidget      *widget,
+                                                gpointer        data);
+
+static void pop_bfr_smtp_tm_set_sens           (GtkWidget      *widget,
                                                 gpointer        data);
-static void prefs_account_ok                   (void);
+
+static void prefs_account_edit_custom_header   (void);
+
 static gint prefs_account_apply                        (void);
-static void prefs_account_cancel               (void);
+
+typedef struct AccountPage
+{
+        PrefsPage page;
+        GtkWidget *vbox;
+} AccountPage;
+
+static AccountPage account_page;
+
+static void privacy_system_activated(GtkMenuItem *menuitem)
+{
+       const gchar* system_id;
+       gboolean privacy_enabled = FALSE;
+       
+       system_id = g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID);
+       
+       privacy_enabled = strcmp(system_id, "");
+
+       gtk_widget_set_sensitive (privacy.default_encrypt_chkbtn, privacy_enabled);
+       gtk_widget_set_sensitive (privacy.default_encrypt_reply_chkbtn, privacy_enabled);
+       gtk_widget_set_sensitive (privacy.default_sign_chkbtn, privacy_enabled);
+       gtk_widget_set_sensitive (privacy.encrypt_to_self_chkbtn, privacy_enabled);
+       gtk_widget_set_sensitive (privacy.save_clear_text_chkbtn, 
+               privacy_enabled && !gtk_toggle_button_get_active(
+                                       GTK_TOGGLE_BUTTON(privacy.encrypt_to_self_chkbtn)));
+}
+
+void update_privacy_system_menu() {
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+       GSList *system_ids, *cur;
+
+       menu = gtk_menu_new();
+
+       menuitem = gtk_menu_item_new_with_label(_("None"));
+       gtk_widget_show(menuitem);
+       g_object_set_data(G_OBJECT(menuitem), MENU_VAL_ID, "");
+       gtk_menu_append(GTK_MENU(menu), menuitem);
+
+       g_signal_connect(G_OBJECT(menuitem), "activate",
+                        G_CALLBACK(privacy_system_activated),
+                        NULL);
+
+       system_ids = privacy_get_system_ids();
+       for (cur = system_ids; cur != NULL; cur = g_slist_next(cur)) {
+               gchar *id = (gchar *) cur->data;
+               const gchar *name;
+               
+               name = privacy_system_get_name(id);
+               menuitem = gtk_menu_item_new_with_label(name);
+               gtk_widget_show(menuitem);
+               g_object_set_data_full(G_OBJECT(menuitem), MENU_VAL_ID, id, g_free);
+               gtk_menu_append(GTK_MENU(menu), menuitem);
+
+               g_signal_connect(G_OBJECT(menuitem), "activate",
+                                G_CALLBACK(privacy_system_activated),
+                                NULL);
+
+               
+       }
+
+       gtk_option_menu_set_menu(GTK_OPTION_MENU(privacy.default_privacy_system), menu);
+}
+
+static void create_widget_func(PrefsPage * _page,
+                                           GtkWindow * window,
+                                           gpointer data)
+{
+       AccountPage *page = (AccountPage *) _page;
+       PrefsAccount *ac_prefs = (PrefsAccount *) data;
+       GtkWidget *vbox;
+
+       vbox = gtk_vbox_new(FALSE, 6);
+       gtk_widget_show(vbox);
+
+       if (notebook == NULL)
+               prefs_account_create();
+       gtk_box_pack_start (GTK_BOX (vbox), notebook, TRUE, TRUE, 0);
+       gtk_notebook_set_current_page(GTK_NOTEBOOK(notebook), 0);
+
+       update_privacy_system_menu();
+
+       tmp_ac_prefs = *ac_prefs;
+
+       if (new_account) {
+               PrefsAccount *def_ac;
+               gchar *buf;
+
+               prefs_set_dialog_to_default(param);
+               buf = g_strdup_printf(_("Account%d"), ac_prefs->account_id);
+               gtk_entry_set_text(GTK_ENTRY(basic.acname_entry), buf);
+               g_free(buf);
+               def_ac = account_get_default();
+               if (def_ac) {
+                       gtk_entry_set_text(GTK_ENTRY(basic.name_entry),
+                                          def_ac->name ? def_ac->name : "");
+                       gtk_entry_set_text(GTK_ENTRY(basic.addr_entry),
+                                          def_ac->address ? def_ac->address : "");
+                       gtk_entry_set_text(GTK_ENTRY(basic.org_entry),
+                                          def_ac->organization ? def_ac->organization : "");
+               }
+               menu_set_sensitive_all
+                       (GTK_MENU_SHELL
+                               (gtk_option_menu_get_menu
+                                       (GTK_OPTION_MENU
+                                               (basic.protocol_optmenu))),
+                        TRUE);
+       } else
+               prefs_set_dialog(param);
+
+       pop_bfr_smtp_tm_set_sens (NULL, NULL);
+       
+       page->vbox = vbox;
+
+       page->page.widget = vbox;
+}
+
+static void destroy_widget_func(PrefsPage *_page)
+{
+       AccountPage *page = (AccountPage *) _page;
+
+       gtk_container_remove(GTK_CONTAINER (page->vbox), notebook);
+}
+
+static gboolean can_close_func(PrefsPage *page_)
+{      
+       return prefs_account_apply() >= 0;
+}
+
+static void save_func(PrefsPage * _page)
+{
+       if (prefs_account_apply() >= 0)
+               cancelled = FALSE;
+}
+
+void prefs_account_init()
+{
+       static gchar *path[2];
+
+       path[0] = _("Account");
+       path[2] = NULL;
+        
+       account_page.page.path = path;
+       account_page.page.weight = 1000.0;
+       account_page.page.create_widget = create_widget_func;
+       account_page.page.destroy_widget = destroy_widget_func;
+       account_page.page.save_page = save_func;
+       account_page.page.can_close = can_close_func;
+
+       prefs_account_register_page((PrefsPage *) &account_page);
+}
+
+PrefsAccount *prefs_account_new(void)
+{
+       PrefsAccount *ac_prefs;
+
+       ac_prefs = g_new0(PrefsAccount, 1);
+       memset(&tmp_ac_prefs, 0, sizeof(PrefsAccount));
+       prefs_set_default(param);
+       *ac_prefs = tmp_ac_prefs;
+       ac_prefs->account_id = prefs_account_get_new_id();
+
+       ac_prefs->privacy_prefs = g_hash_table_new(g_str_hash, g_str_equal);
+
+       return ac_prefs;
+}
 
 void prefs_account_read_config(PrefsAccount *ac_prefs, const gchar *label)
 {
        const gchar *p = label;
+       gchar *rcpath;
        gint id;
+       gchar **strv, **cur;
 
        g_return_if_fail(ac_prefs != NULL);
        g_return_if_fail(label != NULL);
 
        memset(&tmp_ac_prefs, 0, sizeof(PrefsAccount));
-       prefs_read_config(param, label, ACCOUNT_RC);
+       tmp_ac_prefs.privacy_prefs = ac_prefs->privacy_prefs;
+
+       rcpath = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S, ACCOUNT_RC, NULL);
+       prefs_read_config(param, label, rcpath, NULL);
+       g_free(rcpath);
+
        *ac_prefs = tmp_ac_prefs;
-       while (*p && !isdigit(*p)) p++;
+       while (*p && !g_ascii_isdigit(*p)) p++;
        id = atoi(p);
        if (id < 0) g_warning("wrong account id: %d\n", id);
        ac_prefs->account_id = id;
 
+       if (ac_prefs->protocol == A_APOP) {
+               debug_print("converting protocol A_APOP to new prefs.\n");
+               ac_prefs->protocol = A_POP3;
+               ac_prefs->use_apop_auth = TRUE;
+       }
+
+       if (privacy_prefs != NULL) {
+               strv = g_strsplit(privacy_prefs, ",", 0);
+               for (cur = strv; *cur != NULL; cur++) {
+                       gchar *encvalue, *value;
+
+                       encvalue = strchr(*cur, '=');
+                       if (encvalue == NULL)
+                               continue;
+                       encvalue[0] = '\0';
+                       encvalue++;
+
+                       value = g_malloc0(strlen(encvalue));
+                       if (base64_decode(value, encvalue, strlen(encvalue)) > 0)
+                               g_hash_table_insert(ac_prefs->privacy_prefs, g_strdup(*cur), g_strdup(value));
+                       g_free(value);
+               }
+               g_strfreev(strv);
+               g_free(privacy_prefs);
+               privacy_prefs = NULL;
+       }
+
        prefs_custom_header_read_config(ac_prefs);
 }
 
-void prefs_account_save_config(PrefsAccount *ac_prefs)
+static void create_privacy_prefs(gpointer key, gpointer _value, gpointer user_data)
 {
-       gchar *buf;
+       GString *str = (GString *) user_data;
+       gchar *encvalue;
+       gchar *value = (gchar *) _value;
 
-       g_return_if_fail(ac_prefs != NULL);
+       if (str->len > 0)
+               g_string_append_c(str, ',');
 
-       tmp_ac_prefs = *ac_prefs;
-       buf = g_strdup_printf("Account: %d", ac_prefs->account_id);
-       prefs_save_config(param, buf, ACCOUNT_RC);
+       encvalue = g_malloc0(B64LEN(strlen(value)) + 1);
+       base64_encode(encvalue, (gchar *) value, strlen(value));
+       g_string_append_printf(str, "%s=%s", (gchar *) key, encvalue);
+       g_free(encvalue);
 }
 
-void prefs_account_save_config_all(GList *account_list)
+void prefs_account_write_config_all(GList *account_list)
 {
        GList *cur;
        gchar *rcpath;
@@ -543,35 +862,79 @@ void prefs_account_save_config_all(GList *account_list)
        g_free(rcpath);
 
        for (cur = account_list; cur != NULL; cur = cur->next) {
+               GString *str;
+
                tmp_ac_prefs = *(PrefsAccount *)cur->data;
                if (fprintf(pfile->fp, "[Account: %d]\n",
-                           tmp_ac_prefs.account_id) <= 0 ||
-                   prefs_write_param(param, pfile->fp) < 0) {
-                       g_warning(_("failed to write configuration to file\n"));
-                       prefs_write_close_revert(pfile);
+                           tmp_ac_prefs.account_id) <= 0)
                        return;
-               }
+
+               str = g_string_sized_new(32);
+               g_hash_table_foreach(tmp_ac_prefs.privacy_prefs, create_privacy_prefs, str);
+               privacy_prefs = str->str;                   
+               g_string_free(str, FALSE);
+
+               if (prefs_write_param(param, pfile->fp) < 0) {
+                       g_warning("failed to write configuration to file\n");
+                       prefs_file_close_revert(pfile);
+                       g_free(privacy_prefs);
+                       privacy_prefs = NULL;
+                       return;
+               }
+               g_free(privacy_prefs);
+               privacy_prefs = NULL;
+
                if (cur->next) {
                        if (fputc('\n', pfile->fp) == EOF) {
                                FILE_OP_ERROR(rcpath, "fputc");
-                               prefs_write_close_revert(pfile);
+                               prefs_file_close_revert(pfile);
                                return;
                        }
                }
        }
 
-       if (prefs_write_close(pfile) < 0)
-               g_warning(_("failed to write configuration to file\n"));
+       if (prefs_file_close(pfile) < 0)
+               g_warning("failed to write configuration to file\n");
+}
+
+static gboolean free_privacy_prefs(gpointer key, gpointer value, gpointer user_data)
+{
+       g_free(key);
+       g_free(value);
+
+       return TRUE;
 }
 
 void prefs_account_free(PrefsAccount *ac_prefs)
 {
        if (!ac_prefs) return;
 
+       g_hash_table_foreach_remove(ac_prefs->privacy_prefs, free_privacy_prefs, NULL);
+
        tmp_ac_prefs = *ac_prefs;
        prefs_free(param);
 }
 
+const gchar *prefs_account_get_privacy_prefs(PrefsAccount *account, gchar *id)
+{
+       return g_hash_table_lookup(account->privacy_prefs, id);
+}
+
+void prefs_account_set_privacy_prefs(PrefsAccount *account, gchar *id, gchar *new_value)
+{
+       gchar *orig_key = NULL, *value;
+
+       if (g_hash_table_lookup_extended(account->privacy_prefs, id, (gpointer *)(gchar *) &orig_key, (gpointer *)(gchar *) &value)) {
+               g_hash_table_remove(account->privacy_prefs, id);
+
+               g_free(orig_key);
+               g_free(value);
+       }
+
+       if (new_value != NULL)
+               g_hash_table_insert(account->privacy_prefs, g_strdup(id), g_strdup(new_value));
+}
+
 static gint prefs_account_get_new_id(void)
 {
        GList *ac_list;
@@ -588,130 +951,88 @@ static gint prefs_account_get_new_id(void)
        return last_id + 1;
 }
 
+void destroy_dialog(gpointer data)
+{
+       PrefsAccount *ac_prefs = (PrefsAccount *) data;
+       if (!cancelled)
+               *ac_prefs = tmp_ac_prefs;
+       else /* the customhdr_list may have changed, update it anyway */
+               ac_prefs->customhdr_list = (&tmp_ac_prefs)->customhdr_list;
+       gtk_main_quit();
+}
+
 PrefsAccount *prefs_account_open(PrefsAccount *ac_prefs)
 {
-       gboolean new_account = FALSE;
+       gchar *title;
 
        if (prefs_rc_is_readonly(ACCOUNT_RC))
                return ac_prefs;
 
-       debug_print(_("Opening account preferences window...\n"));
+       debug_print("Opening account preferences window...\n");
 
        inc_lock();
 
-       cancelled = FALSE;
+       cancelled = TRUE;
 
        if (!ac_prefs) {
-               ac_prefs = g_new0(PrefsAccount, 1);
-               memset(&tmp_ac_prefs, 0, sizeof(PrefsAccount));
-               prefs_set_default(param);
-               *ac_prefs = tmp_ac_prefs;
-               ac_prefs->account_id = prefs_account_get_new_id();
+               ac_prefs = prefs_account_new();
                new_account = TRUE;
-       }
-
-       if (!dialog.window) {
-               prefs_account_create();
-       }
-
-       manage_window_set_transient(GTK_WINDOW(dialog.window));
-       gtk_notebook_set_page(GTK_NOTEBOOK(dialog.notebook), 0);
-       gtk_widget_grab_focus(dialog.ok_btn);
-
-       tmp_ac_prefs = *ac_prefs;
-
-       if (new_account) {
-               PrefsAccount *def_ac;
-               gchar *buf;
-
-               prefs_set_dialog_to_default(param);
-               buf = g_strdup_printf(_("Account%d"), ac_prefs->account_id);
-               gtk_entry_set_text(GTK_ENTRY(basic.acname_entry), buf);
-               g_free(buf);
-               def_ac = account_get_default();
-               if (def_ac) {
-                       gtk_entry_set_text(GTK_ENTRY(basic.name_entry),
-                                          def_ac->name ? def_ac->name : "");
-                       gtk_entry_set_text(GTK_ENTRY(basic.addr_entry),
-                                          def_ac->address ? def_ac->address : "");
-                       gtk_entry_set_text(GTK_ENTRY(basic.org_entry),
-                                          def_ac->organization ? def_ac->organization : "");
-               }
-               menu_set_sensitive_all
-                       (GTK_MENU_SHELL
-                               (gtk_option_menu_get_menu
-                                       (GTK_OPTION_MENU
-                                               (basic.protocol_optmenu))),
-                        TRUE);
-               gtk_window_set_title(GTK_WINDOW(dialog.window),
-                                    _("Preferences for new account"));
-               gtk_widget_hide(dialog.apply_btn);
-       } else {
-               prefs_set_dialog(param);
-               gtk_window_set_title(GTK_WINDOW(dialog.window),
-                                    _("Account preferences"));
-               gtk_widget_show(dialog.apply_btn);
-       }
-
-       if (ac_prefs->protocol != A_LOCAL) {
-               gtk_widget_set_sensitive(basic.smtpserv_entry, TRUE);
-               gtk_widget_set_sensitive(basic.smtpserv_label, TRUE);
-       }
-
-       gtk_widget_show(dialog.window);
+       } else
+               new_account = FALSE;
+
+       if (new_account)
+               title = g_strdup (_("Preferences for new account"));
+       else
+               title = g_strdup_printf (_("%s - Account preferences"),
+                               ac_prefs->account_name);
+
+       prefswindow_open_full(title, prefs_pages, ac_prefs, destroy_dialog,
+                       &prefs_common.editaccountwin_width, &prefs_common.editaccountwin_height);
+       g_free(title);
        gtk_main();
-       gtk_widget_hide(dialog.window);
 
        inc_unlock();
 
        if (cancelled && new_account) {
-               g_free(ac_prefs);
+               prefs_account_free(ac_prefs);
                return NULL;
-       } else {
-               *ac_prefs = tmp_ac_prefs;
+       } else 
                return ac_prefs;
-       }
 }
 
 static void prefs_account_create(void)
 {
        gint page = 0;
 
-       debug_print(_("Creating account preferences window...\n"));
+       debug_print("Creating account preferences window...\n");
 
-       /* create dialog */
-       prefs_dialog_create(&dialog);
-       gtk_signal_connect(GTK_OBJECT(dialog.window), "delete_event",
-                          GTK_SIGNAL_FUNC(prefs_account_deleted), NULL);
-       gtk_signal_connect(GTK_OBJECT(dialog.window), "key_press_event",
-                          GTK_SIGNAL_FUNC(prefs_account_key_pressed), NULL);
-       MANAGE_WINDOW_SIGNALS_CONNECT(dialog.window);
+       notebook = gtk_notebook_new ();
+       gtk_widget_show(notebook);
+       gtk_container_set_border_width (GTK_CONTAINER (notebook), 2);
+       /* GTK_WIDGET_UNSET_FLAGS (notebook, GTK_CAN_FOCUS); */
+       gtk_notebook_set_scrollable (GTK_NOTEBOOK (notebook), TRUE);
+       
+       gtk_notebook_popup_enable (GTK_NOTEBOOK (notebook));
 
-       gtk_signal_connect(GTK_OBJECT(dialog.ok_btn), "clicked",
-                          GTK_SIGNAL_FUNC(prefs_account_ok), NULL);
-       gtk_signal_connect(GTK_OBJECT(dialog.apply_btn), "clicked",
-                          GTK_SIGNAL_FUNC(prefs_account_apply), NULL);
-       gtk_signal_connect(GTK_OBJECT(dialog.cancel_btn), "clicked",
-                          GTK_SIGNAL_FUNC(prefs_account_cancel), NULL);
+       gtk_widget_ref(notebook);
 
+       /* create all widgets on notebook */
        prefs_account_basic_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("Basic"), page++);
+       SET_NOTEBOOK_LABEL(notebook, _("_Basic"), page++);
        prefs_account_receive_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("Receive"), page++);
+       SET_NOTEBOOK_LABEL(notebook, _("_Receive"), page++);
        prefs_account_send_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("Send"), page++);
+       SET_NOTEBOOK_LABEL(notebook, _("_Send"), page++);
        prefs_account_compose_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("Compose"), page++);
-#if USE_GPGME
+       SET_NOTEBOOK_LABEL(notebook, _("Co_mpose"), page++);
        prefs_account_privacy_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("Privacy"), page++);
-#endif /* USE_GPGME */
-#if USE_SSL
+       SET_NOTEBOOK_LABEL(notebook, _("_Privacy"), page++);
+#if USE_OPENSSL
        prefs_account_ssl_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("SSL"), page++);
-#endif /* USE_SSL */
+       SET_NOTEBOOK_LABEL(notebook, _("SS_L"), page++);
+#endif /* USE_OPENSSL */
        prefs_account_advanced_create();
-       SET_NOTEBOOK_LABEL(dialog.notebook, _("Advanced"), page++);
+       SET_NOTEBOOK_LABEL(notebook, _("A_dvanced"), page++);
 
        prefs_account_fix_size();
 }
@@ -737,9 +1058,9 @@ static void prefs_account_fix_size(void)
 
 #define SET_ACTIVATE(menuitem) \
 { \
-       gtk_signal_connect(GTK_OBJECT(menuitem), "activate", \
-                          GTK_SIGNAL_FUNC(prefs_account_protocol_activated), \
-                          NULL); \
+       g_signal_connect(G_OBJECT(menuitem), "activate", \
+                        G_CALLBACK(prefs_account_protocol_activated), \
+                        NULL); \
 }
 
 #define TABLE_YPAD 2
@@ -772,6 +1093,7 @@ static void prefs_account_basic_create(void)
        GtkWidget *smtpserv_entry;
        GtkWidget *nntpserv_entry;
        GtkWidget *nntpauth_chkbtn;
+       GtkWidget *nntpauth_onconnect_chkbtn;
        GtkWidget *localmbox_entry;
        GtkWidget *mailcmd_chkbtn;
        GtkWidget *mailcmd_entry;
@@ -782,20 +1104,20 @@ static void prefs_account_basic_create(void)
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
        hbox = gtk_hbox_new (FALSE, 8);
        gtk_widget_show (hbox);
        gtk_box_pack_start (GTK_BOX (vbox1), hbox, FALSE, FALSE, 0);
 
-       label = gtk_label_new (_("Name of this account"));
+       label = gtk_label_new (_("Name of account"));
        gtk_widget_show (label);
        gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
 
        acname_entry = gtk_entry_new ();
        gtk_widget_show (acname_entry);
-       gtk_widget_set_usize (acname_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_widget_set_size_request (acname_entry, DEFAULT_ENTRY_WIDTH, -1);
        gtk_box_pack_start (GTK_BOX (hbox), acname_entry, TRUE, TRUE, 0);
 
        default_chkbtn = gtk_check_button_new_with_label (_("Set as default"));
@@ -868,15 +1190,15 @@ static void prefs_account_basic_create(void)
 
        optmenu_menu = gtk_menu_new ();
 
-       MENUITEM_ADD (optmenu_menu, menuitem, _("POP3 (normal)"),  A_POP3);
-       SET_ACTIVATE (menuitem);
-       MENUITEM_ADD (optmenu_menu, menuitem, _("POP3 (APOP auth)"),  A_APOP);
+       MENUITEM_ADD (optmenu_menu, menuitem, _("POP3"),  A_POP3);
        SET_ACTIVATE (menuitem);
        MENUITEM_ADD (optmenu_menu, menuitem, _("IMAP4"), A_IMAP4);
        SET_ACTIVATE (menuitem);
        MENUITEM_ADD (optmenu_menu, menuitem, _("News (NNTP)"), A_NNTP);
        SET_ACTIVATE (menuitem);
-       MENUITEM_ADD (optmenu_menu, menuitem, _("None (local)"), A_LOCAL);
+       MENUITEM_ADD (optmenu_menu, menuitem, _("Local mbox file"), A_LOCAL);
+       SET_ACTIVATE (menuitem);
+       MENUITEM_ADD (optmenu_menu, menuitem, _("None (SMTP only)"), A_NONE);
        SET_ACTIVATE (menuitem);
 
        gtk_option_menu_set_menu (GTK_OPTION_MENU (optmenu), optmenu_menu);
@@ -898,7 +1220,15 @@ static void prefs_account_basic_create(void)
        nntpauth_chkbtn = gtk_check_button_new_with_label
                (_("This server requires authentication"));
        gtk_widget_show (nntpauth_chkbtn);
-       gtk_table_attach (GTK_TABLE (serv_table), nntpauth_chkbtn, 0, 4, 1, 2,
+       
+       gtk_table_attach (GTK_TABLE (serv_table), nntpauth_chkbtn, 0, 2, 6, 7,
+                         GTK_FILL, 0, 0, 0);
+
+       nntpauth_onconnect_chkbtn = gtk_check_button_new_with_label
+               (_("Authenticate on connect"));
+       gtk_widget_show (nntpauth_onconnect_chkbtn);
+
+       gtk_table_attach (GTK_TABLE (serv_table), nntpauth_onconnect_chkbtn, 2, 4, 6, 7,
                          GTK_FILL, 0, 0, 0);
 
        recvserv_entry = gtk_entry_new ();
@@ -927,14 +1257,14 @@ static void prefs_account_basic_create(void)
 
        uid_entry = gtk_entry_new ();
        gtk_widget_show (uid_entry);
-       gtk_widget_set_usize (uid_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_widget_set_size_request (uid_entry, DEFAULT_ENTRY_WIDTH, -1);
        gtk_table_attach (GTK_TABLE (serv_table), uid_entry, 1, 2, 7, 8,
                          GTK_EXPAND | GTK_SHRINK | GTK_FILL,
                          GTK_EXPAND | GTK_SHRINK | GTK_FILL, 0, 0);
 
        pass_entry = gtk_entry_new ();
        gtk_widget_show (pass_entry);
-       gtk_widget_set_usize (pass_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_widget_set_size_request (pass_entry, DEFAULT_ENTRY_WIDTH, -1);
        gtk_table_attach (GTK_TABLE (serv_table), pass_entry, 3, 4, 7, 8,
                          GTK_EXPAND | GTK_SHRINK | GTK_FILL,
                          GTK_EXPAND | GTK_SHRINK | GTK_FILL, 0, 0);
@@ -952,7 +1282,7 @@ static void prefs_account_basic_create(void)
                          GTK_FILL, 0, 0, 0);
        gtk_misc_set_alignment (GTK_MISC (recvserv_label), 1, 0.5);
 
-       localmbox_label = gtk_label_new (_("Local mailbox file"));
+       localmbox_label = gtk_label_new (_("Local mailbox"));
        gtk_widget_show (localmbox_label);
        gtk_table_attach (GTK_TABLE (serv_table), localmbox_label, 0, 1, 3, 4,
                          GTK_FILL, 0, 0, 0);
@@ -972,9 +1302,9 @@ static void prefs_account_basic_create(void)
        gtk_table_attach (GTK_TABLE (serv_table), mailcmd_chkbtn, 0, 4, 5, 6,
                          GTK_EXPAND | GTK_FILL,
                          0, 0, TABLE_YPAD);
-       gtk_signal_connect(GTK_OBJECT(mailcmd_chkbtn), "toggled",
-                          GTK_SIGNAL_FUNC(prefs_account_mailcmd_toggled),
-                          NULL);
+       g_signal_connect(G_OBJECT(mailcmd_chkbtn), "toggled",
+                        G_CALLBACK(prefs_account_mailcmd_toggled),
+                        NULL);
 
        mailcmd_label = gtk_label_new (_("command to send mails"));
        gtk_widget_show (mailcmd_label);
@@ -998,6 +1328,7 @@ static void prefs_account_basic_create(void)
        SET_TOGGLE_SENSITIVITY (nntpauth_chkbtn, pass_label);
        SET_TOGGLE_SENSITIVITY (nntpauth_chkbtn, uid_entry);
        SET_TOGGLE_SENSITIVITY (nntpauth_chkbtn, pass_entry);
+       SET_TOGGLE_SENSITIVITY (nntpauth_chkbtn, nntpauth_onconnect_chkbtn);
 
        basic.acname_entry   = acname_entry;
        basic.default_chkbtn = default_chkbtn;
@@ -1016,6 +1347,7 @@ static void prefs_account_basic_create(void)
        basic.nntpserv_label   = nntpserv_label;
        basic.nntpserv_entry   = nntpserv_entry;
        basic.nntpauth_chkbtn  = nntpauth_chkbtn;
+       basic.nntpauth_onconnect_chkbtn  = nntpauth_onconnect_chkbtn;
        basic.localmbox_label   = localmbox_label;
        basic.localmbox_entry   = localmbox_entry;
        basic.mailcmd_chkbtn   = mailcmd_chkbtn;
@@ -1032,55 +1364,128 @@ static void prefs_account_receive_create(void)
        GtkWidget *vbox1;
        GtkWidget *frame1;
        GtkWidget *vbox2;
+       GtkWidget *use_apop_chkbtn;
        GtkWidget *rmmail_chkbtn;
+       GtkWidget *hbox_spc;
+       GtkTooltips *leave_time_tooltip;
+       GtkWidget *leave_time_label;
+       GtkWidget *leave_time_entry;
        GtkWidget *getall_chkbtn;
        GtkWidget *hbox1;
        GtkWidget *size_limit_chkbtn;
        GtkWidget *size_limit_entry;
+       GtkTooltips *size_limit_tooltip;
        GtkWidget *label;
        GtkWidget *filter_on_recv_chkbtn;
        GtkWidget *vbox3;
-       GtkWidget *hbox2;
        GtkWidget *inbox_label;
        GtkWidget *inbox_entry;
-       GtkWidget *leave_time_entry;
-       GtkWidget *leave_time_label;
-       GtkWidget *leave_time_hint;     
        GtkWidget *inbox_btn;
-       GtkWidget *recvatgetall_chkbtn;
+       GtkTooltips *inbox_tooltip;
+       GtkWidget *imap_frame;
+       GtkWidget *imapdir_label;
+       GtkWidget *imapdir_entry;
+       GtkWidget *local_frame;
+       GtkWidget *local_vbox;
+       GtkWidget *local_hbox;
+       GtkWidget *local_inbox_label;
+       GtkWidget *local_inbox_entry;
+       GtkWidget *local_inbox_btn;
+
+       GtkWidget *optmenu;
+       GtkWidget *optmenu_menu;
+       GtkWidget *menuitem;
+       GtkWidget *recvatgetall_chkbtn;
+
+       GtkWidget *hbox2;
+       GtkWidget *frame2;
+       GtkWidget *maxarticle_label;
+       GtkWidget *maxarticle_spinbtn;
+       GtkObject *maxarticle_spinbtn_adj;
+       GtkTooltips *maxarticle_tool_tip;
+
+       inbox_tooltip = gtk_tooltips_new();
+       size_limit_tooltip = gtk_tooltips_new();
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
+       PACK_FRAME (vbox1, local_frame, _("Local"));
+
+       local_vbox = gtk_vbox_new (FALSE, 0);
+       gtk_widget_show (local_vbox);
+       gtk_container_add (GTK_CONTAINER (local_frame), local_vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (local_vbox), VBOX_BORDER);
+
+       local_hbox = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (local_hbox);
+       gtk_box_pack_start (GTK_BOX (local_vbox), local_hbox, FALSE, FALSE, 0);
+
+       local_inbox_label = gtk_label_new (_("Default inbox"));
+       gtk_widget_show (local_inbox_label);
+       gtk_box_pack_start (GTK_BOX (local_hbox), local_inbox_label, FALSE, FALSE, 0);
+
+       local_inbox_entry = gtk_entry_new ();
+       gtk_widget_show (local_inbox_entry);
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(inbox_tooltip), local_inbox_entry,
+                            _("Unfiltered messages will be stored in this folder"),
+                            NULL);
+       gtk_widget_set_size_request (local_inbox_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_box_pack_start (GTK_BOX (local_hbox), local_inbox_entry, TRUE, TRUE, 0);
+
+       local_inbox_btn = gtkut_get_browse_file_btn(_("Bro_wse"));
+       gtk_widget_show (local_inbox_btn);
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(inbox_tooltip), local_inbox_btn,
+                            _("Unfiltered messages will be stored in this folder"),
+                            NULL);
+       gtk_box_pack_start (GTK_BOX (local_hbox), local_inbox_btn, FALSE, FALSE, 0);
+       g_signal_connect (G_OBJECT (local_inbox_btn), "clicked",
+                         G_CALLBACK (prefs_account_select_folder_cb),
+                         local_inbox_entry);
+
        PACK_FRAME (vbox1, frame1, _("POP3"));
 
        vbox2 = gtk_vbox_new (FALSE, 0);
        gtk_widget_show (vbox2);
        gtk_container_add (GTK_CONTAINER (frame1), vbox2);
-       gtk_container_set_border_width (GTK_CONTAINER (vbox2), 8);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox2), VBOX_BORDER);
 
-       hbox2 = gtk_hbox_new (FALSE, 0);
-       gtk_widget_show (hbox2);
-       gtk_container_add (GTK_CONTAINER (vbox2), hbox2);
-       gtk_container_set_border_width (GTK_CONTAINER (hbox2), 0);
+       PACK_CHECK_BUTTON (vbox2, use_apop_chkbtn,
+                          _("Use secure authentication (APOP)"));
+
+       PACK_CHECK_BUTTON (vbox2, rmmail_chkbtn,
+                          _("Remove messages on server when received"));
+
+       hbox1 = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox1);
+       gtk_box_pack_start (GTK_BOX (vbox2), hbox1, FALSE, FALSE, 0);
+
+       hbox_spc = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox_spc);
+       gtk_box_pack_start (GTK_BOX (hbox1), hbox_spc, FALSE, FALSE, 0);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
+
+       leave_time_label = gtk_label_new (_("Remove after"));
+       gtk_widget_show (leave_time_label);
+       gtk_box_pack_start (GTK_BOX (hbox1), leave_time_label, FALSE, FALSE, 0);
+
+       leave_time_tooltip = gtk_tooltips_new();
 
-       PACK_CHECK_BUTTON (hbox2, rmmail_chkbtn,
-                          _("Remove messages on server when received for "));
        leave_time_entry = gtk_entry_new ();
        gtk_widget_show (leave_time_entry);
-       gtk_widget_set_usize (leave_time_entry, DEFAULT_ENTRY_WIDTH, -1);
-       gtk_box_pack_start (GTK_BOX (hbox2), leave_time_entry, TRUE, TRUE, 0);
-       
-       leave_time_label = gtk_label_new (_(" days"));
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(leave_time_tooltip), leave_time_entry,
+                            _("0 days: remove immediately"), NULL);
+       gtk_widget_set_size_request (leave_time_entry, 64, -1);
+       gtk_box_pack_start (GTK_BOX (hbox1), leave_time_entry, FALSE, FALSE, 0);
+
+       leave_time_label = gtk_label_new (_("days"));
        gtk_widget_show (leave_time_label);
-       gtk_box_pack_start (GTK_BOX (hbox2), leave_time_label, FALSE, FALSE, 0);
-       
-       leave_time_hint=gtk_label_new (_("(Setting to 0 days will delete messages immediately)"));
-       gtk_widget_show(leave_time_hint);
-       gtk_box_pack_start (GTK_BOX (vbox2), leave_time_hint, FALSE, FALSE, 0);
-               
+       gtk_box_pack_start (GTK_BOX (hbox1), leave_time_label, FALSE, FALSE, 0);
+
+       SET_TOGGLE_SENSITIVITY (rmmail_chkbtn, hbox1);
+
        PACK_CHECK_BUTTON (vbox2, getall_chkbtn,
                           _("Download all messages on server"));
 
@@ -1090,20 +1495,23 @@ static void prefs_account_receive_create(void)
 
        PACK_CHECK_BUTTON (hbox1, size_limit_chkbtn, _("Receive size limit"));
 
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(size_limit_tooltip), size_limit_chkbtn,
+                            _("Messages over this limit will be partially retrieved. "
+                              "When selecting them you will be able to download them fully "
+                              "or delete them."),
+                            NULL);
+
        size_limit_entry = gtk_entry_new ();
        gtk_widget_show (size_limit_entry);
-       gtk_widget_set_usize (size_limit_entry, 64, -1);
+       gtk_widget_set_size_request (size_limit_entry, 64, -1);
        gtk_box_pack_start (GTK_BOX (hbox1), size_limit_entry, FALSE, FALSE, 0);
 
-       label = gtk_label_new ("KB");
+       label = gtk_label_new (_("KB"));
        gtk_widget_show (label);
        gtk_box_pack_start (GTK_BOX (hbox1), label, FALSE, FALSE, 0);
 
        SET_TOGGLE_SENSITIVITY (size_limit_chkbtn, size_limit_entry);
 
-       PACK_CHECK_BUTTON (vbox2, filter_on_recv_chkbtn,
-                          _("Filter messages on receiving"));
-
        PACK_VSPACER(vbox2, vbox3, VSPACING_NARROW_2);
 
        hbox1 = gtk_hbox_new (FALSE, 8);
@@ -1116,44 +1524,133 @@ static void prefs_account_receive_create(void)
 
        inbox_entry = gtk_entry_new ();
        gtk_widget_show (inbox_entry);
-       gtk_widget_set_usize (inbox_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(inbox_tooltip), inbox_entry,
+                            _("Unfiltered messages will be stored in this folder"),
+                            NULL);
+       gtk_widget_set_size_request (inbox_entry, DEFAULT_ENTRY_WIDTH, -1);
        gtk_box_pack_start (GTK_BOX (hbox1), inbox_entry, TRUE, TRUE, 0);
 
-       inbox_btn = gtk_button_new_with_label (_(" Select... "));
+       inbox_btn = gtkut_get_browse_file_btn(_("Bro_wse"));
        gtk_widget_show (inbox_btn);
+       gtk_tooltips_set_tip(GTK_TOOLTIPS(inbox_tooltip), inbox_btn,
+                            _("Unfiltered messages will be stored in this folder"),
+                            NULL);
        gtk_box_pack_start (GTK_BOX (hbox1), inbox_btn, FALSE, FALSE, 0);
-       gtk_signal_connect (GTK_OBJECT (inbox_btn), "clicked",
-                           GTK_SIGNAL_FUNC (prefs_account_select_folder_cb),
-                           inbox_entry);
+       g_signal_connect (G_OBJECT (inbox_btn), "clicked",
+                         G_CALLBACK (prefs_account_select_folder_cb),
+                         inbox_entry);
 
-       PACK_VSPACER(vbox2, vbox3, VSPACING_NARROW_2);
+       PACK_FRAME(vbox1, frame2, _("NNTP"));
+
+       vbox2 = gtk_vbox_new (FALSE, 0);
+       gtk_widget_show (vbox2);
+       gtk_container_add (GTK_CONTAINER (frame2), vbox2);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox2), VBOX_BORDER);
+
+       hbox2 = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox2);
+       gtk_box_pack_start (GTK_BOX (vbox2), hbox2, FALSE, FALSE, 0);
+
+       maxarticle_label = gtk_label_new
+               (_("Maximum number of articles to download"));
+       gtk_widget_show (maxarticle_label);
+       gtk_box_pack_start (GTK_BOX (hbox2), maxarticle_label, FALSE, FALSE, 0);
+
+       maxarticle_tool_tip = gtk_tooltips_new();
+
+       maxarticle_spinbtn_adj =
+               gtk_adjustment_new (300, 0, 10000, 10, 100, 100);
+       maxarticle_spinbtn = gtk_spin_button_new
+               (GTK_ADJUSTMENT (maxarticle_spinbtn_adj), 10, 0);
+       gtk_widget_show (maxarticle_spinbtn);
+       gtk_tooltips_set_tip(maxarticle_tool_tip, maxarticle_spinbtn,
+                            _("unlimited if 0 is specified"), NULL);
+       gtk_box_pack_start (GTK_BOX (hbox2), maxarticle_spinbtn,
+                           FALSE, FALSE, 0);
+       gtk_widget_set_size_request (maxarticle_spinbtn, 64, -1);
+       gtk_spin_button_set_numeric
+               (GTK_SPIN_BUTTON (maxarticle_spinbtn), TRUE);
+
+       PACK_FRAME (vbox1, imap_frame, _("IMAP4"));
+
+       vbox2 = gtk_vbox_new (FALSE, 0);
+       gtk_widget_show (vbox2);
+       gtk_container_add (GTK_CONTAINER (imap_frame), vbox2);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox2), VBOX_BORDER);
 
        hbox1 = gtk_hbox_new (FALSE, 8);
        gtk_widget_show (hbox1);
        gtk_box_pack_start (GTK_BOX (vbox2), hbox1, FALSE, FALSE, 0);
 
-       label = gtk_label_new
-               (_("(Unfiltered messages will be stored in this folder)"));
+       label = gtk_label_new (_("Authentication method"));
        gtk_widget_show (label);
        gtk_box_pack_start (GTK_BOX (hbox1), label, FALSE, FALSE, 0);
-       gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
+
+       optmenu = gtk_option_menu_new ();
+       gtk_widget_show (optmenu);
+       gtk_box_pack_start (GTK_BOX (hbox1), optmenu, FALSE, FALSE, 0);
+
+       optmenu_menu = gtk_menu_new ();
+
+       MENUITEM_ADD (optmenu_menu, menuitem, _("Automatic"), 0);
+       MENUITEM_ADD (optmenu_menu, menuitem, "LOGIN", IMAP_AUTH_LOGIN);
+       MENUITEM_ADD (optmenu_menu, menuitem, "CRAM-MD5", IMAP_AUTH_CRAM_MD5);
+       MENUITEM_ADD (optmenu_menu, menuitem, "ANONYMOUS", IMAP_AUTH_ANON);
+
+       gtk_option_menu_set_menu (GTK_OPTION_MENU (optmenu), optmenu_menu);
+
+       hbox1 = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox1);
+       gtk_box_pack_start (GTK_BOX (vbox2), hbox1, FALSE, FALSE, 4);
+
+       imapdir_label = gtk_label_new (_("IMAP server directory"));
+       gtk_widget_show (imapdir_label);
+       gtk_box_pack_start (GTK_BOX (hbox1), imapdir_label, FALSE, FALSE, 0);
+
+       imapdir_label = gtk_label_new(_("(usually empty)"));
+       gtk_widget_show (imapdir_label);
+       gtkut_widget_set_small_font_size (imapdir_label);
+       gtk_box_pack_start (GTK_BOX (hbox1), imapdir_label, FALSE, FALSE, 0);
+
+       imapdir_entry = gtk_entry_new();
+       gtk_widget_show (imapdir_entry);
+       gtk_box_pack_start (GTK_BOX (hbox1), imapdir_entry, FALSE, FALSE, 0);
+
+       PACK_CHECK_BUTTON (vbox1, filter_on_recv_chkbtn,
+                          _("Filter messages on receiving"));
 
        PACK_CHECK_BUTTON
                (vbox1, recvatgetall_chkbtn,
-                _("`Get all' checks for new messages on this account"));
-
-       receive.pop3_frame            = frame1;
-       receive.rmmail_chkbtn         = rmmail_chkbtn;
-       receive.leave_time_entry      = leave_time_entry;
-       receive.getall_chkbtn         = getall_chkbtn;
-       receive.size_limit_chkbtn     = size_limit_chkbtn;
-       receive.size_limit_entry      = size_limit_entry;
-       receive.filter_on_recv_chkbtn = filter_on_recv_chkbtn;
-       receive.inbox_label           = inbox_label;
-       receive.inbox_entry           = inbox_entry;
-       receive.inbox_btn             = inbox_btn;
-
-       receive.recvatgetall_chkbtn   = recvatgetall_chkbtn;
+                _("'Get Mail' checks for new messages on this account"));
+
+       receive.pop3_frame               = frame1;
+       receive.use_apop_chkbtn          = use_apop_chkbtn;
+       receive.rmmail_chkbtn            = rmmail_chkbtn;
+       receive.leave_time_entry         = leave_time_entry;
+       receive.getall_chkbtn            = getall_chkbtn;
+       receive.size_limit_chkbtn        = size_limit_chkbtn;
+       receive.size_limit_entry         = size_limit_entry;
+       receive.filter_on_recv_chkbtn    = filter_on_recv_chkbtn;
+       receive.inbox_label              = inbox_label;
+       receive.inbox_entry              = inbox_entry;
+       receive.inbox_btn                = inbox_btn;
+
+       receive.imap_frame               = imap_frame;
+       receive.imap_auth_type_optmenu   = optmenu;
+
+       receive.imapdir_label           = imapdir_label;
+       receive.imapdir_entry           = imapdir_entry;
+
+       receive.local_frame             = local_frame;
+       receive.local_inbox_label       = local_inbox_label;
+       receive.local_inbox_entry       = local_inbox_entry;
+       receive.local_inbox_btn         = local_inbox_btn;
+
+       receive.recvatgetall_chkbtn      = recvatgetall_chkbtn;
+
+       receive.frame_maxarticle        = frame2;
+       receive.maxarticle_spinbtn      = maxarticle_spinbtn;
+       receive.maxarticle_spinbtn_adj  = maxarticle_spinbtn_adj;
 }
 
 static void prefs_account_send_create(void)
@@ -1168,6 +1665,9 @@ static void prefs_account_send_create(void)
        GtkWidget *customhdr_edit_btn;
        GtkWidget *vbox3;
        GtkWidget *smtp_auth_chkbtn;
+       GtkWidget *optmenu;
+       GtkWidget *optmenu_menu;
+       GtkWidget *menuitem;
        GtkWidget *vbox4;
        GtkWidget *hbox_spc;
        GtkWidget *label;
@@ -1175,10 +1675,13 @@ static void prefs_account_send_create(void)
        GtkWidget *smtp_pass_entry;
        GtkWidget *vbox_spc;
        GtkWidget *pop_bfr_smtp_chkbtn;
+       GtkWidget *pop_bfr_smtp_tm_entry;
+       GtkWidget *pop_auth_timeout_lbl;
+       GtkWidget *pop_auth_minutes_lbl;
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
        PACK_FRAME (vbox1, frame, _("Header"));
@@ -1188,7 +1691,7 @@ static void prefs_account_send_create(void)
        gtk_container_add (GTK_CONTAINER (frame), vbox2);
        gtk_container_set_border_width (GTK_CONTAINER (vbox2), 8);
 
-       PACK_CHECK_BUTTON (vbox2, date_chkbtn, _("Add Date header field"));
+       PACK_CHECK_BUTTON (vbox2, date_chkbtn, _("Add Date"));
        PACK_CHECK_BUTTON (vbox2, msgid_chkbtn, _("Generate Message-ID"));
 
        hbox = gtk_hbox_new (FALSE, 12);
@@ -1202,9 +1705,9 @@ static void prefs_account_send_create(void)
        gtk_widget_show (customhdr_edit_btn);
        gtk_box_pack_start (GTK_BOX (hbox), customhdr_edit_btn,
                            FALSE, FALSE, 0);
-       gtk_signal_connect (GTK_OBJECT (customhdr_edit_btn), "clicked",
-                           GTK_SIGNAL_FUNC (prefs_account_edit_custom_header),
-                           NULL);
+       g_signal_connect (G_OBJECT (customhdr_edit_btn), "clicked",
+                         G_CALLBACK (prefs_account_edit_custom_header),
+                         NULL);
 
        SET_TOGGLE_SENSITIVITY (customhdr_chkbtn, customhdr_edit_btn);
 
@@ -1229,7 +1732,37 @@ static void prefs_account_send_create(void)
        hbox_spc = gtk_hbox_new (FALSE, 0);
        gtk_widget_show (hbox_spc);
        gtk_box_pack_start (GTK_BOX (hbox), hbox_spc, FALSE, FALSE, 0);
-       gtk_widget_set_usize (hbox_spc, 16, -1);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
+
+       label = gtk_label_new (_("Authentication method"));
+       gtk_widget_show (label);
+       gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
+
+       optmenu = gtk_option_menu_new ();
+       gtk_widget_show (optmenu);
+       gtk_box_pack_start (GTK_BOX (hbox), optmenu, FALSE, FALSE, 0);
+
+       optmenu_menu = gtk_menu_new ();
+
+       MENUITEM_ADD (optmenu_menu, menuitem, _("Automatic"), 0);
+       MENUITEM_ADD (optmenu_menu, menuitem, "PLAIN", SMTPAUTH_PLAIN);
+       MENUITEM_ADD (optmenu_menu, menuitem, "LOGIN", SMTPAUTH_LOGIN);
+       MENUITEM_ADD (optmenu_menu, menuitem, "CRAM-MD5", SMTPAUTH_CRAM_MD5);
+       MENUITEM_ADD (optmenu_menu, menuitem, "DIGEST-MD5", SMTPAUTH_DIGEST_MD5);
+       gtk_widget_set_sensitive (menuitem, FALSE);
+
+       gtk_option_menu_set_menu (GTK_OPTION_MENU (optmenu), optmenu_menu);
+
+       PACK_VSPACER(vbox4, vbox_spc, VSPACING_NARROW_2);
+
+       hbox = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox);
+       gtk_box_pack_start (GTK_BOX (vbox4), hbox, FALSE, FALSE, 0);
+
+       hbox_spc = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox_spc);
+       gtk_box_pack_start (GTK_BOX (hbox), hbox_spc, FALSE, FALSE, 0);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
 
        label = gtk_label_new (_("User ID"));
        gtk_widget_show (label);
@@ -1237,7 +1770,7 @@ static void prefs_account_send_create(void)
 
        smtp_uid_entry = gtk_entry_new ();
        gtk_widget_show (smtp_uid_entry);
-       gtk_widget_set_usize (smtp_uid_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_widget_set_size_request (smtp_uid_entry, DEFAULT_ENTRY_WIDTH, -1);
        gtk_box_pack_start (GTK_BOX (hbox), smtp_uid_entry, TRUE, TRUE, 0);
 
        label = gtk_label_new (_("Password"));
@@ -1246,7 +1779,7 @@ static void prefs_account_send_create(void)
 
        smtp_pass_entry = gtk_entry_new ();
        gtk_widget_show (smtp_pass_entry);
-       gtk_widget_set_usize (smtp_pass_entry, DEFAULT_ENTRY_WIDTH, -1);
+       gtk_widget_set_size_request (smtp_pass_entry, DEFAULT_ENTRY_WIDTH, -1);
        gtk_box_pack_start (GTK_BOX (hbox), smtp_pass_entry, TRUE, TRUE, 0);
        gtk_entry_set_visibility (GTK_ENTRY (smtp_pass_entry), FALSE);
 
@@ -1259,37 +1792,76 @@ static void prefs_account_send_create(void)
        hbox_spc = gtk_hbox_new (FALSE, 0);
        gtk_widget_show (hbox_spc);
        gtk_box_pack_start (GTK_BOX (hbox), hbox_spc, FALSE, FALSE, 0);
-       gtk_widget_set_usize (hbox_spc, 16, -1);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
 
        label = gtk_label_new
-               (_("If you leave these entries empty, the same\n"
+               (_("If you leave these entries empty, the same "
                   "user ID and password as receiving will be used."));
        gtk_widget_show (label);
        gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
        gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
+       gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
+       gtkut_widget_set_small_font_size (label);
 
        SET_TOGGLE_SENSITIVITY (smtp_auth_chkbtn, vbox4);
 
        PACK_CHECK_BUTTON (vbox3, pop_bfr_smtp_chkbtn,
                _("Authenticate with POP3 before sending"));
-       gtk_widget_set_sensitive(pop_bfr_smtp_chkbtn, FALSE);
+       
+       g_signal_connect (G_OBJECT (pop_bfr_smtp_chkbtn), "clicked",
+                         G_CALLBACK (pop_bfr_smtp_tm_set_sens),
+                         NULL);
+
+       hbox = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox);
+       gtk_box_pack_start (GTK_BOX (vbox3), hbox, FALSE, FALSE, 0);
+
+       hbox_spc = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox_spc);
+       gtk_box_pack_start (GTK_BOX (hbox), hbox_spc, FALSE, FALSE, 0);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
+
+       pop_auth_timeout_lbl = gtk_label_new(_("POP authentication timeout: "));
+       gtk_widget_show (pop_auth_timeout_lbl);
+       gtk_box_pack_start (GTK_BOX (hbox), pop_auth_timeout_lbl, FALSE, FALSE, 0);
+
+       pop_bfr_smtp_tm_entry = gtk_entry_new ();
+       gtk_widget_show (pop_bfr_smtp_tm_entry);
+       gtk_widget_set_size_request (pop_bfr_smtp_tm_entry, 30, -1);
+       gtk_box_pack_start (GTK_BOX (hbox), pop_bfr_smtp_tm_entry, FALSE, FALSE, 0);
+
+       pop_auth_minutes_lbl = gtk_label_new(_("minutes"));
+       gtk_widget_show (pop_auth_minutes_lbl);
+       gtk_box_pack_start (GTK_BOX (hbox), pop_auth_minutes_lbl, FALSE, FALSE, 0);
 
-       send.date_chkbtn      = date_chkbtn;
-       send.msgid_chkbtn     = msgid_chkbtn;
-       send.customhdr_chkbtn = customhdr_chkbtn;
 
-       send.smtp_auth_chkbtn    = smtp_auth_chkbtn;
-       send.smtp_uid_entry      = smtp_uid_entry;
-       send.smtp_pass_entry     = smtp_pass_entry;
-       send.pop_bfr_smtp_chkbtn = pop_bfr_smtp_chkbtn;
+       
+       p_send.date_chkbtn      = date_chkbtn;
+       p_send.msgid_chkbtn     = msgid_chkbtn;
+       p_send.customhdr_chkbtn = customhdr_chkbtn;
+
+       p_send.smtp_auth_chkbtn       = smtp_auth_chkbtn;
+       p_send.smtp_auth_type_optmenu = optmenu;
+       p_send.smtp_uid_entry         = smtp_uid_entry;
+       p_send.smtp_pass_entry        = smtp_pass_entry;
+       p_send.pop_bfr_smtp_chkbtn    = pop_bfr_smtp_chkbtn;
+       p_send.pop_bfr_smtp_tm_entry  = pop_bfr_smtp_tm_entry;
+       p_send.pop_auth_timeout_lbl   = pop_auth_timeout_lbl;
+       p_send.pop_auth_minutes_lbl   = pop_auth_minutes_lbl;
 }
 
 static void prefs_account_compose_create(void)
 {
        GtkWidget *vbox1;
-       GtkWidget *hbox;
-       GtkWidget *label;
-       GtkWidget *sigpath_entry;
+       GtkWidget *sig_hbox;
+       GtkWidget *hbox1;
+       GtkWidget *hbox2;
+       GtkWidget *frame_sig;
+       GtkWidget *vbox_sig;
+       GtkWidget *label_sigpath;
+       GtkWidget *checkbtn_autosig;
+       GtkWidget *label_sigsep;
+       GtkWidget *entry_sigsep;
        GtkWidget *frame;
        GtkWidget *table;
        GtkWidget *autocc_chkbtn;
@@ -1301,20 +1873,83 @@ static void prefs_account_compose_create(void)
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
-       hbox = gtk_hbox_new (FALSE, 8);
-       gtk_widget_show (hbox);
-       gtk_box_pack_start (GTK_BOX (vbox1), hbox, FALSE, FALSE, 0);
+       PACK_FRAME(vbox1, frame_sig, _("Signature"));
 
-       label = gtk_label_new (_("Signature file"));
-       gtk_widget_show (label);
-       gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
+       vbox_sig = gtk_vbox_new (FALSE, VSPACING_NARROW);
+       gtk_widget_show (vbox_sig);
+       gtk_container_add (GTK_CONTAINER (frame_sig), vbox_sig);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox_sig), 8);
+
+       PACK_CHECK_BUTTON (vbox_sig, checkbtn_autosig,
+                          _("Insert signature automatically"));
+
+       hbox1 = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox1);
+       gtk_box_pack_start (GTK_BOX (vbox_sig), hbox1, TRUE, TRUE, 0);
+       label_sigsep = gtk_label_new (_("Signature separator"));
+       gtk_widget_show (label_sigsep);
+       gtk_box_pack_start (GTK_BOX (hbox1), label_sigsep, FALSE, FALSE, 0);
+
+       entry_sigsep = gtk_entry_new ();
+       gtk_widget_show (entry_sigsep);
+       gtk_box_pack_start (GTK_BOX (hbox1), entry_sigsep, FALSE, FALSE, 0);
 
-       sigpath_entry = gtk_entry_new ();
-       gtk_widget_show (sigpath_entry);
-       gtk_box_pack_start (GTK_BOX (hbox), sigpath_entry, TRUE, TRUE, 0);
+       gtk_widget_set_size_request (entry_sigsep, 64, -1);
+
+       sig_hbox = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (sig_hbox);
+       gtk_box_pack_start (GTK_BOX (vbox_sig), sig_hbox, FALSE, FALSE, 0);
+
+       sigfile_radiobtn = gtk_radio_button_new_with_label (NULL, _("File"));
+       gtk_widget_show (sigfile_radiobtn);
+       gtk_box_pack_start (GTK_BOX (sig_hbox), sigfile_radiobtn,
+                           FALSE, FALSE, 0);
+       g_object_set_data (G_OBJECT (sigfile_radiobtn),
+                          MENU_VAL_ID,
+                          GINT_TO_POINTER (SIG_FILE));
+       g_signal_connect(G_OBJECT(sigfile_radiobtn), "clicked",
+                        G_CALLBACK(prefs_account_sigfile_radiobtn_cb), NULL);
+
+       sigcmd_radiobtn = gtk_radio_button_new_with_label_from_widget
+               (GTK_RADIO_BUTTON(sigfile_radiobtn), _("Command output"));
+       gtk_widget_show (sigcmd_radiobtn);
+       gtk_box_pack_start (GTK_BOX (sig_hbox), sigcmd_radiobtn,
+                           FALSE, FALSE, 0);
+       g_object_set_data (G_OBJECT (sigcmd_radiobtn),
+                          MENU_VAL_ID,
+                          GINT_TO_POINTER (SIG_COMMAND));
+       g_signal_connect(G_OBJECT(sigcmd_radiobtn), "clicked",
+                        G_CALLBACK(prefs_account_sigcmd_radiobtn_cb), NULL);
+
+       hbox2 = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox2);
+       gtk_box_pack_start (GTK_BOX (vbox_sig), hbox2, TRUE, TRUE, 0);
+       label_sigpath = gtk_label_new (_("Signature"));
+       gtk_widget_show (label_sigpath);
+       gtk_box_pack_start (GTK_BOX (hbox2), label_sigpath, FALSE, FALSE, 0);
+
+       entry_sigpath = gtk_entry_new ();
+       gtk_widget_show (entry_sigpath);
+       gtk_box_pack_start (GTK_BOX (hbox2), entry_sigpath, TRUE, TRUE, 0);
+
+       signature_browse_button = gtkut_get_browse_file_btn(_("Bro_wse"));
+       gtk_widget_show (signature_browse_button);
+       gtk_box_pack_start (GTK_BOX (hbox2), signature_browse_button, FALSE, FALSE, 0);
+       g_signal_connect(G_OBJECT(signature_browse_button), "clicked",
+                        G_CALLBACK(prefs_account_signature_browse_cb), NULL);
+
+       #if GTK_CHECK_VERSION(2, 6, 0)
+       signature_edit_button = gtk_button_new_from_stock (GTK_STOCK_EDIT);
+       #else
+       signature_edit_button = gtk_button_new_with_label (_(" Edit... "));
+       #endif
+       gtk_widget_show (signature_edit_button);
+       gtk_box_pack_start (GTK_BOX (hbox2), signature_edit_button, FALSE, FALSE, 0);
+       g_signal_connect(G_OBJECT(signature_edit_button), "clicked",
+                        G_CALLBACK(prefs_account_signature_edit_cb), entry_sigpath);
 
        PACK_FRAME (vbox1, frame, _("Automatically set the following addresses"));
 
@@ -1364,7 +1999,10 @@ static void prefs_account_compose_create(void)
 
        SET_TOGGLE_SENSITIVITY (autoreplyto_chkbtn, autoreplyto_entry);
 
-       compose.sigpath_entry = sigpath_entry;
+       compose.sigfile_radiobtn = sigfile_radiobtn;
+       compose.entry_sigpath      = entry_sigpath;
+       compose.checkbtn_autosig   = checkbtn_autosig;
+       compose.entry_sigsep       = entry_sigsep;
 
        compose.autocc_chkbtn      = autocc_chkbtn;
        compose.autocc_entry       = autocc_entry;
@@ -1374,123 +2012,74 @@ static void prefs_account_compose_create(void)
        compose.autoreplyto_entry  = autoreplyto_entry;
 }
 
-#if USE_GPGME
 static void prefs_account_privacy_create(void)
 {
        GtkWidget *vbox1;
-       GtkWidget *frame1;
        GtkWidget *vbox2;
-       GtkWidget *frame2;
-       GtkWidget *vbox3;
        GtkWidget *hbox1;
        GtkWidget *label;
-       GtkWidget *checkbtn_default_encrypt;
-       GtkWidget *checkbtn_ascii_armored;
-       GtkWidget *checkbtn_default_sign;
-       GtkWidget *defaultkey_radiobtn;
-       GtkWidget *emailkey_radiobtn;
-       GtkWidget *customkey_radiobtn;
-       GtkWidget *customkey_entry;
+       GtkWidget *default_privacy_system;
+       GtkWidget *default_encrypt_chkbtn;
+       GtkWidget *default_encrypt_reply_chkbtn;
+       GtkWidget *default_sign_chkbtn;
+       GtkWidget *save_clear_text_chkbtn;
+       GtkWidget *encrypt_to_self_chkbtn;
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
-       PACK_FRAME (vbox1, frame1, _("Default Actions"));
-
        vbox2 = gtk_vbox_new (FALSE, 0);
        gtk_widget_show (vbox2);
-       gtk_container_add (GTK_CONTAINER (frame1), vbox2);
-       gtk_container_set_border_width (GTK_CONTAINER (vbox2), 8);
-
-       PACK_CHECK_BUTTON (vbox2, checkbtn_default_encrypt,
-                          _("Encrypt message by default"));
-
-       PACK_CHECK_BUTTON (vbox2, checkbtn_ascii_armored,
-                          _("Plain ASCII-armored"));
-       gtk_signal_connect(GTK_OBJECT(checkbtn_ascii_armored), "toggled",
-                               prefs_account_ascii_armored_warning, (gpointer)0);
-
-       PACK_CHECK_BUTTON (vbox2, checkbtn_default_sign,
-                          _("Sign message by default"));
-
-       PACK_FRAME (vbox1, frame2, _("Sign key"));
-
-       vbox3 = gtk_vbox_new (FALSE, VSPACING_NARROW);
-       gtk_widget_show (vbox3);
-       gtk_container_add (GTK_CONTAINER (frame2), vbox3);
-       gtk_container_set_border_width (GTK_CONTAINER (vbox3), 8);
-
-       defaultkey_radiobtn = gtk_radio_button_new_with_label
-               (NULL, _("Use default GnuPG key"));
-       gtk_widget_show (defaultkey_radiobtn);
-       gtk_box_pack_start (GTK_BOX (vbox3), defaultkey_radiobtn,
-                           FALSE, FALSE, 0);
-       gtk_object_set_user_data (GTK_OBJECT (defaultkey_radiobtn),
-                                 GINT_TO_POINTER (SIGN_KEY_DEFAULT));
-
-       emailkey_radiobtn = gtk_radio_button_new_with_label_from_widget
-               (GTK_RADIO_BUTTON (defaultkey_radiobtn),
-                _("Select key by your email address"));
-       gtk_widget_show (emailkey_radiobtn);
-       gtk_box_pack_start (GTK_BOX (vbox3), emailkey_radiobtn,
-                           FALSE, FALSE, 0);
-       gtk_object_set_user_data (GTK_OBJECT (emailkey_radiobtn),
-                                 GINT_TO_POINTER (SIGN_KEY_BY_FROM));
-
-       customkey_radiobtn = gtk_radio_button_new_with_label_from_widget
-               (GTK_RADIO_BUTTON (defaultkey_radiobtn),
-                _("Specify key manually"));
-       gtk_widget_show (customkey_radiobtn);
-       gtk_box_pack_start (GTK_BOX (vbox3), customkey_radiobtn,
-                           FALSE, FALSE, 0);
-       gtk_object_set_user_data (GTK_OBJECT (customkey_radiobtn),
-                                 GINT_TO_POINTER (SIGN_KEY_CUSTOM));
+       gtk_box_pack_start (GTK_BOX (vbox1), vbox2, FALSE, FALSE, 0);
 
-       hbox1 = gtk_hbox_new (FALSE, 8);
+       hbox1 = gtk_hbox_new(FALSE, 8);
        gtk_widget_show (hbox1);
-       gtk_box_pack_start (GTK_BOX (vbox3), hbox1, FALSE, FALSE, 0);
-
-       label = gtk_label_new ("");
-       gtk_widget_show (label);
-       gtk_box_pack_start (GTK_BOX (hbox1), label, FALSE, FALSE, 0);
-       gtk_widget_set_usize (label, 16, -1);
+       gtk_container_add (GTK_CONTAINER(vbox2), hbox1);
 
-       label = gtk_label_new (_("User or key ID:"));
-       gtk_widget_show (label);
+       label = gtk_label_new(_("Default privacy system"));
+       gtk_widget_show(label);
        gtk_box_pack_start (GTK_BOX (hbox1), label, FALSE, FALSE, 0);
 
-       customkey_entry = gtk_entry_new ();
-       gtk_widget_show (customkey_entry);
-       gtk_box_pack_start (GTK_BOX (hbox1), customkey_entry,
-                           TRUE, TRUE, 0);
+       default_privacy_system = gtk_option_menu_new();
+       gtk_widget_show (default_privacy_system);
+       gtk_box_pack_start (GTK_BOX(hbox1), default_privacy_system, FALSE, TRUE, 0);
 
-       SET_TOGGLE_SENSITIVITY (customkey_radiobtn, customkey_entry);
-
-       privacy.checkbtn_default_encrypt = checkbtn_default_encrypt;
-       privacy.checkbtn_ascii_armored   = checkbtn_ascii_armored;
-       privacy.checkbtn_default_sign    = checkbtn_default_sign;
-       privacy.defaultkey_radiobtn = defaultkey_radiobtn;
-       privacy.emailkey_radiobtn = emailkey_radiobtn;
-       privacy.customkey_radiobtn = customkey_radiobtn;
-       privacy.customkey_entry = customkey_entry;
+       PACK_CHECK_BUTTON (vbox2, default_encrypt_chkbtn,
+                          _("Encrypt message by default"));
+       PACK_CHECK_BUTTON (vbox2, default_encrypt_reply_chkbtn,
+                          _("Encrypt message by default when replying to an "
+                            "encrypted message"));
+       PACK_CHECK_BUTTON (vbox2, default_sign_chkbtn,
+                          _("Sign message by default"));
+       PACK_CHECK_BUTTON (vbox2, encrypt_to_self_chkbtn,
+                          _("Encrypt sent messages to myself too"));
+       PACK_CHECK_BUTTON (vbox2, save_clear_text_chkbtn,
+                          _("Save sent encrypted messages as clear text"));
+
+       SET_TOGGLE_SENSITIVITY_REVERSE(encrypt_to_self_chkbtn, save_clear_text_chkbtn);
+
+       privacy.default_privacy_system = default_privacy_system;
+       privacy.default_encrypt_chkbtn = default_encrypt_chkbtn;
+       privacy.default_encrypt_reply_chkbtn = default_encrypt_reply_chkbtn;
+       privacy.default_sign_chkbtn    = default_sign_chkbtn;
+       privacy.save_clear_text_chkbtn = save_clear_text_chkbtn;
+       privacy.encrypt_to_self_chkbtn = encrypt_to_self_chkbtn;
 }
 
-static void prefs_account_ascii_armored_warning(GtkWidget* widget,
-                                              gpointer unused)
-{
-       if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget))
-               && gtk_notebook_get_current_page(GTK_NOTEBOOK(dialog.notebook))) {
-               alertpanel_message(_("Warning - Privacy/Plain ASCII-armored"),
-                       _("Its not recommend to use the old style plain ASCII-\n"
-                       "armored mode for encrypted messages. It doesn't comply\n"
-                       "with the RFC 3156 - MIME security with OpenPGP."));
-       }
-}
-#endif /* USE_GPGME */
+#if USE_OPENSSL
 
-#if USE_SSL
+#define CREATE_RADIO_BUTTON(box, btn, btn_p, label, data)              \
+{                                                                      \
+       btn = gtk_radio_button_new_with_label_from_widget               \
+               (GTK_RADIO_BUTTON (btn_p), label);                      \
+       gtk_widget_show (btn);                                          \
+       gtk_box_pack_start (GTK_BOX (box), btn, FALSE, FALSE, 0);       \
+       g_object_set_data (G_OBJECT (btn),                              \
+                          MENU_VAL_ID,                                 \
+                          GINT_TO_POINTER (data));                     \
+}
 
 #define CREATE_RADIO_BUTTONS(box,                                      \
                             btn1, btn1_label, btn1_data,               \
@@ -1500,22 +2089,12 @@ static void prefs_account_ascii_armored_warning(GtkWidget* widget,
        btn1 = gtk_radio_button_new_with_label(NULL, btn1_label);       \
        gtk_widget_show (btn1);                                         \
        gtk_box_pack_start (GTK_BOX (box), btn1, FALSE, FALSE, 0);      \
-       gtk_object_set_user_data (GTK_OBJECT (btn1),                    \
-                                 GINT_TO_POINTER (btn1_data));         \
-                                                                       \
-       btn2 = gtk_radio_button_new_with_label_from_widget              \
-               (GTK_RADIO_BUTTON (btn1), btn2_label);                  \
-       gtk_widget_show (btn2);                                         \
-       gtk_box_pack_start (GTK_BOX (box), btn2, FALSE, FALSE, 0);      \
-       gtk_object_set_user_data (GTK_OBJECT (btn2),                    \
-                                 GINT_TO_POINTER (btn2_data));         \
+       g_object_set_data (G_OBJECT (btn1),                             \
+                          MENU_VAL_ID,                                 \
+                          GINT_TO_POINTER (btn1_data));                \
                                                                        \
-       btn3 = gtk_radio_button_new_with_label_from_widget              \
-               (GTK_RADIO_BUTTON (btn1), btn3_label);                  \
-       gtk_widget_show (btn3);                                         \
-       gtk_box_pack_start (GTK_BOX (box), btn3, FALSE, FALSE, 0);      \
-       gtk_object_set_user_data (GTK_OBJECT (btn3),                    \
-                                 GINT_TO_POINTER (btn3_data));         \
+       CREATE_RADIO_BUTTON(box, btn2, btn1, btn2_label, btn2_data);    \
+       CREATE_RADIO_BUTTON(box, btn3, btn1, btn3_label, btn3_data);    \
 }
 
 static void prefs_account_ssl_create(void)
@@ -1538,7 +2117,6 @@ static void prefs_account_ssl_create(void)
        GtkWidget *vbox4;
        GtkWidget *nntp_nossl_radiobtn;
        GtkWidget *nntp_ssltunnel_radiobtn;
-       GtkWidget *nntp_starttls_radiobtn;
 
        GtkWidget *send_frame;
        GtkWidget *vbox5;
@@ -1546,9 +2124,15 @@ static void prefs_account_ssl_create(void)
        GtkWidget *smtp_ssltunnel_radiobtn;
        GtkWidget *smtp_starttls_radiobtn;
 
+       GtkWidget *vbox6;
+       GtkWidget *use_nonblocking_ssl_chkbtn;
+       GtkWidget *hbox;
+       GtkWidget *hbox_spc;
+       GtkWidget *label;
+
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
        PACK_FRAME (vbox1, pop_frame, _("POP3"));
@@ -1591,16 +2175,17 @@ static void prefs_account_ssl_create(void)
        gtk_container_add (GTK_CONTAINER (nntp_frame), vbox4);
        gtk_container_set_border_width (GTK_CONTAINER (vbox4), 8);
 
-       CREATE_RADIO_BUTTONS(vbox4,
-                            nntp_nossl_radiobtn,
-                            _("Don't use SSL"),
-                            SSL_NONE,
-                            nntp_ssltunnel_radiobtn,
-                            _("Use SSL for NNTP connection"),
-                            SSL_TUNNEL,
-                            nntp_starttls_radiobtn,
-                            _("Use STARTTLS command to start SSL session"),
-                            SSL_STARTTLS);
+       nntp_nossl_radiobtn =
+               gtk_radio_button_new_with_label (NULL, _("Don't use SSL"));
+       gtk_widget_show (nntp_nossl_radiobtn);
+       gtk_box_pack_start (GTK_BOX (vbox4), nntp_nossl_radiobtn,
+                           FALSE, FALSE, 0);
+       g_object_set_data (G_OBJECT (nntp_nossl_radiobtn),
+                          MENU_VAL_ID,
+                          GINT_TO_POINTER (SSL_NONE));
+
+       CREATE_RADIO_BUTTON(vbox4, nntp_ssltunnel_radiobtn, nntp_nossl_radiobtn,
+                           _("Use SSL for NNTP connection"), SSL_TUNNEL);
 
        PACK_FRAME (vbox1, send_frame, _("Send (SMTP)"));
        vbox5 = gtk_vbox_new (FALSE, 0);
@@ -1610,7 +2195,7 @@ static void prefs_account_ssl_create(void)
 
        CREATE_RADIO_BUTTONS(vbox5,
                             smtp_nossl_radiobtn,
-                            _("Don't use SSL"),
+                            _("Don't use SSL (but, if necessary, use STARTTLS)"),
                             SSL_NONE,
                             smtp_ssltunnel_radiobtn,
                             _("Use SSL for SMTP connection"),
@@ -1619,6 +2204,28 @@ static void prefs_account_ssl_create(void)
                             _("Use STARTTLS command to start SSL session"),
                             SSL_STARTTLS);
 
+       vbox6 = gtk_vbox_new (FALSE, 0);
+       gtk_widget_show (vbox6);
+       gtk_box_pack_start (GTK_BOX (vbox1), vbox6, FALSE, FALSE, 0);
+
+       PACK_CHECK_BUTTON(vbox6, use_nonblocking_ssl_chkbtn,
+                         _("Use non-blocking SSL"));
+
+       hbox = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox);
+       gtk_box_pack_start (GTK_BOX (vbox6), hbox, FALSE, FALSE, 0);
+
+       hbox_spc = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox_spc);
+       gtk_box_pack_start (GTK_BOX (hbox), hbox_spc, FALSE, FALSE, 0);
+       gtk_widget_set_size_request (hbox_spc, 16, -1);
+
+       label = gtk_label_new
+               (_("Turn this off if you have SSL connection problems"));
+       gtk_widget_show (label);
+       gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
+       gtkut_widget_set_small_font_size (label);
+
        ssl.pop_frame               = pop_frame;
        ssl.pop_nossl_radiobtn      = pop_nossl_radiobtn;
        ssl.pop_ssltunnel_radiobtn  = pop_ssltunnel_radiobtn;
@@ -1632,16 +2239,18 @@ static void prefs_account_ssl_create(void)
        ssl.nntp_frame              = nntp_frame;
        ssl.nntp_nossl_radiobtn     = nntp_nossl_radiobtn;
        ssl.nntp_ssltunnel_radiobtn = nntp_ssltunnel_radiobtn;
-       ssl.nntp_starttls_radiobtn  = nntp_starttls_radiobtn;
 
        ssl.send_frame              = send_frame;
        ssl.smtp_nossl_radiobtn     = smtp_nossl_radiobtn;
        ssl.smtp_ssltunnel_radiobtn = smtp_ssltunnel_radiobtn;
        ssl.smtp_starttls_radiobtn  = smtp_starttls_radiobtn;
+
+       ssl.use_nonblocking_ssl_chkbtn = use_nonblocking_ssl_chkbtn;
 }
 
 #undef CREATE_RADIO_BUTTONS
-#endif /* USE_SSL */
+#undef CREATE_RADIO_BUTTON
+#endif /* USE_OPENSSL */
 
 static void crosspost_color_toggled(void)
 {
@@ -1660,7 +2269,7 @@ static void prefs_account_crosspost_set_data_from_colormenu(PrefParam *pparam)
        menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(advanced.crosspost_colormenu));
        menuitem = gtk_menu_get_active(GTK_MENU(menu));
        *((gint *)pparam->data) = GPOINTER_TO_INT
-               (gtk_object_get_data(GTK_OBJECT(menuitem), "color"));
+               (g_object_get_data(G_OBJECT(menuitem), "color"));
 }
 
 static void prefs_account_crosspost_set_colormenu(PrefParam *pparam)
@@ -1695,22 +2304,18 @@ static void prefs_account_advanced_create(void)
        GtkWidget *entry_nntpport;
        GtkWidget *checkbtn_domain;
        GtkWidget *entry_domain;
-       GtkWidget *checkbtn_tunnelcmd;
-       GtkWidget *entry_tunnelcmd;
-       GtkWidget *checkbtn_crosspost;
+       GtkWidget *checkbtn_crosspost;
        GtkWidget *colormenu_crosspost;
        GtkWidget *menu;
-       GtkWidget *menuitem;
-       GtkWidget *item;
-       gint i;
-       GtkWidget *imap_frame;
-       GtkWidget *imapdir_label;
-       GtkWidget *imapdir_entry;
+       GtkWidget *checkbtn_tunnelcmd;
+       GtkWidget *entry_tunnelcmd;
        GtkWidget *folder_frame;
        GtkWidget *vbox3;
        GtkWidget *table;
        GtkWidget *sent_folder_chkbtn;
        GtkWidget *sent_folder_entry;
+       GtkWidget *queue_folder_chkbtn;
+       GtkWidget *queue_folder_entry;
        GtkWidget *draft_folder_chkbtn;
        GtkWidget *draft_folder_entry;
        GtkWidget *trash_folder_chkbtn;
@@ -1725,15 +2330,16 @@ static void prefs_account_advanced_create(void)
 
 #define PACK_PORT_ENTRY(box, entry) \
        { \
-       entry = gtk_entry_new_with_max_length (5); \
+       entry = gtk_entry_new (); \
+       gtk_entry_set_max_length  (GTK_ENTRY(entry), 5); \
        gtk_widget_show (entry); \
        gtk_box_pack_start (GTK_BOX (box), entry, FALSE, FALSE, 0); \
-       gtk_widget_set_usize (entry, 64, -1); \
+       gtk_widget_set_size_request (entry, 64, -1); \
        }
 
        vbox1 = gtk_vbox_new (FALSE, VSPACING);
        gtk_widget_show (vbox1);
-       gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
+       gtk_container_add (GTK_CONTAINER (notebook), vbox1);
        gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
 
        vbox2 = gtk_vbox_new (FALSE, VSPACING_NARROW_2);
@@ -1741,30 +2347,30 @@ static void prefs_account_advanced_create(void)
        gtk_box_pack_start (GTK_BOX (vbox1), vbox2, FALSE, FALSE, 0);
 
        PACK_HBOX (hbox1);
-       PACK_CHECK_BUTTON (hbox1, checkbtn_smtpport, _("Specify SMTP port"));
+       PACK_CHECK_BUTTON (hbox1, checkbtn_smtpport, _("SMTP port"));
        PACK_PORT_ENTRY (hbox1, entry_smtpport);
        SET_TOGGLE_SENSITIVITY (checkbtn_smtpport, entry_smtpport);
 
        PACK_HBOX (hbox_popport);
        PACK_CHECK_BUTTON (hbox_popport, checkbtn_popport,
-                          _("Specify POP3 port"));
+                          _("POP3 port"));
        PACK_PORT_ENTRY (hbox_popport, entry_popport);
        SET_TOGGLE_SENSITIVITY (checkbtn_popport, entry_popport);
 
        PACK_HBOX (hbox_imapport);
        PACK_CHECK_BUTTON (hbox_imapport, checkbtn_imapport,
-                          _("Specify IMAP4 port"));
+                          _("IMAP4 port"));
        PACK_PORT_ENTRY (hbox_imapport, entry_imapport);
        SET_TOGGLE_SENSITIVITY (checkbtn_imapport, entry_imapport);
 
        PACK_HBOX (hbox_nntpport);
        PACK_CHECK_BUTTON (hbox_nntpport, checkbtn_nntpport,
-                          _("Specify NNTP port"));
+                          _("NNTP port"));
        PACK_PORT_ENTRY (hbox_nntpport, entry_nntpport);
        SET_TOGGLE_SENSITIVITY (checkbtn_nntpport, entry_nntpport);
 
        PACK_HBOX (hbox1);
-       PACK_CHECK_BUTTON (hbox1, checkbtn_domain, _("Specify domain name"));
+       PACK_CHECK_BUTTON (hbox1, checkbtn_domain, _("Domain name"));
 
        entry_domain = gtk_entry_new ();
        gtk_widget_show (entry_domain);
@@ -1774,7 +2380,7 @@ static void prefs_account_advanced_create(void)
        
        PACK_HBOX (hbox1);
        PACK_CHECK_BUTTON (hbox1, checkbtn_tunnelcmd,
-                          _("Tunnel command to open connection"));
+                          _("Use command to communicate with server"));
        entry_tunnelcmd = gtk_entry_new ();
        gtk_widget_show (entry_tunnelcmd);
        gtk_box_pack_start (GTK_BOX (hbox1), entry_tunnelcmd, TRUE, TRUE, 0);
@@ -1783,9 +2389,9 @@ static void prefs_account_advanced_create(void)
        PACK_HBOX (hbox1);
        PACK_CHECK_BUTTON (hbox1, checkbtn_crosspost, 
                           _("Mark cross-posted messages as read and color:"));
-       gtk_signal_connect (GTK_OBJECT (checkbtn_crosspost), "toggled",
-                                       GTK_SIGNAL_FUNC (crosspost_color_toggled),
-                                       NULL);
+       g_signal_connect (G_OBJECT (checkbtn_crosspost), "toggled",
+                         G_CALLBACK (crosspost_color_toggled),
+                         NULL);
 
        colormenu_crosspost = gtk_option_menu_new();
        gtk_widget_show (colormenu_crosspost);
@@ -1795,25 +2401,7 @@ static void prefs_account_advanced_create(void)
        gtk_option_menu_set_menu (GTK_OPTION_MENU(colormenu_crosspost), menu);
        SET_TOGGLE_SENSITIVITY(checkbtn_crosspost, colormenu_crosspost);
 
-       PACK_FRAME (vbox1, imap_frame, _("IMAP4"));
-
-       vbox3 = gtk_vbox_new (FALSE, VSPACING_NARROW);
-       gtk_widget_show (vbox3);
-       gtk_container_add (GTK_CONTAINER (imap_frame), vbox3);
-       gtk_container_set_border_width (GTK_CONTAINER (vbox3), 8);
-
-       hbox1 = gtk_hbox_new (FALSE, 8);
-       gtk_widget_show (hbox1);
-       gtk_box_pack_start (GTK_BOX (vbox3), hbox1, FALSE, FALSE, 0);
-
-       imapdir_label = gtk_label_new (_("IMAP server directory"));
-       gtk_widget_show (imapdir_label);
-       gtk_box_pack_start (GTK_BOX (hbox1), imapdir_label, FALSE, FALSE, 0);
-
-       imapdir_entry = gtk_entry_new();
-       gtk_widget_show (imapdir_entry);
-       gtk_box_pack_start (GTK_BOX (hbox1), imapdir_entry, TRUE, TRUE, 0);
-
+       PACK_HBOX (hbox1);
 #undef PACK_HBOX
 #undef PACK_PORT_ENTRY
 
@@ -1826,7 +2414,7 @@ static void prefs_account_advanced_create(void)
        gtk_container_add (GTK_CONTAINER (folder_frame), vbox3);
        gtk_container_set_border_width (GTK_CONTAINER (vbox3), 8);
 
-       table = gtk_table_new (3, 3, FALSE);
+       table = gtk_table_new (4, 3, FALSE);
        gtk_widget_show (table);
        gtk_container_add (GTK_CONTAINER (vbox3), table);
        gtk_table_set_row_spacings (GTK_TABLE (table), VSPACING_NARROW_2);
@@ -1847,13 +2435,13 @@ static void prefs_account_advanced_create(void)
                          GTK_EXPAND | GTK_SHRINK | GTK_FILL,           \
                          GTK_EXPAND | GTK_SHRINK | GTK_FILL, 0, 0);    \
                                                                        \
-       button = gtk_button_new_with_label (_(" ... "));                \
+       button = gtkut_get_browse_file_btn(_("Browse"));                \
        gtk_widget_show (button);                                       \
        gtk_table_attach (GTK_TABLE (table), button,                    \
                          2, 3, n, n + 1, GTK_FILL, 0, 0, 0);           \
-       gtk_signal_connect                                              \
-               (GTK_OBJECT (button), "clicked",                        \
-                GTK_SIGNAL_FUNC (prefs_account_select_folder_cb),      \
+       g_signal_connect                                                \
+               (G_OBJECT (button), "clicked",                  \
+                G_CALLBACK (prefs_account_select_folder_cb),           \
                 entry);                                                \
                                                                        \
        SET_TOGGLE_SENSITIVITY (chkbtn, entry);                         \
@@ -1862,10 +2450,12 @@ static void prefs_account_advanced_create(void)
 
        SET_CHECK_BTN_AND_ENTRY(_("Put sent messages in"),
                                sent_folder_chkbtn, sent_folder_entry, 0);
+       SET_CHECK_BTN_AND_ENTRY(_("Put queued messages in"),
+                               queue_folder_chkbtn, queue_folder_entry, 1);
        SET_CHECK_BTN_AND_ENTRY(_("Put draft messages in"),
-                               draft_folder_chkbtn, draft_folder_entry, 1);
+                               draft_folder_chkbtn, draft_folder_entry, 2);
        SET_CHECK_BTN_AND_ENTRY(_("Put deleted messages in"),
-                               trash_folder_chkbtn, trash_folder_entry, 2);
+                               trash_folder_chkbtn, trash_folder_entry, 3);
 
        advanced.smtpport_chkbtn        = checkbtn_smtpport;
        advanced.smtpport_entry         = entry_smtpport;
@@ -1880,52 +2470,34 @@ static void prefs_account_advanced_create(void)
        advanced.nntpport_entry         = entry_nntpport;
        advanced.domain_chkbtn          = checkbtn_domain;
        advanced.domain_entry           = entry_domain;
-       advanced.tunnelcmd_chkbtn       = checkbtn_tunnelcmd;
-       advanced.tunnelcmd_entry        = entry_tunnelcmd;
        advanced.crosspost_chkbtn       = checkbtn_crosspost;
        advanced.crosspost_colormenu    = colormenu_crosspost;
 
-       advanced.imap_frame             = imap_frame;
-       advanced.imapdir_entry          = imapdir_entry;
+       advanced.tunnelcmd_chkbtn       = checkbtn_tunnelcmd;
+       advanced.tunnelcmd_entry        = entry_tunnelcmd;
 
        advanced.sent_folder_chkbtn  = sent_folder_chkbtn;
        advanced.sent_folder_entry   = sent_folder_entry;
+       advanced.queue_folder_chkbtn  = queue_folder_chkbtn;
+       advanced.queue_folder_entry   = queue_folder_entry;
        advanced.draft_folder_chkbtn = draft_folder_chkbtn;
        advanced.draft_folder_entry  = draft_folder_entry;
        advanced.trash_folder_chkbtn = trash_folder_chkbtn;
        advanced.trash_folder_entry  = trash_folder_entry;
 }
 
-static gint prefs_account_deleted(GtkWidget *widget, GdkEventAny *event,
-                                 gpointer data)
-{
-       prefs_account_cancel();
-       return TRUE;
-}
-
-static void prefs_account_key_pressed(GtkWidget *widget, GdkEventKey *event,
-                                     gpointer data)
-{
-       if (event && event->keyval == GDK_Escape)
-               prefs_account_cancel();
-}
-
-static void prefs_account_ok(void)
-{
-       if (prefs_account_apply() == 0)
-               gtk_main_quit();
-}
-
 static gint prefs_account_apply(void)
 {
        RecvProtocol protocol;
        GtkWidget *menu;
        GtkWidget *menuitem;
-
+       gchar *old_id = NULL;
+       gchar *new_id = NULL;
+       
        menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(basic.protocol_optmenu));
        menuitem = gtk_menu_get_active(GTK_MENU(menu));
        protocol = GPOINTER_TO_INT
-               (gtk_object_get_user_data(GTK_OBJECT(menuitem)));
+               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
 
        if (*gtk_entry_get_text(GTK_ENTRY(basic.acname_entry)) == '\0') {
                alertpanel_error(_("Account name is not entered."));
@@ -1935,17 +2507,19 @@ static gint prefs_account_apply(void)
                alertpanel_error(_("Mail address is not entered."));
                return -1;
        }
-       if ((protocol == A_POP3 || protocol == A_APOP || (protocol == A_LOCAL && !gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(basic.mailcmd_chkbtn)))) &&
+       if (((protocol == A_POP3) || 
+            (protocol == A_LOCAL && !gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(basic.mailcmd_chkbtn))) || 
+            (protocol == A_NONE)) &&
            *gtk_entry_get_text(GTK_ENTRY(basic.smtpserv_entry)) == '\0') {
                alertpanel_error(_("SMTP server is not entered."));
                return -1;
        }
-       if ((protocol == A_POP3 || protocol == A_APOP || protocol == A_IMAP4) &&
+       if ((protocol == A_POP3 || protocol == A_IMAP4) &&
            *gtk_entry_get_text(GTK_ENTRY(basic.uid_entry)) == '\0') {
                alertpanel_error(_("User ID is not entered."));
                return -1;
        }
-       if ((protocol == A_POP3 || protocol == A_APOP) &&
+       if (protocol == A_POP3 &&
            *gtk_entry_get_text(GTK_ENTRY(basic.recvserv_entry)) == '\0') {
                alertpanel_error(_("POP3 server is not entered."));
                return -1;
@@ -1972,15 +2546,34 @@ static gint prefs_account_apply(void)
                alertpanel_error(_("mail command is not entered."));
                return -1;
        }
-
+       
+       if (protocol == A_IMAP4 || protocol == A_NNTP) 
+               old_id = g_strdup_printf("#%s/%s",
+                               protocol == A_IMAP4 ? "imap":"nntp",
+                               tmp_ac_prefs.account_name ? tmp_ac_prefs.account_name : "(null)");
+       
        prefs_set_data_from_dialog(param);
+       
+       if (protocol == A_IMAP4 || protocol == A_NNTP) {
+               new_id = g_strdup_printf("#%s/%s",
+                               protocol == A_IMAP4 ? "imap":"nntp",
+                               tmp_ac_prefs.account_name);
+               if (old_id != NULL && new_id != NULL)
+                       prefs_filtering_rename_path(old_id, new_id);
+               g_free(old_id);
+               g_free(new_id);
+       }
        return 0;
 }
 
-static void prefs_account_cancel(void)
+static void pop_bfr_smtp_tm_set_sens(GtkWidget *widget, gpointer data)
 {
-       cancelled = TRUE;
-       gtk_main_quit();
+       gtk_widget_set_sensitive(p_send.pop_bfr_smtp_tm_entry, 
+                                gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(p_send.pop_bfr_smtp_chkbtn)));
+       gtk_widget_set_sensitive(p_send.pop_auth_timeout_lbl, 
+                                gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(p_send.pop_bfr_smtp_chkbtn)));
+       gtk_widget_set_sensitive(p_send.pop_auth_minutes_lbl, 
+                                gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(p_send.pop_bfr_smtp_chkbtn)));
 }
 
 static void prefs_account_select_folder_cb(GtkWidget *widget, gpointer data)
@@ -1998,24 +2591,58 @@ static void prefs_account_select_folder_cb(GtkWidget *widget, gpointer data)
        }
 }
 
+static void prefs_account_sigfile_radiobtn_cb(GtkWidget *widget, gpointer data)
+{
+       gtk_widget_set_sensitive(GTK_WIDGET(signature_browse_button), TRUE);
+       gtk_widget_set_sensitive(GTK_WIDGET(signature_edit_button), TRUE);
+}
+
+static void prefs_account_sigcmd_radiobtn_cb(GtkWidget *widget, gpointer data)
+{
+       gtk_widget_set_sensitive(GTK_WIDGET(signature_browse_button), FALSE);
+       gtk_widget_set_sensitive(GTK_WIDGET(signature_edit_button), FALSE);
+}
+
+static void prefs_account_signature_browse_cb(GtkWidget *widget, gpointer data)
+{
+       gchar *filename;
+       gchar *utf8_filename;
+
+       filename = filesel_select_file_open(_("Select signature file"), NULL);
+       if (!filename) return;
+
+       utf8_filename = g_filename_to_utf8(filename, -1, NULL, NULL, NULL);
+       if (!utf8_filename) {
+               g_warning("prefs_account_signature_browse_cb(): failed to convert character set.");
+               utf8_filename = g_strdup(filename);
+       }
+       gtk_entry_set_text(GTK_ENTRY(entry_sigpath), utf8_filename);
+       g_free(utf8_filename);
+}
+
+static void prefs_account_signature_edit_cb(GtkWidget *widget, gpointer data)
+{
+       const gchar *sigpath = gtk_entry_get_text(GTK_ENTRY(data));
+       open_txt_editor(sigpath, prefs_common.ext_editor_cmd);
+}
+
 static void prefs_account_edit_custom_header(void)
 {
        prefs_custom_header_open(&tmp_ac_prefs);
 }
 
-#if USE_GPGME || USE_SSL
 static void prefs_account_enum_set_data_from_radiobtn(PrefParam *pparam)
 {
        GtkRadioButton *radiobtn;
        GSList *group;
 
        radiobtn = GTK_RADIO_BUTTON (*pparam->widget);
-       group = gtk_radio_button_group (radiobtn);
+       group = gtk_radio_button_get_group (radiobtn);
        while (group != NULL) {
                GtkToggleButton *btn = GTK_TOGGLE_BUTTON (group->data);
                if (gtk_toggle_button_get_active (btn)) {
                        *((gint *)pparam->data) = GPOINTER_TO_INT
-                               (gtk_object_get_user_data (GTK_OBJECT (btn)));
+                               (g_object_get_data (G_OBJECT (btn), MENU_VAL_ID));
                        break;
                }
                group = group->next;
@@ -2030,10 +2657,10 @@ static void prefs_account_enum_set_radiobtn(PrefParam *pparam)
 
        data = GINT_TO_POINTER (*((gint *)pparam->data));
        radiobtn = GTK_RADIO_BUTTON (*pparam->widget);
-       group = gtk_radio_button_group (radiobtn);
+       group = gtk_radio_button_get_group (radiobtn);
        while (group != NULL) {
                GtkToggleButton *btn = GTK_TOGGLE_BUTTON (group->data);
-               gpointer data1 = gtk_object_get_user_data (GTK_OBJECT (btn));
+               gpointer data1 = g_object_get_data (G_OBJECT (btn), MENU_VAL_ID);
                if (data1 == data) {
                        gtk_toggle_button_set_active (btn, TRUE);
                        break;
@@ -2042,8 +2669,6 @@ static void prefs_account_enum_set_radiobtn(PrefParam *pparam)
        }
 }
 
-#endif /* USE_GPGME */
-
 static void prefs_account_protocol_set_data_from_optmenu(PrefParam *pparam)
 {
        GtkWidget *menu;
@@ -2052,7 +2677,7 @@ static void prefs_account_protocol_set_data_from_optmenu(PrefParam *pparam)
        menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
        menuitem = gtk_menu_get_active(GTK_MENU(menu));
        *((RecvProtocol *)pparam->data) = GPOINTER_TO_INT
-               (gtk_object_get_user_data(GTK_OBJECT(menuitem)));
+               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
 }
 
 static void prefs_account_protocol_set_optmenu(PrefParam *pparam)
@@ -2061,53 +2686,172 @@ static void prefs_account_protocol_set_optmenu(PrefParam *pparam)
        GtkOptionMenu *optmenu = GTK_OPTION_MENU(*pparam->widget);
        GtkWidget *menu;
        GtkWidget *menuitem;
-       GList *children;
-       gint list_order[] = {
-               0,  /* A_POP3  */
-               1,  /* A_APOP  */
-               -1, /* A_RPOP  */
-               2,  /* A_IMAP4 */
-               3,  /* A_NNTP  */
-               4   /* A_LOCAL */
-       };
+       gint index;
 
        protocol = *((RecvProtocol *)pparam->data);
-       if (protocol < 0 || protocol > A_LOCAL) return;
-       if (list_order[protocol] < 0) return;
-       gtk_option_menu_set_history(optmenu, list_order[protocol]);
+       index = menu_find_option_menu_index
+               (optmenu, GINT_TO_POINTER(protocol), NULL);
+       if (index < 0) return;
+       gtk_option_menu_set_history(optmenu, index);
 
        menu = gtk_option_menu_get_menu(optmenu);
        menu_set_insensitive_all(GTK_MENU_SHELL(menu));
 
-#define SET_NTH_SENSITIVE(proto) \
-{ \
-       menuitem = g_list_nth_data(children, list_order[proto]); \
-       if (menuitem) \
-               gtk_widget_set_sensitive(menuitem, TRUE); \
+       menuitem = gtk_menu_get_active(GTK_MENU(menu));
+       gtk_widget_set_sensitive(menuitem, TRUE);
+       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
 }
 
-       children = GTK_MENU_SHELL(menu)->children;
-       SET_NTH_SENSITIVE(protocol);
-       if (protocol == A_POP3) {
-               SET_NTH_SENSITIVE(A_APOP);
-       } else if (protocol == A_APOP) {
-               SET_NTH_SENSITIVE(A_POP3);
+static void prefs_account_imap_auth_type_set_data_from_optmenu(PrefParam *pparam)
+{
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+
+       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
+       menuitem = gtk_menu_get_active(GTK_MENU(menu));
+       *((RecvProtocol *)pparam->data) = GPOINTER_TO_INT
+               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+}
+
+static void prefs_account_imap_auth_type_set_optmenu(PrefParam *pparam)
+{
+       IMAPAuthType type = *((IMAPAuthType *)pparam->data);
+       GtkOptionMenu *optmenu = GTK_OPTION_MENU(*pparam->widget);
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+
+       switch (type) {
+       case IMAP_AUTH_LOGIN:
+               gtk_option_menu_set_history(optmenu, 1);
+               break;
+       case IMAP_AUTH_CRAM_MD5:
+               gtk_option_menu_set_history(optmenu, 2);
+               break;
+       case IMAP_AUTH_ANON:
+               gtk_option_menu_set_history(optmenu, 3);
+               break;
+       case 0:
+       default:
+               gtk_option_menu_set_history(optmenu, 0);
        }
 
-#undef SET_NTH_SENSITIVE
+       menu = gtk_option_menu_get_menu(optmenu);
+       menuitem = gtk_menu_get_active(GTK_MENU(menu));
+       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
+}
+
+static void prefs_account_smtp_auth_type_set_data_from_optmenu(PrefParam *pparam)
+{
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+
+       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
+       menuitem = gtk_menu_get_active(GTK_MENU(menu));
+       *((RecvProtocol *)pparam->data) = GPOINTER_TO_INT
+               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+}
 
+static void prefs_account_smtp_auth_type_set_optmenu(PrefParam *pparam)
+{
+       SMTPAuthType type = *((SMTPAuthType *)pparam->data);
+       GtkOptionMenu *optmenu = GTK_OPTION_MENU(*pparam->widget);
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+
+       switch (type) {
+       case SMTPAUTH_PLAIN:
+               gtk_option_menu_set_history(optmenu, 1);
+               break;
+       case SMTPAUTH_LOGIN:
+               gtk_option_menu_set_history(optmenu, 2);
+               break;
+       case SMTPAUTH_CRAM_MD5:
+               gtk_option_menu_set_history(optmenu, 3);
+               break;
+       case SMTPAUTH_DIGEST_MD5:
+               gtk_option_menu_set_history(optmenu, 4);
+               break;
+       case 0:
+       default:
+               gtk_option_menu_set_history(optmenu, 0);
+       }
+
+       menu = gtk_option_menu_get_menu(optmenu);
        menuitem = gtk_menu_get_active(GTK_MENU(menu));
        gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
 }
 
+static void prefs_account_set_string_from_optmenu(PrefParam *pparam)
+{
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+       gchar **str;
+
+       g_return_if_fail(*pparam->widget != NULL);
+
+       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(*pparam->widget));
+       menuitem = gtk_menu_get_active(GTK_MENU(menu));
+       if (menuitem == NULL)
+               return;
+
+       str = (gchar **) pparam->data;
+        g_free(*str);
+       *str = g_strdup(g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+}
+
+static void prefs_account_set_optmenu_from_string(PrefParam *pparam)
+{
+       GtkWidget *optionmenu;
+       GtkWidget *menu;
+       gboolean found = FALSE;
+       GList *children, *cur;
+       gchar *prefsid;
+       guint i = 0;
+
+       g_return_if_fail(*pparam->widget != NULL);
+
+       prefsid = *((gchar **) pparam->data);
+       if (prefsid == NULL)
+               return;
+
+       optionmenu = *pparam->widget;
+       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(optionmenu));
+       children = gtk_container_children(GTK_CONTAINER(menu));
+       for (cur = children; cur != NULL; cur = g_list_next(cur)) {
+               GtkWidget *item = (GtkWidget *) cur->data;
+               gchar *id;
+
+               id = g_object_get_data(G_OBJECT(item), MENU_VAL_ID);
+               if (id != NULL && strcmp(id, prefsid) == 0) {
+                       found = TRUE;
+                       gtk_option_menu_set_history(GTK_OPTION_MENU(optionmenu), i);
+               }
+               i++;
+       }
+
+       if (!found) {
+               gchar *name;
+               GtkWidget *menuitem;
+
+               name = g_strdup_printf(_("Unsupported (%s)"), prefsid);
+               menuitem = gtk_menu_item_new_with_label(name);
+               gtk_widget_show(menuitem);
+               g_object_set_data_full(G_OBJECT(menuitem), MENU_VAL_ID, g_strdup(prefsid), g_free);
+               gtk_menu_append(GTK_MENU(menu), menuitem);
+               g_free(name);
+
+               gtk_option_menu_set_history(GTK_OPTION_MENU(optionmenu), i);
+       }
+
+       g_list_free(children);
+}
+
 static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
 {
        RecvProtocol protocol;
-       gboolean active;
-       gint auth;
 
        protocol = GPOINTER_TO_INT
-               (gtk_object_get_user_data(GTK_OBJECT(menuitem)));
+               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
 
        switch(protocol) {
        case A_NNTP:
@@ -2115,8 +2859,13 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                gtk_widget_show(basic.nntpserv_entry);
                gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
                                           0, VSPACING_NARROW);
+
                gtk_widget_set_sensitive(basic.nntpauth_chkbtn, TRUE);
                gtk_widget_show(basic.nntpauth_chkbtn);
+
+               gtk_widget_set_sensitive(basic.nntpauth_onconnect_chkbtn, TRUE);
+               gtk_widget_show(basic.nntpauth_onconnect_chkbtn);
+
                gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
                                           1, VSPACING_NARROW);
                gtk_widget_hide(basic.recvserv_label);
@@ -2151,29 +2900,45 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                gtk_widget_set_sensitive(basic.pass_entry, TRUE);
 
                /* update userid/passwd sensitive state */
+
                prefs_account_nntpauth_toggled
                        (GTK_TOGGLE_BUTTON(basic.nntpauth_chkbtn), NULL);
-               gtk_widget_set_sensitive(receive.pop3_frame, FALSE);
+               gtk_widget_hide(receive.pop3_frame);
+               gtk_widget_hide(receive.imap_frame);
+               gtk_widget_hide(receive.local_frame);
+               gtk_widget_show(receive.frame_maxarticle);
+               gtk_widget_set_sensitive(receive.filter_on_recv_chkbtn, TRUE);
                gtk_widget_set_sensitive(receive.recvatgetall_chkbtn, TRUE);
-
+               /* update pop_before_smtp sensitivity */
+               gtk_toggle_button_set_active
+                       (GTK_TOGGLE_BUTTON(p_send.pop_bfr_smtp_chkbtn), FALSE);
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_chkbtn, FALSE);
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_tm_entry, FALSE);
+               
                if (!tmp_ac_prefs.account_name) {
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive.filter_on_recv_chkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive.recvatgetall_chkbtn),
                                 FALSE);
                }
 
-#if USE_SSL
-               gtk_widget_set_sensitive(ssl.pop_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.imap_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.nntp_frame, TRUE);
-               gtk_widget_set_sensitive(ssl.send_frame, TRUE);
+#if USE_OPENSSL
+               gtk_widget_hide(ssl.pop_frame);
+               gtk_widget_hide(ssl.imap_frame);
+               gtk_widget_show(ssl.nntp_frame);
+               gtk_widget_show(ssl.send_frame);
 #endif
                gtk_widget_hide(advanced.popport_hbox);
                gtk_widget_hide(advanced.imapport_hbox);
                gtk_widget_show(advanced.nntpport_hbox);
                gtk_widget_show(advanced.crosspost_chkbtn);
                gtk_widget_show(advanced.crosspost_colormenu);
-               gtk_widget_set_sensitive(advanced.imap_frame, FALSE);
+               gtk_widget_hide(advanced.tunnelcmd_chkbtn);
+               gtk_widget_hide(advanced.tunnelcmd_entry);
+               gtk_widget_hide(receive.imapdir_label);
+               gtk_widget_hide(receive.imapdir_entry);
                break;
        case A_LOCAL:
                gtk_widget_hide(basic.nntpserv_label);
@@ -2182,6 +2947,9 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                           0, 0);
                gtk_widget_set_sensitive(basic.nntpauth_chkbtn, FALSE);
                gtk_widget_hide(basic.nntpauth_chkbtn);
+
+               gtk_widget_set_sensitive(basic.nntpauth_onconnect_chkbtn, FALSE);
+               gtk_widget_hide(basic.nntpauth_onconnect_chkbtn);
                gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
                                           1, 0);
                gtk_widget_hide(basic.recvserv_label);
@@ -2214,29 +2982,45 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                gtk_widget_set_sensitive(basic.pass_label, TRUE);
                gtk_widget_set_sensitive(basic.uid_entry,  TRUE);
                gtk_widget_set_sensitive(basic.pass_entry, TRUE);
-               gtk_widget_set_sensitive(receive.pop3_frame, FALSE);
-               gtk_widget_set_sensitive(receive.recvatgetall_chkbtn, FALSE);
+               gtk_widget_hide(receive.pop3_frame);
+               gtk_widget_hide(receive.imap_frame);
+               gtk_widget_show(receive.local_frame);
+               gtk_widget_hide(receive.frame_maxarticle);
+               gtk_widget_set_sensitive(receive.filter_on_recv_chkbtn, TRUE);
+               gtk_widget_set_sensitive(receive.recvatgetall_chkbtn, TRUE);
                prefs_account_mailcmd_toggled
                        (GTK_TOGGLE_BUTTON(basic.mailcmd_chkbtn), NULL);
 
+               /* update pop_before_smtp sensitivity */
+               gtk_toggle_button_set_active
+                       (GTK_TOGGLE_BUTTON(p_send.pop_bfr_smtp_chkbtn), FALSE);
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_chkbtn, FALSE);
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_tm_entry, FALSE);
+
                if (!tmp_ac_prefs.account_name) {
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive.filter_on_recv_chkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive.recvatgetall_chkbtn),
                                 TRUE);
                }
 
-#if USE_SSL
-               gtk_widget_set_sensitive(ssl.pop_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.imap_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.nntp_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.send_frame, TRUE);
+#if USE_OPENSSL
+               gtk_widget_hide(ssl.pop_frame);
+               gtk_widget_hide(ssl.imap_frame);
+               gtk_widget_hide(ssl.nntp_frame);
+               gtk_widget_show(ssl.send_frame);
 #endif
                gtk_widget_hide(advanced.popport_hbox);
                gtk_widget_hide(advanced.imapport_hbox);
                gtk_widget_hide(advanced.nntpport_hbox);
                gtk_widget_hide(advanced.crosspost_chkbtn);
                gtk_widget_hide(advanced.crosspost_colormenu);
-               gtk_widget_set_sensitive(advanced.imap_frame, FALSE);
+               gtk_widget_hide(advanced.tunnelcmd_chkbtn);
+               gtk_widget_hide(advanced.tunnelcmd_entry);
+               gtk_widget_hide(receive.imapdir_label);
+               gtk_widget_hide(receive.imapdir_entry);
                break;
        case A_IMAP4:
                gtk_widget_hide(basic.nntpserv_label);
@@ -2245,6 +3029,10 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                           0, 0);
                gtk_widget_set_sensitive(basic.nntpauth_chkbtn, FALSE);
                gtk_widget_hide(basic.nntpauth_chkbtn);
+
+               gtk_widget_set_sensitive(basic.nntpauth_onconnect_chkbtn, FALSE);
+               gtk_widget_hide(basic.nntpauth_onconnect_chkbtn);
+
                gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
                                           1, 0);
                gtk_widget_set_sensitive(basic.recvserv_label, TRUE);
@@ -2279,29 +3067,126 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                gtk_widget_set_sensitive(basic.pass_label, TRUE);
                gtk_widget_set_sensitive(basic.uid_entry,  TRUE);
                gtk_widget_set_sensitive(basic.pass_entry, TRUE);
-               gtk_widget_set_sensitive(receive.pop3_frame, FALSE);
+               gtk_widget_hide(receive.pop3_frame);
+               gtk_widget_show(receive.imap_frame);
+               gtk_widget_hide(receive.local_frame);
+               gtk_widget_hide(receive.frame_maxarticle);
+               gtk_widget_set_sensitive(receive.filter_on_recv_chkbtn, TRUE);
                gtk_widget_set_sensitive(receive.recvatgetall_chkbtn, TRUE);
                gtk_widget_set_sensitive(basic.smtpserv_entry, TRUE);
                gtk_widget_set_sensitive(basic.smtpserv_label, TRUE);
 
+               /* update pop_before_smtp sensitivity */
+               gtk_toggle_button_set_active
+                       (GTK_TOGGLE_BUTTON(p_send.pop_bfr_smtp_chkbtn), FALSE);
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_chkbtn, FALSE);
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_tm_entry, FALSE);
+
                if (!tmp_ac_prefs.account_name) {
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive.filter_on_recv_chkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive.recvatgetall_chkbtn),
                                 FALSE);
                }
 
-#if USE_SSL
-               gtk_widget_set_sensitive(ssl.pop_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.imap_frame, TRUE);
-               gtk_widget_set_sensitive(ssl.nntp_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.send_frame, TRUE);
+#if USE_OPENSSL
+               gtk_widget_hide(ssl.pop_frame);
+               gtk_widget_show(ssl.imap_frame);
+               gtk_widget_hide(ssl.nntp_frame);
+               gtk_widget_show(ssl.send_frame);
 #endif
                gtk_widget_hide(advanced.popport_hbox);
                gtk_widget_show(advanced.imapport_hbox);
                gtk_widget_hide(advanced.nntpport_hbox);
                gtk_widget_hide(advanced.crosspost_chkbtn);
                gtk_widget_hide(advanced.crosspost_colormenu);
-               gtk_widget_set_sensitive(advanced.imap_frame, TRUE);
+               gtk_widget_show(advanced.tunnelcmd_chkbtn);
+               gtk_widget_show(advanced.tunnelcmd_entry);
+               gtk_widget_show(receive.imapdir_label);
+               gtk_widget_show(receive.imapdir_entry);
+               break;
+       case A_NONE:
+               gtk_widget_hide(basic.nntpserv_label);
+               gtk_widget_hide(basic.nntpserv_entry);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          0, 0);
+               gtk_widget_set_sensitive(basic.nntpauth_chkbtn, FALSE);
+               gtk_widget_hide(basic.nntpauth_chkbtn);
+
+               gtk_widget_set_sensitive(basic.nntpauth_onconnect_chkbtn, FALSE);
+               gtk_widget_hide(basic.nntpauth_onconnect_chkbtn);
+
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          1, 0);
+               gtk_widget_set_sensitive(basic.recvserv_label, FALSE);
+               gtk_widget_set_sensitive(basic.recvserv_entry, FALSE);
+               gtk_widget_hide(basic.recvserv_label);
+               gtk_widget_hide(basic.recvserv_entry);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          2, VSPACING_NARROW);
+               gtk_widget_show(basic.smtpserv_label);
+               gtk_widget_show(basic.smtpserv_entry);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          4, VSPACING_NARROW);
+               gtk_widget_hide(basic.localmbox_label);
+               gtk_widget_hide(basic.localmbox_entry);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          3, 0);
+               gtk_widget_hide(basic.mailcmd_label);
+               gtk_widget_hide(basic.mailcmd_entry);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          6, 0);
+               gtk_widget_hide(basic.mailcmd_chkbtn);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          5, 0);
+               gtk_widget_hide(basic.uid_label);
+               gtk_widget_hide(basic.pass_label);
+               gtk_widget_hide(basic.uid_entry);
+               gtk_widget_hide(basic.pass_entry);
+               gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
+                                          7, VSPACING_NARROW);
+
+               gtk_widget_set_sensitive(basic.uid_label,  FALSE);
+               gtk_widget_set_sensitive(basic.pass_label, FALSE);
+               gtk_widget_set_sensitive(basic.uid_entry,  FALSE);
+               gtk_widget_set_sensitive(basic.pass_entry, FALSE);
+               gtk_widget_set_sensitive(receive.pop3_frame, FALSE);
+               gtk_widget_hide(receive.pop3_frame);
+               gtk_widget_hide(receive.imap_frame);
+               gtk_widget_hide(receive.local_frame);
+               gtk_widget_hide(receive.frame_maxarticle);
+               gtk_widget_set_sensitive(receive.filter_on_recv_chkbtn, FALSE);
+               gtk_widget_set_sensitive(receive.recvatgetall_chkbtn, FALSE);
+
+               gtk_widget_set_sensitive(basic.smtpserv_entry, TRUE);
+               gtk_widget_set_sensitive(basic.smtpserv_label, TRUE);
+
+               /* update pop_before_smtp sensitivity */
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_chkbtn, FALSE);
+               pop_bfr_smtp_tm_set_sens(NULL, NULL);
+       
+               gtk_toggle_button_set_active
+                       (GTK_TOGGLE_BUTTON(receive.filter_on_recv_chkbtn), FALSE);
+               gtk_toggle_button_set_active
+                       (GTK_TOGGLE_BUTTON(receive.recvatgetall_chkbtn), FALSE);
+
+#if USE_OPENSSL
+               gtk_widget_hide(ssl.pop_frame);
+               gtk_widget_hide(ssl.imap_frame);
+               gtk_widget_hide(ssl.nntp_frame);
+               gtk_widget_show(ssl.send_frame);
+#endif
+               gtk_widget_hide(advanced.popport_hbox);
+               gtk_widget_hide(advanced.imapport_hbox);
+               gtk_widget_hide(advanced.nntpport_hbox);
+               gtk_widget_hide(advanced.crosspost_chkbtn);
+               gtk_widget_hide(advanced.crosspost_colormenu);
+               gtk_widget_hide(advanced.tunnelcmd_chkbtn);
+               gtk_widget_hide(advanced.tunnelcmd_entry);
+               gtk_widget_hide(receive.imapdir_label);
+               gtk_widget_hide(receive.imapdir_entry);
                break;
        case A_POP3:
        default:
@@ -2311,6 +3196,10 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                           0, 0);
                gtk_widget_set_sensitive(basic.nntpauth_chkbtn, FALSE);
                gtk_widget_hide(basic.nntpauth_chkbtn);
+
+               gtk_widget_set_sensitive(basic.nntpauth_onconnect_chkbtn, FALSE);
+               gtk_widget_hide(basic.nntpauth_onconnect_chkbtn);
+
                gtk_table_set_row_spacing (GTK_TABLE (basic.serv_table),
                                           1, 0);
                gtk_widget_set_sensitive(basic.recvserv_label, TRUE);
@@ -2346,28 +3235,44 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                gtk_widget_set_sensitive(basic.uid_entry,  TRUE);
                gtk_widget_set_sensitive(basic.pass_entry, TRUE);
                gtk_widget_set_sensitive(receive.pop3_frame, TRUE);
+               gtk_widget_show(receive.pop3_frame);
+               gtk_widget_hide(receive.imap_frame);
+               gtk_widget_hide(receive.local_frame);
+               gtk_widget_hide(receive.frame_maxarticle);
+               gtk_widget_set_sensitive(receive.filter_on_recv_chkbtn, TRUE);
                gtk_widget_set_sensitive(receive.recvatgetall_chkbtn, TRUE);
+
                gtk_widget_set_sensitive(basic.smtpserv_entry, TRUE);
                gtk_widget_set_sensitive(basic.smtpserv_label, TRUE);
 
+               /* update pop_before_smtp sensitivity */
+               gtk_widget_set_sensitive(p_send.pop_bfr_smtp_chkbtn, TRUE);
+               pop_bfr_smtp_tm_set_sens(NULL, NULL);
+               
                if (!tmp_ac_prefs.account_name) {
+                       gtk_toggle_button_set_active
+                               (GTK_TOGGLE_BUTTON(receive.filter_on_recv_chkbtn), 
+                               TRUE);
                        gtk_toggle_button_set_active
                                (GTK_TOGGLE_BUTTON(receive.recvatgetall_chkbtn),
                                 TRUE);
                }
 
-#if USE_SSL
-               gtk_widget_set_sensitive(ssl.pop_frame, TRUE);
-               gtk_widget_set_sensitive(ssl.imap_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.nntp_frame, FALSE);
-               gtk_widget_set_sensitive(ssl.send_frame, TRUE);
+#if USE_OPENSSL
+               gtk_widget_show(ssl.pop_frame);
+               gtk_widget_hide(ssl.imap_frame);
+               gtk_widget_hide(ssl.nntp_frame);
+               gtk_widget_show(ssl.send_frame);
 #endif
                gtk_widget_show(advanced.popport_hbox);
                gtk_widget_hide(advanced.imapport_hbox);
                gtk_widget_hide(advanced.nntpport_hbox);
                gtk_widget_hide(advanced.crosspost_chkbtn);
                gtk_widget_hide(advanced.crosspost_colormenu);
-               gtk_widget_set_sensitive(advanced.imap_frame, FALSE);
+               gtk_widget_hide(advanced.tunnelcmd_chkbtn);
+               gtk_widget_hide(advanced.tunnelcmd_entry);
+               gtk_widget_hide(receive.imapdir_label);
+               gtk_widget_hide(receive.imapdir_entry);
                break;
        }
 
@@ -2386,6 +3291,7 @@ static void prefs_account_nntpauth_toggled(GtkToggleButton *button,
        gtk_widget_set_sensitive(basic.pass_label, auth);
        gtk_widget_set_sensitive(basic.uid_entry,  auth);
        gtk_widget_set_sensitive(basic.pass_entry, auth);
+       gtk_widget_set_sensitive(basic.nntpauth_onconnect_chkbtn, auth);
 }
 
 static void prefs_account_mailcmd_toggled(GtkToggleButton *button,
@@ -2403,18 +3309,12 @@ static void prefs_account_mailcmd_toggled(GtkToggleButton *button,
        gtk_widget_set_sensitive(basic.pass_entry, !use_mailcmd);
 }
 
-static void prefs_account_smtp_userid_cb(GtkEditable *editable,
-                                        gpointer smtp_passwd)
+void prefs_account_register_page(PrefsPage *page)
 {
-       gchar *buf;
-       gboolean use_smtp_userid;
-       
-       buf = gtk_editable_get_chars(editable, 0, -1);
-       if(buf[0] == '\0') {
-               use_smtp_userid = FALSE;
-       } else {
-               use_smtp_userid = TRUE;
-       }
-       gtk_widget_set_sensitive(GTK_WIDGET(smtp_passwd), use_smtp_userid);
-       g_free(buf);
+       prefs_pages = g_slist_append(prefs_pages, page);
+}
+
+void prefs_account_unregister_page(PrefsPage *page)
+{
+       prefs_pages = g_slist_remove(prefs_pages, page);
 }