summaryrefslogtreecommitdiffstats
path: root/Lib/imaplib.py
diff options
context:
space:
mode:
authorBill Janssen <janssen@parc.com>2008-02-01 02:16:46 (GMT)
committerBill Janssen <janssen@parc.com>2008-02-01 02:16:46 (GMT)
commita7712090f78d19d0711553d58e403c9fa44474a8 (patch)
tree9f322fa60cabe6d00c05028fa38a5ec44a2b13b4 /Lib/imaplib.py
parentdb0a9b37b66fb45923fc9cd96b41d72f443f34e1 (diff)
downloadcpython-a7712090f78d19d0711553d58e403c9fa44474a8.zip
cpython-a7712090f78d19d0711553d58e403c9fa44474a8.tar.gz
cpython-a7712090f78d19d0711553d58e403c9fa44474a8.tar.bz2
fix bug 1482: IMAP4 SSL isn't working
Diffstat (limited to 'Lib/imaplib.py')
-rw-r--r--Lib/imaplib.py55
1 files changed, 5 insertions, 50 deletions
diff --git a/Lib/imaplib.py b/Lib/imaplib.py
index 6cd1e2f..57046d3 100644
--- a/Lib/imaplib.py
+++ b/Lib/imaplib.py
@@ -1145,55 +1145,10 @@ else:
"""
self.host = host
self.port = port
- self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
- self.sock.connect((host, port))
- self.sslobj = ssl.wrap_socket(self.sock, self.keyfile, self.certfile)
-
-
- def read(self, size):
- """Read 'size' bytes from remote."""
- # sslobj.read() sometimes returns < size bytes
- chunks = []
- read = 0
- while read < size:
- data = self.sslobj.read(size-read)
- read += len(data)
- chunks.append(data)
-
- return ''.join(chunks)
-
-
- def readline(self):
- """Read line from remote."""
- line = []
- while 1:
- char = self.sslobj.read(1)
- line.append(char)
- if char == "\n": return ''.join(line)
-
-
- def send(self, data):
- """Send data to remote."""
- bytes = len(data)
- while bytes > 0:
- sent = self.sslobj.write(data)
- if sent == bytes:
- break # avoid copy
- data = data[sent:]
- bytes = bytes - sent
-
-
- def shutdown(self):
- """Close I/O established in "open"."""
- self.sock.close()
-
-
- def socket(self):
- """Return socket instance used to connect to IMAP4 server.
-
- socket = <instance>.socket()
- """
- return self.sock
+ sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
+ sock.connect((host, port))
+ self.sock = ssl.wrap_socket(sock, self.keyfile, self.certfile)
+ self.file = self.sock.makefile('rb')
def ssl(self):
@@ -1201,7 +1156,7 @@ else:
ssl = ssl.wrap_socket(<instance>.socket)
"""
- return self.sslobj
+ return self.sock
__all__.append("IMAP4_SSL")