Commit 1fb0e25c authored by Hans Leidekker's avatar Hans Leidekker Committed by Alexandre Julliard

webservices: Pass AI_PASSIVE when resolving the hostname for a listener socket.

parent b4587998
...@@ -637,7 +637,7 @@ static HRESULT connect_channel_tcp( struct channel *channel ) ...@@ -637,7 +637,7 @@ static HRESULT connect_channel_tcp( struct channel *channel )
winsock_init(); winsock_init();
hr = resolve_hostname( host, port, addr, &addr_len ); hr = resolve_hostname( host, port, addr, &addr_len, 0 );
heap_free( host ); heap_free( host );
if (hr != S_OK) return hr; if (hr != S_OK) return hr;
...@@ -675,7 +675,7 @@ static HRESULT connect_channel_udp( struct channel *channel ) ...@@ -675,7 +675,7 @@ static HRESULT connect_channel_udp( struct channel *channel )
winsock_init(); winsock_init();
hr = resolve_hostname( host, port, addr, &addr_len ); hr = resolve_hostname( host, port, addr, &addr_len, 0 );
heap_free( host ); heap_free( host );
if (hr != S_OK) return hr; if (hr != S_OK) return hr;
......
...@@ -256,16 +256,20 @@ void WINAPI WsFreeListener( WS_LISTENER *handle ) ...@@ -256,16 +256,20 @@ void WINAPI WsFreeListener( WS_LISTENER *handle )
free_listener( listener ); free_listener( listener );
} }
HRESULT resolve_hostname( const WCHAR *host, USHORT port, struct sockaddr *addr, int *addr_len ) HRESULT resolve_hostname( const WCHAR *host, USHORT port, struct sockaddr *addr, int *addr_len, int flags )
{ {
static const WCHAR fmtW[] = {'%','u',0}; static const WCHAR fmtW[] = {'%','u',0};
WCHAR service[6]; WCHAR service[6];
ADDRINFOW *res, *info; ADDRINFOW hints, *res, *info;
HRESULT hr = WS_E_ADDRESS_NOT_AVAILABLE; HRESULT hr = WS_E_ADDRESS_NOT_AVAILABLE;
memset( &hints, 0, sizeof(hints) );
hints.ai_flags = flags;
hints.ai_family = AF_INET;
*addr_len = 0; *addr_len = 0;
sprintfW( service, fmtW, port ); sprintfW( service, fmtW, port );
if (GetAddrInfoW( host, service, NULL, &res )) return HRESULT_FROM_WIN32( WSAGetLastError() ); if (GetAddrInfoW( host, service, &hints, &res )) return HRESULT_FROM_WIN32( WSAGetLastError() );
info = res; info = res;
while (info && info->ai_family != AF_INET) info = info->ai_next; while (info && info->ai_family != AF_INET) info = info->ai_next;
...@@ -330,7 +334,7 @@ static HRESULT open_listener_tcp( struct listener *listener, const WS_STRING *ur ...@@ -330,7 +334,7 @@ static HRESULT open_listener_tcp( struct listener *listener, const WS_STRING *ur
winsock_init(); winsock_init();
hr = resolve_hostname( host, port, addr, &addr_len ); hr = resolve_hostname( host, port, addr, &addr_len, AI_PASSIVE );
heap_free( host ); heap_free( host );
if (hr != S_OK) return hr; if (hr != S_OK) return hr;
...@@ -381,7 +385,7 @@ static HRESULT open_listener_udp( struct listener *listener, const WS_STRING *ur ...@@ -381,7 +385,7 @@ static HRESULT open_listener_udp( struct listener *listener, const WS_STRING *ur
winsock_init(); winsock_init();
hr = resolve_hostname( host, port, addr, &addr_len ); hr = resolve_hostname( host, port, addr, &addr_len, AI_PASSIVE );
heap_free( host ); heap_free( host );
if (hr != S_OK) return hr; if (hr != S_OK) return hr;
......
...@@ -19,6 +19,6 @@ ...@@ -19,6 +19,6 @@
#include "ws2tcpip.h" #include "ws2tcpip.h"
void winsock_init(void) DECLSPEC_HIDDEN; void winsock_init(void) DECLSPEC_HIDDEN;
HRESULT resolve_hostname( const WCHAR *, USHORT, struct sockaddr *, int * ) DECLSPEC_HIDDEN; HRESULT resolve_hostname( const WCHAR *, USHORT, struct sockaddr *, int *, int ) DECLSPEC_HIDDEN;
HRESULT channel_accept_tcp( SOCKET, HANDLE, HANDLE, WS_CHANNEL * ) DECLSPEC_HIDDEN; HRESULT channel_accept_tcp( SOCKET, HANDLE, HANDLE, WS_CHANNEL * ) DECLSPEC_HIDDEN;
HRESULT channel_accept_udp( SOCKET, HANDLE, HANDLE, WS_CHANNEL * ) DECLSPEC_HIDDEN; HRESULT channel_accept_udp( SOCKET, HANDLE, HANDLE, WS_CHANNEL * ) DECLSPEC_HIDDEN;
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