Reverting revision 59394. We'll sort this out later.
This commit is contained in:
parent
03b5c9ae75
commit
e6650f91ea
|
@ -148,10 +148,6 @@ class SSLSocket(socket):
|
||||||
self.do_handshake_on_connect = do_handshake_on_connect
|
self.do_handshake_on_connect = do_handshake_on_connect
|
||||||
self.suppress_ragged_eofs = suppress_ragged_eofs
|
self.suppress_ragged_eofs = suppress_ragged_eofs
|
||||||
|
|
||||||
# See Modules/_ssl.c:PySSL_dealloc()
|
|
||||||
# def __del__(self):
|
|
||||||
# self._real_close()
|
|
||||||
|
|
||||||
def dup(self):
|
def dup(self):
|
||||||
raise NotImplemented("Can't dup() %s instances" %
|
raise NotImplemented("Can't dup() %s instances" %
|
||||||
self.__class__.__name__)
|
self.__class__.__name__)
|
||||||
|
@ -304,7 +300,6 @@ class SSLSocket(socket):
|
||||||
socket.shutdown(self, how)
|
socket.shutdown(self, how)
|
||||||
|
|
||||||
def _real_close(self):
|
def _real_close(self):
|
||||||
# real close is called by Modules/_ssl.c:PySSL_dealloc()
|
|
||||||
self._sslobj = None
|
self._sslobj = None
|
||||||
# self._closed = True
|
# self._closed = True
|
||||||
if self._base:
|
if self._base:
|
||||||
|
@ -353,6 +348,10 @@ class SSLSocket(socket):
|
||||||
self.do_handshake_on_connect),
|
self.do_handshake_on_connect),
|
||||||
addr)
|
addr)
|
||||||
|
|
||||||
|
|
||||||
|
def __del__(self):
|
||||||
|
self._real_close()
|
||||||
|
|
||||||
def wrap_socket(sock, keyfile=None, certfile=None,
|
def wrap_socket(sock, keyfile=None, certfile=None,
|
||||||
server_side=False, cert_reqs=CERT_NONE,
|
server_side=False, cert_reqs=CERT_NONE,
|
||||||
ssl_version=PROTOCOL_SSLv23, ca_certs=None,
|
ssl_version=PROTOCOL_SSLv23, ca_certs=None,
|
||||||
|
|
|
@ -266,7 +266,7 @@ newPySSLObject(PySocketSockObject *Sock, char *key_file, char *cert_file,
|
||||||
int ret;
|
int ret;
|
||||||
int verification_mode;
|
int verification_mode;
|
||||||
|
|
||||||
self = PyObject_GC_New(PySSLObject, &PySSL_Type); /* Create new object */
|
self = PyObject_New(PySSLObject, &PySSL_Type); /* Create new object */
|
||||||
if (self == NULL)
|
if (self == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
self->peer_cert = NULL;
|
self->peer_cert = NULL;
|
||||||
|
@ -385,7 +385,6 @@ newPySSLObject(PySocketSockObject *Sock, char *key_file, char *cert_file,
|
||||||
|
|
||||||
self->Socket = Sock;
|
self->Socket = Sock;
|
||||||
Py_INCREF(self->Socket);
|
Py_INCREF(self->Socket);
|
||||||
_PyObject_GC_TRACK(self);
|
|
||||||
return self;
|
return self;
|
||||||
fail:
|
fail:
|
||||||
if (errstr)
|
if (errstr)
|
||||||
|
@ -1051,41 +1050,16 @@ static PyObject *PySSL_cipher (PySSLObject *self) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* GC support. */
|
static void PySSL_dealloc(PySSLObject *self)
|
||||||
static int
|
|
||||||
PySSL_traverse(PySSLObject *self, visitproc visit, void *arg)
|
|
||||||
{
|
{
|
||||||
Py_VISIT(self->Socket);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
PySSL_clear(PySSLObject *self)
|
|
||||||
{
|
|
||||||
Py_CLEAR(self->Socket);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
PySSL_dealloc(PySSLObject *self)
|
|
||||||
{
|
|
||||||
PyObject *o;
|
|
||||||
PyObject *exc_type, *exc_value, *exc_tb;
|
|
||||||
|
|
||||||
PyErr_Fetch(&exc_type, &exc_value, &exc_tb);
|
|
||||||
o = PyObject_CallMethod((PyObject*)self, "_real_close", NULL);
|
|
||||||
Py_XDECREF(o);
|
|
||||||
PyErr_Restore(exc_type, exc_value, exc_tb);
|
|
||||||
|
|
||||||
PyObject_GC_UnTrack(self);
|
|
||||||
if (self->peer_cert) /* Possible not to have one? */
|
if (self->peer_cert) /* Possible not to have one? */
|
||||||
X509_free(self->peer_cert);
|
X509_free (self->peer_cert);
|
||||||
if (self->ssl)
|
if (self->ssl)
|
||||||
SSL_free(self->ssl);
|
SSL_free(self->ssl);
|
||||||
if (self->ctx)
|
if (self->ctx)
|
||||||
SSL_CTX_free(self->ctx);
|
SSL_CTX_free(self->ctx);
|
||||||
Py_CLEAR(self->Socket);
|
Py_XDECREF(self->Socket);
|
||||||
Py_Type(self)->tp_free((PyObject *)self);
|
PyObject_Del(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If the socket has a timeout, do a select()/poll() on the socket.
|
/* If the socket has a timeout, do a select()/poll() on the socket.
|
||||||
|
@ -1385,15 +1359,20 @@ static PyMethodDef PySSLMethods[] = {
|
||||||
{NULL, NULL}
|
{NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static PyObject *PySSL_getattr(PySSLObject *self, char *name)
|
||||||
|
{
|
||||||
|
return Py_FindMethod(PySSLMethods, (PyObject *)self, name);
|
||||||
|
}
|
||||||
|
|
||||||
static PyTypeObject PySSL_Type = {
|
static PyTypeObject PySSL_Type = {
|
||||||
PyVarObject_HEAD_INIT(NULL, 0)
|
PyVarObject_HEAD_INIT(NULL, 0)
|
||||||
"_ssl.SSLContext", /*tp_name*/
|
"ssl.SSLContext", /*tp_name*/
|
||||||
sizeof(PySSLObject), /*tp_basicsize*/
|
sizeof(PySSLObject), /*tp_basicsize*/
|
||||||
0, /*tp_itemsize*/
|
0, /*tp_itemsize*/
|
||||||
/* methods */
|
/* methods */
|
||||||
(destructor)PySSL_dealloc, /*tp_dealloc*/
|
(destructor)PySSL_dealloc, /*tp_dealloc*/
|
||||||
0, /*tp_print*/
|
0, /*tp_print*/
|
||||||
0, /*tp_getattr*/
|
(getattrfunc)PySSL_getattr, /*tp_getattr*/
|
||||||
0, /*tp_setattr*/
|
0, /*tp_setattr*/
|
||||||
0, /*tp_compare*/
|
0, /*tp_compare*/
|
||||||
0, /*tp_repr*/
|
0, /*tp_repr*/
|
||||||
|
@ -1401,32 +1380,6 @@ static PyTypeObject PySSL_Type = {
|
||||||
0, /*tp_as_sequence*/
|
0, /*tp_as_sequence*/
|
||||||
0, /*tp_as_mapping*/
|
0, /*tp_as_mapping*/
|
||||||
0, /*tp_hash*/
|
0, /*tp_hash*/
|
||||||
0, /* tp_call */
|
|
||||||
0, /* tp_str */
|
|
||||||
PyObject_GenericGetAttr, /* tp_getattro */
|
|
||||||
0, /* tp_setattro */
|
|
||||||
0, /* tp_as_buffer */
|
|
||||||
Py_TPFLAGS_DEFAULT |
|
|
||||||
Py_TPFLAGS_HAVE_GC, /* tp_flags */
|
|
||||||
0, /* tp_doc */
|
|
||||||
(traverseproc)PySSL_traverse, /* tp_traverse */
|
|
||||||
(inquiry)PySSL_clear, /* tp_clear */
|
|
||||||
0, /* tp_richcompare */
|
|
||||||
0, /* tp_weaklistoffset */
|
|
||||||
0, /* tp_iter */
|
|
||||||
0, /* tp_iternext */
|
|
||||||
PySSLMethods, /* tp_methods */
|
|
||||||
0, /* tp_members */
|
|
||||||
0, /* tp_getset */
|
|
||||||
0, /* tp_base */
|
|
||||||
0, /* tp_dict */
|
|
||||||
0, /* tp_descr_get */
|
|
||||||
0, /* tp_descr_set */
|
|
||||||
0, /* tp_dictoffset */
|
|
||||||
0, /* tp_init */
|
|
||||||
PyType_GenericAlloc, /* tp_alloc */
|
|
||||||
PyType_GenericNew, /* tp_new */
|
|
||||||
PyObject_GC_Del, /* tp_free */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef HAVE_OPENSSL_RAND
|
#ifdef HAVE_OPENSSL_RAND
|
||||||
|
|
Loading…
Reference in New Issue