mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
Issue #16039: CVE-2013-1752: Change use of readline in imaplib module to limit
line length. Patch by Emil Lind.
This commit is contained in:
parent
0840b41582
commit
fd9262cf2a
3 changed files with 27 additions and 1 deletions
|
@ -42,6 +42,15 @@ IMAP4_PORT = 143
|
|||
IMAP4_SSL_PORT = 993
|
||||
AllowedVersions = ('IMAP4REV1', 'IMAP4') # Most recent first
|
||||
|
||||
# Maximal line length when calling readline(). This is to prevent
|
||||
# reading arbitrary length lines. RFC 3501 and 2060 (IMAP 4rev1)
|
||||
# don't specify a line length. RFC 2683 however suggests limiting client
|
||||
# command lines to 1000 octets and server command lines to 8000 octets.
|
||||
# We have selected 10000 for some extra margin and since that is supposedly
|
||||
# also what UW and Panda IMAP does.
|
||||
_MAXLINE = 10000
|
||||
|
||||
|
||||
# Commands
|
||||
|
||||
Commands = {
|
||||
|
@ -263,7 +272,10 @@ class IMAP4:
|
|||
|
||||
def readline(self):
|
||||
"""Read line from remote."""
|
||||
return self.file.readline()
|
||||
line = self.file.readline(_MAXLINE + 1)
|
||||
if len(line) > _MAXLINE:
|
||||
raise self.error("got more than %d bytes" % _MAXLINE)
|
||||
return line
|
||||
|
||||
|
||||
def send(self, data):
|
||||
|
|
|
@ -309,6 +309,17 @@ class BaseThreadedNetworkedTests(unittest.TestCase):
|
|||
self.assertEqual(ret, "OK")
|
||||
|
||||
|
||||
def test_linetoolong(self):
|
||||
class TooLongHandler(SimpleIMAPHandler):
|
||||
def handle(self):
|
||||
# Send a very long response line
|
||||
self.wfile.write(b'* OK ' + imaplib._MAXLINE*b'x' + b'\r\n')
|
||||
|
||||
with self.reaped_server(TooLongHandler) as server:
|
||||
self.assertRaises(imaplib.IMAP4.error,
|
||||
self.imap_class, *server.server_address)
|
||||
|
||||
|
||||
class ThreadedNetworkedTests(BaseThreadedNetworkedTests):
|
||||
|
||||
server_class = socketserver.TCPServer
|
||||
|
|
|
@ -10,6 +10,9 @@ What's New in Python 3.2.6?
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #16039: CVE-2013-1752: Change use of readline in imaplib module to limit
|
||||
line length. Patch by Emil Lind.
|
||||
|
||||
- Issue #22421: Fix a regression that caused the pydoc server to be bound to
|
||||
all interfaces instead of only localhost.
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue