Kaydet (Commit) 2e57b4e4 authored tarafından Victor Stinner's avatar Victor Stinner

Issue #21781: Make the ssl module "ssize_t clean" for parsing parameters.

ssl.RAND_add() now supports strings longer than 2 GB.
üst 1690ed39
......@@ -27,6 +27,8 @@ Core and Builtins
Library
-------
- Issue #21781: ssl.RAND_add() now supports strings longer than 2 GB.
- Issue #11453: asyncore: emit a ResourceWarning when an unclosed file_wrapper
object is destroyed. The destructor now closes the file if needed. The
close() method can now be called twice: the second call does nothing.
......
......@@ -14,6 +14,8 @@
http://bugs.python.org/issue8108#msg102867 ?
*/
#define PY_SSIZE_T_CLEAN
#include "Python.h"
#ifdef WITH_THREAD
......@@ -3235,12 +3237,17 @@ static PyObject *
PySSL_RAND_add(PyObject *self, PyObject *args)
{
char *buf;
int len;
Py_ssize_t len, written;
double entropy;
if (!PyArg_ParseTuple(args, "s#d:RAND_add", &buf, &len, &entropy))
return NULL;
RAND_add(buf, len, entropy);
do {
written = Py_MIN(len, INT_MAX);
RAND_add(buf, (int)written, entropy);
buf += written;
len -= written;
} while (len);
Py_INCREF(Py_None);
return Py_None;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment