Allow to specify remote hostname even for the Gmail case
Previously we hard-coded the imap server name in the case of Gmail repositories, but often we need a different host name. So, allow people to specify the hostname via the regular "remotehosteval" and "remotehost" settings, and only falling back to imap.gmail.com when nothing has been specified. Cache the hostname, so we don't evaluate the whole thing each time we query the host name. Make the remotehosteval processing more robust, by catching any Exceptions that occur, and throw a OfflineImapError, that explains where exactly the error had occured. You can test this, e.g. by setting remotehosteval to 1/"n" or some other invalid expression. The whole IMAP.gethost() function has been documented code wise while going through. Signed-off-by: Sebastian Spaeth <Sebastian@SSpaeth.de> Signed-off-by: Nicolas Sebrecht <nicolas.s-dev@laposte.net>
This commit is contained in:

committed by
Nicolas Sebrecht

parent
1754bf4110
commit
b20f5192fb
@ -16,33 +16,37 @@
|
||||
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
|
||||
from offlineimap.repository.IMAP import IMAPRepository
|
||||
from offlineimap import folder
|
||||
from offlineimap import folder, OfflineImapError
|
||||
|
||||
class GmailRepository(IMAPRepository):
|
||||
"""Gmail IMAP repository.
|
||||
|
||||
Uses hard-coded host name and port, see:
|
||||
http://mail.google.com/support/bin/answer.py?answer=78799&topic=12814
|
||||
Falls back to hard-coded gmail host name and port, if none were specified:
|
||||
http://mail.google.com/support/bin/answer.py?answer=78799&topic=12814
|
||||
"""
|
||||
|
||||
#: Gmail IMAP server hostname
|
||||
# Gmail IMAP server hostname
|
||||
HOSTNAME = "imap.gmail.com"
|
||||
|
||||
#: Gmail IMAP server port
|
||||
# Gmail IMAP server port
|
||||
PORT = 993
|
||||
|
||||
def __init__(self, reposname, account):
|
||||
"""Initialize a GmailRepository object."""
|
||||
account.getconfig().set('Repository ' + reposname,
|
||||
'remotehost', GmailRepository.HOSTNAME)
|
||||
account.getconfig().set('Repository ' + reposname,
|
||||
'remoteport', GmailRepository.PORT)
|
||||
# Enforce SSL usage
|
||||
account.getconfig().set('Repository ' + reposname,
|
||||
'ssl', 'yes')
|
||||
IMAPRepository.__init__(self, reposname, account)
|
||||
|
||||
def gethost(self):
|
||||
return GmailRepository.HOSTNAME
|
||||
"""Return the server name to connect to.
|
||||
|
||||
Gmail implementation first checks for the usual IMAP settings
|
||||
and falls back to imap.gmail.com if not specified."""
|
||||
try:
|
||||
return super(GmailRepository, self).gethost()
|
||||
except OfflineImapError:
|
||||
# nothing was configured, cache and return hardcoded one
|
||||
self._host = GmailRepository.HOSTNAME
|
||||
return self._host
|
||||
|
||||
def getport(self):
|
||||
return GmailRepository.PORT
|
||||
|
Reference in New Issue
Block a user