aboutsummaryrefslogtreecommitdiffstats
path: root/archivemail
diff options
context:
space:
mode:
authorNikolaus Schulz <microschulz@web.de>2011-07-09 17:47:06 +0200
committerNikolaus Schulz <microschulz@web.de>2011-07-09 18:03:12 +0200
commiteb07611faeaa3b0d6f1dad5852ccab231d3f1c24 (patch)
treebd64e663feae35695a8d3cc5b7cb059d598a3ffb /archivemail
parentf9f9eacd888565660e44ee5119124614dd442e03 (diff)
downloadarchivemail-eb07611faeaa3b0d6f1dad5852ccab231d3f1c24.tar.gz
archivemail-eb07611faeaa3b0d6f1dad5852ccab231d3f1c24.tar.bz2
archivemail-eb07611faeaa3b0d6f1dad5852ccab231d3f1c24.zip
IMAP: support servers listening on non-standard ports
Diffstat (limited to 'archivemail')
-rwxr-xr-xarchivemail28
1 files changed, 20 insertions, 8 deletions
diff --git a/archivemail b/archivemail
index 8c0e2c9..7426c59 100755
--- a/archivemail
+++ b/archivemail
@@ -1290,9 +1290,9 @@ def _archive_imap(mailbox_name):
vprint("Setting imaplib.Debug = %d" % options.debug_imap)
imaplib.Debug = options.debug_imap
archive = None
- imap_str = mailbox_name[mailbox_name.find('://') + 3:]
- imap_username, imap_password, imap_server, imap_folder_pattern = \
- parse_imap_url(imap_str)
+ imap_username, imap_password, \
+ imap_server, imap_server_port, \
+ imap_folder_pattern = parse_imap_url(mailbox_name)
if not imap_password:
if options.pwfile:
imap_password = open(options.pwfile).read().rstrip()
@@ -1303,11 +1303,13 @@ def _archive_imap(mailbox_name):
is_ssl = mailbox_name[:5].lower() == 'imaps'
if is_ssl:
- vprint("establishing secure connection to server %s" % imap_server)
- imap_srv = imaplib.IMAP4_SSL(imap_server)
+ vprint("establishing secure connection to server %s, port %s" %
+ (imap_server, imap_server_port))
+ imap_srv = imaplib.IMAP4_SSL(imap_server, imap_server_port)
else:
- vprint("establishing connection to server %s" % imap_server)
- imap_srv = imaplib.IMAP4(imap_server)
+ vprint("establishing connection to server %s, port %s" %
+ (imap_server, imap_server_port))
+ imap_srv = imaplib.IMAP4(imap_server, imap_server_port)
if "AUTH=CRAM-MD5" in imap_srv.capabilities:
vprint("authenticating (cram-md5) to server as %s" % imap_username)
result, response = imap_srv.login_cram_md5(imap_username, imap_password)
@@ -1551,6 +1553,7 @@ def parse_imap_url(url):
a, b = string.split(delim, 1)
return a, b
+ scheme, url = url.split('://')
password = None
try:
if options.pwfile:
@@ -1566,7 +1569,16 @@ def parse_imap_url(url):
server, folder = url.split('/', 1)
except ValueError:
unexpected_error("Invalid IMAP connection string")
- return username, password, server, folder
+ try:
+ server, port = server.split(':')
+ except ValueError:
+ if scheme.lower() == 'imap':
+ port = 143
+ else:
+ port = 993
+ else:
+ port = int(port)
+ return username, password, server, port, folder
def imap_getdelim(imap_server):