2004-11-09 [colin] 0.9.12cvs144.1
[claws.git] / src / prefs_account.h
index a60e0937ec2cf4769e7d0fab9dd0c7ab0be21742..09d09a698b717da5cea587f28f4b4007fd11b06a 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2001 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2004 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
 #  include "config.h"
 #endif
 
-#include <glib.h>
-
 typedef struct _PrefsAccount   PrefsAccount;
 
-#include "folder.h"
-
 typedef enum {
        A_POP3,
        A_APOP,
        A_RPOP,
        A_IMAP4,
        A_NNTP,
-       A_LOCAL
+       A_LOCAL,
+       A_NONE,         /* SMTP only */
 } RecvProtocol;
 
-#if USE_GPGME
 typedef enum {
-       SIGN_KEY_DEFAULT,
-       SIGN_KEY_BY_FROM,
-       SIGN_KEY_CUSTOM
-} SignKeyType;
-#endif /* USE_GPGME */
+       SIG_FILE,
+       SIG_COMMAND,
+       SIG_DIRECT
+} SigType;
 
-#if USE_SSL
-typedef enum {
-       SSL_SMTP_NONE,
-       SSL_SMTP_TUNNEL,
-       SSL_SMTP_STARTTLS
-} SSLSMTPType;
-#endif /* USE_SSL */
+#include <glib.h>
+
+#include "smtp.h"
+#include "folder.h"
 
 struct _PrefsAccount
 {
@@ -66,11 +58,11 @@ struct _PrefsAccount
 
        /* Server info */
        RecvProtocol protocol;
-       gchar *inbox;
        gchar *recv_server;
        gchar *smtp_server;
        gchar *nntp_server;
        gboolean use_nntp_auth;
+       gboolean use_nntp_auth_onconnect;
        gchar *userid;
        gchar *passwd;
 
@@ -78,48 +70,66 @@ struct _PrefsAccount
        gboolean use_mail_command;
        gchar * mail_command;
 
-#if USE_SSL
-       /* SSL */
-       gboolean ssl_pop;
-       gboolean ssl_imap;
-       SSLSMTPType ssl_smtp;
-#endif /* USE_SSL */
-
+#if USE_OPENSSL
+       SSLType ssl_pop;
+       SSLType ssl_imap;
+       SSLType ssl_nntp;
+       SSLType ssl_smtp;
+       gboolean use_nonblocking_ssl;
+#endif /* USE_OPENSSL */
 
        /* Temporarily preserved password */
        gchar *tmp_pass;
 
        /* Receive */
        gboolean rmmail;
+       gint msg_leave_time;
        gboolean getall;
        gboolean recv_at_getall;
+       gboolean sd_rmmail_on_download;
+       gboolean sd_filter_on_recv;
+       gboolean enable_size_limit;
+       gint size_limit;
        gboolean filter_on_recv;
+       gchar *inbox;
+       gint max_articles;
 
-       gchar *imap_dir;
+       gint imap_auth_type;
 
        /* Send */
-       gboolean  add_date;
-       gboolean  gen_msgid;
-       gboolean  add_customhdr;
-       gboolean  set_autocc;
-       gchar    *auto_cc;
-       gboolean  set_autobcc;
-       gchar    *auto_bcc;
-       gboolean  set_autoreplyto;
-       gchar    *auto_replyto;
+       gboolean add_date;
+       gboolean gen_msgid;
+       gboolean add_customhdr;
        gboolean use_smtp_auth;
+       SMTPAuthType smtp_auth_type;
+       gchar *smtp_userid;
+       gchar *smtp_passwd;
+
+       /* Temporarily preserved password */
+       gchar *tmp_smtp_pass;
+
        gboolean pop_before_smtp;
+       gint pop_before_smtp_timeout;
+       time_t last_pop_login_time;
 
        GSList *customhdr_list;
 
        /* Compose */
-       gchar *sig_path;
+       SigType sig_type;
+       gchar    *sig_path;
+       gboolean  auto_sig;
+       gchar    *sig_sep;
+       gboolean  set_autocc;
+       gchar    *auto_cc;
+       gboolean  set_autobcc;
+       gchar    *auto_bcc;
+       gboolean  set_autoreplyto;
+       gchar    *auto_replyto;
 
-#if USE_GPGME
        /* Privacy */
-       SignKeyType sign_key;
-       gchar *sign_key_id;
-#endif /* USE_GPGME */
+       gchar    *default_privacy_system;
+       gboolean  default_encrypt;
+       gboolean  default_sign;
 
        /* Advanced */
        gboolean  set_smtpport;
@@ -132,20 +142,45 @@ struct _PrefsAccount
        gushort   nntpport;
        gboolean  set_domain;
        gchar    *domain;
+       gboolean  mark_crosspost_read;
+       gint      crosspost_col;
+
+       /* Use this command to open a socket, rather than doing so
+        * directly.  Good if you want to perhaps use a special socks
+        * tunnel command, or run IMAP-over-SSH.  In this case the
+        * server, port etc are only for the user's own information
+        * and are not used.  username and password are used to
+        * authenticate the account only if necessary, since some
+        * tunnels will implicitly authenticate by running e.g. imapd
+        * as a particular user. */
+       gboolean  set_tunnelcmd;
+       gchar     *tunnelcmd;
+
+       gchar *imap_dir;
+
+       gboolean set_sent_folder;
+       gchar *sent_folder;
+       gboolean set_draft_folder;
+       gchar *draft_folder;
+       gboolean set_trash_folder;
+       gchar *trash_folder;
 
        /* Default or not */
        gboolean is_default;
        /* Unique account ID */
        gint account_id;
 
-       RemoteFolder *folder;
+       Folder *folder;
 };
 
+PrefsAccount *prefs_account_new                (void);
+
 void prefs_account_read_config         (PrefsAccount   *ac_prefs,
                                         const gchar    *label);
-void prefs_account_save_config         (PrefsAccount   *ac_prefs);
-void prefs_account_save_config_all     (GList          *account_list);
+void prefs_account_write_config_all    (GList          *account_list);
+
 void prefs_account_free                        (PrefsAccount   *ac_prefs);
+
 PrefsAccount *prefs_account_open       (PrefsAccount   *ac_prefs);
 
 #endif /* __PREFS_ACCOUNT_H__ */