diff --git a/config.c b/config.c index 5389955..8fc93bb 100644 --- a/config.c +++ b/config.c @@ -44,6 +44,7 @@ config_defaults (config_t * conf) conf->copy_deleted_to = global.copy_deleted_to; conf->use_namespace = global.use_namespace; conf->expunge = global.expunge; + conf->poll = global.poll; #if HAVE_LIBSSL conf->require_ssl = global.require_ssl; conf->use_imaps = global.use_imaps; @@ -235,6 +236,13 @@ load_config (const char *where) else global.expunge = (strcasecmp (val, "yes") == 0); } + else if (!strncasecmp ("Poll", cmd, 4)) + { + if (*cur) + (*cur)->poll = atoi (val); + else + global.poll = atoi (val); + } #if HAVE_LIBSSL else if (!strncasecmp ("CertificateFile", cmd, 15)) { diff --git a/imap.c b/imap.c index 0e8f0d6..00f9159 100644 --- a/imap.c +++ b/imap.c @@ -653,20 +653,22 @@ imap_open (config_t * box, unsigned int minuid, imap_t * imap) #if HAVE_LIBSSL if (box->use_imaps) use_ssl = 1; - else if (box->use_sslv2 || box->use_sslv3 || box->use_tlsv1) + else { /* let's see what this puppy can do... */ if ((ret = imap_exec (imap, "CAPABILITY"))) break; - /* always try to select SSL support if available */ - if (imap->have_starttls) + if (box->use_sslv2 || box->use_sslv3 || box->use_tlsv1) { - if ((ret = imap_exec (imap, "STARTTLS"))) - break; - use_ssl = 1; + /* always try to select SSL support if available */ + if (imap->have_starttls) + { + if ((ret = imap_exec (imap, "STARTTLS"))) + break; + use_ssl = 1; + } } - } if (!use_ssl) diff --git a/isync.h b/isync.h index 3d82ce8..130967b 100644 --- a/isync.h +++ b/isync.h @@ -57,6 +57,7 @@ struct config char *box; char *alias; char *copy_deleted_to; + int poll; /* how often to poll (in seconds) 0 = OFF */ off_t max_size; config_t *next; #if HAVE_LIBSSL