Commit 93b07c09 authored by Paul Gofman's avatar Paul Gofman Committed by Alexandre Julliard

winhttp: Handle TLS close notify in netconn_is_alive().

parent 2bbb725b
...@@ -616,11 +616,31 @@ DWORD netconn_set_timeout( struct netconn *netconn, BOOL send, int value ) ...@@ -616,11 +616,31 @@ DWORD netconn_set_timeout( struct netconn *netconn, BOOL send, int value )
BOOL netconn_is_alive( struct netconn *netconn ) BOOL netconn_is_alive( struct netconn *netconn )
{ {
SIZE_T size;
int len; int len;
char b; char b;
DWORD err; DWORD err;
BOOL eof;
set_blocking( netconn, FALSE ); set_blocking( netconn, FALSE );
if (netconn->secure)
{
while (!netconn->peek_msg && !(err = read_ssl_chunk( netconn, NULL, 0, &size, &eof )) && !eof)
;
TRACE("Checking secure connection, err %d.\n", err);
if (netconn->peek_msg || err == WSAEWOULDBLOCK)
{
set_blocking( netconn, TRUE );
return TRUE;
}
if (err != SEC_E_OK && err != SEC_E_INCOMPLETE_MESSAGE)
{
set_blocking( netconn, TRUE );
return FALSE;
}
}
len = sock_recv( netconn->socket, &b, 1, MSG_PEEK ); len = sock_recv( netconn->socket, &b, 1, MSG_PEEK );
err = WSAGetLastError(); err = WSAGetLastError();
set_blocking( netconn, TRUE ); set_blocking( netconn, TRUE );
......
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