summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-06-24 22:42:31 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2013-06-24 22:42:31 (GMT)
commit6efa965a27696ae0acf1c914ca71b545a53be01c (patch)
treea65180f88e89778a17ad59969106083edf2a9bc4
parent51cee7d24a8927a91f8c005590583346161798b8 (diff)
downloadcpython-6efa965a27696ae0acf1c914ca71b545a53be01c.zip
cpython-6efa965a27696ae0acf1c914ca71b545a53be01c.tar.gz
cpython-6efa965a27696ae0acf1c914ca71b545a53be01c.tar.bz2
Issue #18135: ssl.SSLSocket.write() now raises an OverflowError if the input
string in longer than 2 gigabytes, and ssl.SSLContext.load_cert_chain() raises a ValueError if the password is longer than 2 gigabytes. The ssl module does not support partial write.
-rw-r--r--Misc/NEWS7
-rw-r--r--Modules/_ssl.c9
2 files changed, 11 insertions, 5 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index f5a35bc..7e65773 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -38,9 +38,10 @@ Core and Builtins
Library
-------
-- Issue #18135: Fix a possible integer overflow in ssl.SSLSocket.write()
- and in ssl.SSLContext.load_cert_chain() for strings and passwords longer than
- 2 gigabytes.
+- Issue #18135: ssl.SSLSocket.write() now raises an OverflowError if the input
+ string in longer than 2 gigabytes, and ssl.SSLContext.load_cert_chain()
+ raises a ValueError if the password is longer than 2 gigabytes. The ssl
+ module does not support partial write.
- Issue #18248: Fix libffi build on AIX.
diff --git a/Modules/_ssl.c b/Modules/_ssl.c
index ebd84d5..434729f 100644
--- a/Modules/_ssl.c
+++ b/Modules/_ssl.c
@@ -1264,6 +1264,12 @@ static PyObject *PySSL_SSLwrite(PySSLSocket *self, PyObject *args)
return NULL;
}
+ if (buf.len > INT_MAX) {
+ PyErr_Format(PyExc_OverflowError,
+ "string longer than %d bytes", INT_MAX);
+ goto error;
+ }
+
/* just in case the blocking state of the socket has been changed */
nonblocking = (sock->sock_timeout >= 0.0);
BIO_set_nbio(SSL_get_rbio(self->ssl), nonblocking);
@@ -1284,9 +1290,8 @@ static PyObject *PySSL_SSLwrite(PySSLSocket *self, PyObject *args)
goto error;
}
do {
- len = (int)Py_MIN(buf.len, INT_MAX);
PySSL_BEGIN_ALLOW_THREADS
- len = SSL_write(self->ssl, buf.buf, len);
+ len = SSL_write(self->ssl, buf.buf, (int)buf.len);
err = SSL_get_error(self->ssl, len);
PySSL_END_ALLOW_THREADS
if (PyErr_CheckSignals()) {