[PATCH] add repository retrycount option
lkcl
lkcl at lkcl.net
Mon Dec 19 05:31:35 GMT 2016
>From 81205e3bb3bc04008b9473a71b90ec9a0612762c Mon Sep 17 00:00:00 2001
From: Luke Kenneth Casson Leighton <lkcl at lkcl.net>
Date: Mon, 19 Dec 2016 05:29:24 +0000
Subject: [PATCH] add repository retrycount option
Signed-off-by: Luke Kenneth Casson Leighton <lkcl at lkcl.net>
---
offlineimap.conf | 21 +++++++++++++++++++++
offlineimap/folder/Gmail.py | 2 +-
offlineimap/folder/IMAP.py | 5 ++++-
3 files changed, 26 insertions(+), 2 deletions(-)
diff --git a/offlineimap.conf b/offlineimap.conf
index 4df674b..2813061 100644
--- a/offlineimap.conf
+++ b/offlineimap.conf
@@ -1272,6 +1272,27 @@ remoteuser = username
# This option stands in the [Repository RemoteExample] section.
#
+# Operating under extreme network conditions (China) network connectivity
+# especially for SSL can be so bad and so slow that absolutely every
+# possible kind of connectivity error that can occur does occur.
+#
+# Rather than have offlineimap exit on errors it may be preferable
+# to have it simply retry connections dozens of times. The alternative
+# is to restart offlineimap in a constant loop, which may involve using
+# significant CPU cycles (if the repository is large) to load up the
+# UID database again.
+#
+# This option is best utilised in combination with socktimeout, which
+# catches instances of interference by e.g. the GFW at the TCP layer,
+# as well as China ISPs simply not coping.
+#
+# Default value: retrycount = 2
+#
+#retrycount = 2
+
+
+# This option stands in the [Repository RemoteExample] section.
+#
# If offlineiamp is having troubles to download some UIDS, it's possible to get
# them ignored in a list. This only ignore the download.
#
diff --git a/offlineimap/folder/Gmail.py b/offlineimap/folder/Gmail.py
index 31eaeb3..dc594d1 100644
--- a/offlineimap/folder/Gmail.py
+++ b/offlineimap/folder/Gmail.py
@@ -71,7 +71,7 @@ class GmailFolder(IMAPFolder):
(probably severity MESSAGE) if e.g. no message with
this UID could be found.
"""
- data = self._fetch_from_imap(str(uid), 2)
+ data = self._fetch_from_imap(str(uid), self.retrycount)
# data looks now e.g.
#[('320 (X-GM-LABELS (...) UID 17061 BODY[] {2565}','msgbody....')]
diff --git a/offlineimap/folder/IMAP.py b/offlineimap/folder/IMAP.py
index f8fcf7b..6587b8a 100644
--- a/offlineimap/folder/IMAP.py
+++ b/offlineimap/folder/IMAP.py
@@ -55,6 +55,9 @@ class IMAPFolder(BaseFolder):
# self.ui is set in BaseFolder.
self.imap_query = ['BODY.PEEK[]']
+ # number of times to retry fetching messages
+ self.retrycount = int(self.repository.getconf('retry', '2'))
+
fh_conf = self.repository.account.getconf('filterheaders', '')
self.filterheaders = [h for h in re.split(r'\s*,\s*', fh_conf) if h]
@@ -305,7 +308,7 @@ class IMAPFolder(BaseFolder):
this UID could be found.
"""
- data = self._fetch_from_imap(str(uid), 2)
+ data = self._fetch_from_imap(str(uid), self.retrycount)
# Data looks now e.g.
# [('320 (UID 17061 BODY[] {2565}','msgbody....')]
--
2.8.1
More information about the OfflineIMAP-project
mailing list