sync with 0.8.10cvs9
[claws.git] / src / prefs_account.c
index f8ba0d35eb6370def44e6426c16238b21c364f9f..0f7f1dade900a2bf1a60b8e213462e85f6392271 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-2003 Hiroyuki Yamamoto
  *
  * 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
@@ -34,7 +34,7 @@
 
 #include "intl.h"
 #include "main.h"
-#include "prefs.h"
+#include "prefs_gtk.h"
 #include "prefs_account.h"
 #include "prefs_customheader.h"
 #include "account.h"
@@ -74,6 +74,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;
@@ -103,9 +104,7 @@ static struct 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;
@@ -116,7 +115,6 @@ static struct Send {
 
 static struct Compose {
        GtkWidget *sigpath_entry;
-
        GtkWidget *autocc_chkbtn;
        GtkWidget *autocc_entry;
        GtkWidget *autobcc_chkbtn;
@@ -129,8 +127,8 @@ static struct Compose {
 static struct Privacy {
        GtkWidget *default_encrypt_chkbtn;
        GtkWidget *default_sign_chkbtn;
-       GtkWidget *ascii_armored_chkbtn;
-       GtkWidget *clearsign_chkbtn;
+       GtkWidget *gnupg_mime_radiobtn;
+       GtkWidget *gnupg_inline_radiobtn;
        GtkWidget *defaultkey_radiobtn;
        GtkWidget *emailkey_radiobtn;
        GtkWidget *customkey_radiobtn;
@@ -138,7 +136,7 @@ static struct Privacy {
 } privacy;
 #endif /* USE_GPGME */
 
-#if USE_SSL
+#if USE_OPENSSL
 static struct SSLPrefs {
        GtkWidget *pop_frame;
        GtkWidget *pop_nossl_radiobtn;
@@ -159,7 +157,7 @@ static struct SSLPrefs {
        GtkWidget *smtp_ssltunnel_radiobtn;
        GtkWidget *smtp_starttls_radiobtn;
 } ssl;
-#endif /* USE_SSL */
+#endif /* USE_OPENSSL */
 
 static struct Advanced {
        GtkWidget *smtpport_chkbtn;
@@ -201,13 +199,13 @@ static void prefs_account_smtp_auth_type_set_data_from_optmenu
                                                        (PrefParam *pparam);
 static void prefs_account_smtp_auth_type_set_optmenu   (PrefParam *pparam);
 
-#if USE_GPGME || USE_SSL
+#if USE_GPGME || USE_OPENSSL
 static void prefs_account_enum_set_data_from_radiobtn  (PrefParam *pparam);
 static void prefs_account_enum_set_radiobtn            (PrefParam *pparam);
-#endif /* USE_GPGME || USE_SSL */
+#endif /* USE_GPGME || USE_OPENSSL */
 
 #if USE_GPGME
-static void prefs_account_ascii_armored_warning                (GtkWidget *widget);
+static void prefs_account_gnupg_inline_warning         (GtkWidget *widget);
 #endif /* USE_GPGME */
 
 static void prefs_account_crosspost_set_data_from_colormenu(PrefParam *pparam);
@@ -262,6 +260,10 @@ static PrefParam param[] = {
        {"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},
@@ -380,12 +382,10 @@ static PrefParam param[] = {
        {"default_sign", "FALSE", &tmp_ac_prefs.default_sign, P_BOOL,
         &privacy.default_sign_chkbtn,
         prefs_set_data_from_toggle, prefs_set_toggle},
-       {"ascii_armored", "FALSE", &tmp_ac_prefs.ascii_armored, P_BOOL,
-        &privacy.ascii_armored_chkbtn,
-        prefs_set_data_from_toggle, prefs_set_toggle},
-       {"clearsign", "FALSE", &tmp_ac_prefs.clearsign, P_BOOL,
-        &privacy.clearsign_chkbtn,
-        prefs_set_data_from_toggle, prefs_set_toggle},
+       {"default_gnupg_mode", NULL, &tmp_ac_prefs.default_gnupg_mode, P_ENUM,
+        &privacy.gnupg_mime_radiobtn,
+        prefs_account_enum_set_data_from_radiobtn,
+        prefs_account_enum_set_radiobtn},
        {"sign_key", NULL, &tmp_ac_prefs.sign_key, P_ENUM,
         &privacy.defaultkey_radiobtn,
         prefs_account_enum_set_data_from_radiobtn,
@@ -395,7 +395,7 @@ static PrefParam param[] = {
         prefs_set_data_from_entry, prefs_set_entry},
 #endif /* USE_GPGME */
 
-#if USE_SSL
+#if USE_OPENSSL
        /* SSL */
        {"ssl_pop", "0", &tmp_ac_prefs.ssl_pop, P_ENUM,
         &ssl.pop_nossl_radiobtn,
@@ -413,7 +413,7 @@ static PrefParam param[] = {
         &ssl.smtp_nossl_radiobtn,
         prefs_account_enum_set_data_from_radiobtn,
         prefs_account_enum_set_radiobtn},
-#endif /* USE_SSL */
+#endif /* USE_OPENSSL */
 
        /* Advanced */
        {"set_smtpport", "FALSE", &tmp_ac_prefs.set_smtpport, P_BOOL,
@@ -510,9 +510,9 @@ 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,
@@ -583,21 +583,21 @@ void prefs_account_save_config_all(GList *account_list)
                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);
+                       g_warning("failed to write configuration to file\n");
+                       prefs_file_close_revert(pfile);
                        return;
                }
                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");
 }
 
 void prefs_account_free(PrefsAccount *ac_prefs)
@@ -740,10 +740,10 @@ static void prefs_account_create(void)
        prefs_account_privacy_create();
        SET_NOTEBOOK_LABEL(dialog.notebook, _("Privacy"), page++);
 #endif /* USE_GPGME */
-#if USE_SSL
+#if USE_OPENSSL
        prefs_account_ssl_create();
        SET_NOTEBOOK_LABEL(dialog.notebook, _("SSL"), page++);
-#endif /* USE_SSL */
+#endif /* USE_OPENSSL */
        prefs_account_advanced_create();
        SET_NOTEBOOK_LABEL(dialog.notebook, _("Advanced"), page++);
 
@@ -806,6 +806,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;
@@ -823,7 +824,7 @@ static void prefs_account_basic_create(void)
        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);
 
@@ -932,7 +933,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, 1, 2,
+                         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, 1, 2,
                          GTK_FILL, 0, 0, 0);
 
        recvserv_entry = gtk_entry_new ();
@@ -1032,6 +1041,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;
@@ -1050,6 +1060,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;
@@ -1158,7 +1169,7 @@ static void prefs_account_receive_create(void)
        gtk_widget_set_usize (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);
 
@@ -1257,7 +1268,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);
@@ -1505,14 +1516,16 @@ static void prefs_account_compose_create(void)
 static void prefs_account_privacy_create(void)
 {
        GtkWidget *vbox1;
+       GtkWidget *frame_mode;
+       GtkWidget *vbox_mode;
        GtkWidget *frame1;
        GtkWidget *vbox2;
        GtkWidget *hbox1;
        GtkWidget *label;
        GtkWidget *default_encrypt_chkbtn;
        GtkWidget *default_sign_chkbtn;
-       GtkWidget *ascii_armored_chkbtn;
-       GtkWidget *clearsign_chkbtn;
+       GtkWidget *gnupg_mime_radiobtn;
+       GtkWidget *gnupg_inline_radiobtn;
        GtkWidget *defaultkey_radiobtn;
        GtkWidget *emailkey_radiobtn;
        GtkWidget *customkey_radiobtn;
@@ -1531,12 +1544,33 @@ static void prefs_account_privacy_create(void)
                           _("Encrypt message by default"));
        PACK_CHECK_BUTTON (vbox2, default_sign_chkbtn,
                           _("Sign message by default"));
-       PACK_CHECK_BUTTON (vbox2, ascii_armored_chkbtn,
-                          _("Use ASCII-armored format for encryption"));
-       PACK_CHECK_BUTTON (vbox2, clearsign_chkbtn,
-                          _("Use clear text signature"));
-       gtk_signal_connect (GTK_OBJECT (ascii_armored_chkbtn), "toggled",
-                           prefs_account_ascii_armored_warning, NULL);
+                           
+       PACK_FRAME (vbox1, frame_mode, _("Default mode"));
+       
+       vbox_mode = gtk_vbox_new (FALSE, 0);
+       gtk_widget_show (vbox_mode);
+       gtk_container_add (GTK_CONTAINER (frame_mode), vbox_mode);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox_mode), 8);
+
+       gnupg_mime_radiobtn = gtk_radio_button_new_with_label
+               (NULL, _("Use PGP/MIME"));
+       gtk_widget_show (gnupg_mime_radiobtn);
+       gtk_box_pack_start (GTK_BOX (vbox_mode), gnupg_mime_radiobtn,
+                           FALSE, FALSE, 0);
+       gtk_object_set_user_data (GTK_OBJECT (gnupg_mime_radiobtn),
+                                 GINT_TO_POINTER (GNUPG_MODE_DETACH));
+
+       gnupg_inline_radiobtn = gtk_radio_button_new_with_label_from_widget
+               (GTK_RADIO_BUTTON (gnupg_mime_radiobtn),
+                _("Use Inline"));
+       gtk_widget_show (gnupg_inline_radiobtn);
+       gtk_box_pack_start (GTK_BOX (vbox_mode), gnupg_inline_radiobtn,
+                           FALSE, FALSE, 0);
+       gtk_object_set_user_data (GTK_OBJECT (gnupg_inline_radiobtn),
+                                 GINT_TO_POINTER (GNUPG_MODE_INLINE));
+       gtk_signal_connect (GTK_OBJECT (gnupg_inline_radiobtn), "clicked",
+                           prefs_account_gnupg_inline_warning, NULL);
+
 
        PACK_FRAME (vbox1, frame1, _("Sign key"));
 
@@ -1593,8 +1627,8 @@ static void prefs_account_privacy_create(void)
 
        privacy.default_encrypt_chkbtn = default_encrypt_chkbtn;
        privacy.default_sign_chkbtn    = default_sign_chkbtn;
-       privacy.ascii_armored_chkbtn   = ascii_armored_chkbtn;
-       privacy.clearsign_chkbtn       = clearsign_chkbtn;
+       privacy.gnupg_mime_radiobtn    = gnupg_mime_radiobtn;
+       privacy.gnupg_inline_radiobtn  = gnupg_inline_radiobtn;
        privacy.defaultkey_radiobtn    = defaultkey_radiobtn;
        privacy.emailkey_radiobtn      = emailkey_radiobtn;
        privacy.customkey_radiobtn     = customkey_radiobtn;
@@ -1602,7 +1636,7 @@ static void prefs_account_privacy_create(void)
 }
 #endif /* USE_GPGME */
 
-#if USE_SSL
+#if USE_OPENSSL
 
 #define CREATE_RADIO_BUTTON(box, btn, btn_p, label, data)              \
 {                                                                      \
@@ -1751,7 +1785,7 @@ static void prefs_account_ssl_create(void)
 
 #undef CREATE_RADIO_BUTTONS
 #undef CREATE_RADIO_BUTTON
-#endif /* USE_SSL */
+#endif /* USE_OPENSSL */
 
 static void crosspost_color_toggled(void)
 {
@@ -2116,7 +2150,7 @@ static void prefs_account_edit_custom_header(void)
        prefs_custom_header_open(&tmp_ac_prefs);
 }
 
-#if USE_GPGME || USE_SSL
+#if USE_GPGME || USE_OPENSSL
 static void prefs_account_enum_set_data_from_radiobtn(PrefParam *pparam)
 {
        GtkRadioButton *radiobtn;
@@ -2155,16 +2189,16 @@ static void prefs_account_enum_set_radiobtn(PrefParam *pparam)
        }
 }
 
-#endif /* USE_GPGME || USE_SSL */
+#endif /* USE_GPGME || USE_OPENSSL */
 
 #if USE_GPGME
-static void prefs_account_ascii_armored_warning(GtkWidget *widget)
+static void prefs_account_gnupg_inline_warning(GtkWidget *widget)
 {
        if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget)) &&
            gtk_notebook_get_current_page(GTK_NOTEBOOK(dialog.notebook)) > 0)
                alertpanel_warning
-                       (_("It's not recommended to use the old style ASCII-armored\n"
-                          "mode for encrypted messages. It doesn't comply with the\n"
+                       (_("Its not recommended to use the old style Inline\n"
+                          "mode for GnuPG messages. It doesn't comply with\n"
                           "RFC 3156 - MIME Security with OpenPGP."));
 }
 #endif /* USE_GPGME */
@@ -2276,8 +2310,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);
@@ -2312,6 +2351,7 @@ 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);
@@ -2329,7 +2369,7 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                 FALSE);
                }
 
