summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2015-05-23 15:40:47 (GMT)
committerBenjamin Peterson <benjamin@python.org>2015-05-23 15:40:47 (GMT)
commitc4ae86e47730a4466a8d6ebae4c5531bf1dfca3b (patch)
tree4c5858a4ef5af5a5e9070ce3b0127c7f6e92e98e
parent7bf0d5a759fb60170f305e0a4f3a5ad9c0882e67 (diff)
parentd504f20e1c30d7ee328e897e1bb93cba3d1db7a2 (diff)
downloadcpython-c4ae86e47730a4466a8d6ebae4c5531bf1dfca3b.zip
cpython-c4ae86e47730a4466a8d6ebae4c5531bf1dfca3b.tar.gz
cpython-c4ae86e47730a4466a8d6ebae4c5531bf1dfca3b.tar.bz2
merge 3.3 (#22931)
-rw-r--r--Lib/http/cookies.py7
-rw-r--r--Lib/test/test_http_cookies.py13
-rw-r--r--Misc/NEWS2
3 files changed, 19 insertions, 3 deletions
diff --git a/Lib/http/cookies.py b/Lib/http/cookies.py
index 3e1abd7..482e601 100644
--- a/Lib/http/cookies.py
+++ b/Lib/http/cookies.py
@@ -428,12 +428,13 @@ class Morsel(dict):
# result, the parsing rules here are less strict.
#
-_LegalCharsPatt = r"[\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\=]"
+_LegalKeyChars = r"\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\="
+_LegalValueChars = _LegalKeyChars + '\[\]'
_CookiePattern = re.compile(r"""
(?x) # This is a verbose pattern
\s* # Optional whitespace at start of cookie
(?P<key> # Start of group 'key'
- """ + _LegalCharsPatt + r"""+? # Any word of at least one letter
+ [""" + _LegalKeyChars + r"""]+? # Any word of at least one letter
) # End of group 'key'
( # Optional group: there may not be a value.
\s*=\s* # Equal Sign
@@ -442,7 +443,7 @@ _CookiePattern = re.compile(r"""
| # or
\w{3},\s[\w\d\s-]{9,11}\s[\d:]{8}\sGMT # Special case for "expires" attr
| # or
- """ + _LegalCharsPatt + r"""* # Any word or empty string
+ [""" + _LegalValueChars + r"""]* # Any word or empty string
) # End of group 'val'
)? # End of optional value group
\s* # Any number of spaces.
diff --git a/Lib/test/test_http_cookies.py b/Lib/test/test_http_cookies.py
index e984252..c7b680b 100644
--- a/Lib/test/test_http_cookies.py
+++ b/Lib/test/test_http_cookies.py
@@ -43,6 +43,19 @@ class CookieTests(unittest.TestCase):
'repr': "<SimpleCookie: key:term='value:term'>",
'output': 'Set-Cookie: key:term=value:term'},
+ # issue22931 - Adding '[' and ']' as valid characters in cookie
+ # values as defined in RFC 6265
+ {
+ 'data': 'a=b; c=[; d=r; f=h',
+ 'dict': {'a':'b', 'c':'[', 'd':'r', 'f':'h'},
+ 'repr': "<SimpleCookie: a='b' c='[' d='r' f='h'>",
+ 'output': '\n'.join((
+ 'Set-Cookie: a=b',
+ 'Set-Cookie: c=[',
+ 'Set-Cookie: d=r',
+ 'Set-Cookie: f=h'
+ ))
+ }
]
for case in cases:
diff --git a/Misc/NEWS b/Misc/NEWS
index 6b491d0..7d2176f 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -80,6 +80,8 @@ Library
- Issue #23796: peek and read1 methods of BufferedReader now raise ValueError
if they called on a closed object. Patch by John Hergenroeder.
+- Issue #22931: Allow '[' and ']' in cookie values.
+
- Issue #24094: Fix possible crash in json.encode with poorly behaved dict
subclasses.