mirror of
https://github.com/python/cpython.git
synced 2025-12-31 04:23:37 +00:00
[3.11] gh-127257: ssl: Raise OSError for ERR_LIB_SYS (GH-127361) (GH-127905) (GH-131970)
gh-127257: ssl: Raise OSError for ERR_LIB_SYS (GH-127361)
From the ERR_raise manpage:
ERR_LIB_SYS
This "library code" indicates that a system error is
being reported. In this case, the reason code given
to `ERR_raise()` and `ERR_raise_data()` *must* be
`errno(3)`.
This PR only handles ERR_LIB_SYS for the high-lever error types
SSL_ERROR_SYSCALL and SSL_ERROR_SSL, i.e., not the ones where
OpenSSL indicates it has some more information about the issue.
(cherry picked from commit f4b31edf2d)
(cherry picked from commit 7f707fa6c6)
Co-authored-by: Petr Viktorin <encukou@gmail.com>
This commit is contained in:
parent
f576d31d1c
commit
4588712773
2 changed files with 12 additions and 0 deletions
|
|
@ -0,0 +1,2 @@
|
|||
In :mod:`ssl`, system call failures that OpenSSL reports using
|
||||
``ERR_LIB_SYS`` are now raised as :exc:`OSError`.
|
||||
|
|
@ -654,6 +654,11 @@ PySSL_SetError(PySSLSocket *sslsock, int ret, const char *filename, int lineno)
|
|||
ERR_GET_REASON(e) == SSL_R_CERTIFICATE_VERIFY_FAILED) {
|
||||
type = state->PySSLCertVerificationErrorObject;
|
||||
}
|
||||
if (ERR_GET_LIB(e) == ERR_LIB_SYS) {
|
||||
// A system error is being reported; reason is set to errno
|
||||
errno = ERR_GET_REASON(e);
|
||||
return PyErr_SetFromErrno(PyExc_OSError);
|
||||
}
|
||||
p = PY_SSL_ERROR_SYSCALL;
|
||||
}
|
||||
break;
|
||||
|
|
@ -679,6 +684,11 @@ PySSL_SetError(PySSLSocket *sslsock, int ret, const char *filename, int lineno)
|
|||
errstr = "EOF occurred in violation of protocol";
|
||||
}
|
||||
#endif
|
||||
if (ERR_GET_LIB(e) == ERR_LIB_SYS) {
|
||||
// A system error is being reported; reason is set to errno
|
||||
errno = ERR_GET_REASON(e);
|
||||
return PyErr_SetFromErrno(PyExc_OSError);
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue