cpython: 5d1c03316af7 (original) (raw)

Mercurial > cpython

changeset 92669:5d1c03316af7 3.2

Issue #16039: CVE-2013-1752: Change use of readline in imaplib module to limit line length. Patch by Emil Lind. [#16039]

Georg Brandl georg@python.org
date Tue, 30 Sep 2014 16:00:09 +0200
parents 02dae04b3e2b
children 97c329849ef3
files Lib/imaplib.py Lib/test/test_imaplib.py Misc/NEWS
diffstat 3 files changed, 27 insertions(+), 1 deletions(-)[+] [-] Lib/imaplib.py 14 Lib/test/test_imaplib.py 11 Misc/NEWS 3

line wrap: on

line diff

--- a/Lib/imaplib.py +++ b/Lib/imaplib.py @@ -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."""

def send(self, data):

--- a/Lib/test/test_imaplib.py +++ b/Lib/test/test_imaplib.py @@ -309,6 +309,17 @@ class BaseThreadedNetworkedTests(unittes self.assertEqual(ret, "OK")

+

+ + class ThreadedNetworkedTests(BaseThreadedNetworkedTests): server_class = socketserver.TCPServer

--- a/Misc/NEWS +++ b/Misc/NEWS @@ -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