diff options
| author | Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> | 2020-08-15 17:42:36 (GMT) |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-08-15 17:42:36 (GMT) |
| commit | 243458115e2cb295fb5bbb61e6ac528c6b2cf5be (patch) | |
| tree | 635e6628caea30640fa4d4350eac577c74b3f56d /Modules | |
| parent | 0a5b30d98913e84f80ecea2b861e96d8f67c89e9 (diff) | |
| download | cpython-243458115e2cb295fb5bbb61e6ac528c6b2cf5be.zip cpython-243458115e2cb295fb5bbb61e6ac528c6b2cf5be.tar.gz cpython-243458115e2cb295fb5bbb61e6ac528c6b2cf5be.tar.bz2 | |
bpo-31122: ssl.wrap_socket() now raises ssl.SSLEOFError rather than OSError when peer closes connection during TLS negotiation (GH-18772)
[bpo-31122](): ssl.wrap_socket() now raises ssl.SSLEOFError rather than OSError when peer closes connection during TLS negotiation
Reproducer: http://tiny.cc/f4ztnz (tiny url because some bot keeps renaming b.p.o.-nnn as bpo links)
(cherry picked from commit 495bd035662fda29639f9d52bb6baebea31d72fa)
Co-authored-by: Dima Tisnek <dimaqq@gmail.com>
Diffstat (limited to 'Modules')
| -rw-r--r-- | Modules/_ssl.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/Modules/_ssl.c b/Modules/_ssl.c index 1944393..e6dda29 100644 --- a/Modules/_ssl.c +++ b/Modules/_ssl.c @@ -807,10 +807,11 @@ PySSL_SetError(PySSLSocket *sslsock, int ret, const char *filename, int lineno) errno = err.c; return PyErr_SetFromErrno(PyExc_OSError); } - Py_INCREF(s); - s->errorhandler(); - Py_DECREF(s); - return NULL; + else { + p = PY_SSL_ERROR_EOF; + type = PySSLEOFErrorObject; + errstr = "EOF occurred in violation of protocol"; + } } else { /* possible? */ p = PY_SSL_ERROR_SYSCALL; type = PySSLSyscallErrorObject; |