-#if USE_SSL
+#if USE_OPENSSL
                gtk_widget_hide(ssl.pop_frame);
                gtk_widget_hide(ssl.imap_frame);
                gtk_widget_show(ssl.nntp_frame);
@@ -2349,6 +2389,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);
@@ -2398,7 +2441,7 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                 TRUE);
                }
 
-#if USE_SSL
+#if USE_OPENSSL
                gtk_widget_hide(ssl.pop_frame);
                gtk_widget_hide(ssl.imap_frame);
                gtk_widget_hide(ssl.nntp_frame);
@@ -2418,6 +2461,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);
@@ -2469,7 +2516,7 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                 FALSE);
                }
 
-#if USE_SSL
+#if USE_OPENSSL
                gtk_widget_hide(ssl.pop_frame);
                gtk_widget_show(ssl.imap_frame);
                gtk_widget_hide(ssl.nntp_frame);
@@ -2490,6 +2537,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);
@@ -2539,7 +2590,7 @@ static void prefs_account_protocol_activated(GtkMenuItem *menuitem)
                                 TRUE);
                }
 
-#if USE_SSL
+#if USE_OPENSSL
                gtk_widget_show(ssl.pop_frame);
                gtk_widget_hide(ssl.imap_frame);
                gtk_widget_hide(ssl.nntp_frame);
@@ -2569,6 +2620,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,