Commit 17e2d5c1 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

dnsapi: Add support for DnsConfigSearchList.

This doesn't appear to be implemented on Windows, however it will be needed by iphlpapi.dll. Signed-off-by: 's avatarHuw Davies <huw@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent f705f583
...@@ -121,12 +121,14 @@ static inline char *strdup_ua( const char *src ) ...@@ -121,12 +121,14 @@ static inline char *strdup_ua( const char *src )
extern const char *type_to_str( unsigned short ) DECLSPEC_HIDDEN; extern const char *type_to_str( unsigned short ) DECLSPEC_HIDDEN;
extern DNS_STATUS CDECL resolv_get_searchlist( DNS_TXT_DATAW *, DWORD * ) DECLSPEC_HIDDEN;
extern DNS_STATUS CDECL resolv_get_serverlist( USHORT, DNS_ADDR_ARRAY *, DWORD * ) DECLSPEC_HIDDEN; extern DNS_STATUS CDECL resolv_get_serverlist( USHORT, DNS_ADDR_ARRAY *, DWORD * ) DECLSPEC_HIDDEN;
extern DNS_STATUS CDECL resolv_query( const char *, WORD, DWORD, DNS_RECORDA ** ) DECLSPEC_HIDDEN; extern DNS_STATUS CDECL resolv_query( const char *, WORD, DWORD, DNS_RECORDA ** ) DECLSPEC_HIDDEN;
extern DNS_STATUS CDECL resolv_set_serverlist( const IP4_ARRAY * ) DECLSPEC_HIDDEN; extern DNS_STATUS CDECL resolv_set_serverlist( const IP4_ARRAY * ) DECLSPEC_HIDDEN;
struct resolv_funcs struct resolv_funcs
{ {
DNS_STATUS (CDECL *get_searchlist)( DNS_TXT_DATAW *list, DWORD *len );
DNS_STATUS (CDECL *get_serverlist)( USHORT family, DNS_ADDR_ARRAY *addrs, DWORD *len ); DNS_STATUS (CDECL *get_serverlist)( USHORT family, DNS_ADDR_ARRAY *addrs, DWORD *len );
DNS_STATUS (CDECL *query)( const char *name, WORD type, DWORD options, DNS_RECORDA **result ); DNS_STATUS (CDECL *query)( const char *name, WORD type, DWORD options, DNS_RECORDA **result );
DNS_STATUS (CDECL *set_serverlist)( const IP4_ARRAY *addrs ); DNS_STATUS (CDECL *set_serverlist)( const IP4_ARRAY *addrs );
......
...@@ -61,6 +61,54 @@ ...@@ -61,6 +61,54 @@
WINE_DEFAULT_DEBUG_CHANNEL(dnsapi); WINE_DEFAULT_DEBUG_CHANNEL(dnsapi);
static CPTABLEINFO unix_cptable;
static ULONG unix_cp = CP_UTF8;
static DWORD WINAPI get_unix_codepage_once( RTL_RUN_ONCE *once, void *param, void **context )
{
static const WCHAR wineunixcpW[] = { 'W','I','N','E','U','N','I','X','C','P',0 };
UNICODE_STRING name, value;
WCHAR value_buffer[13];
SIZE_T size;
void *ptr;
RtlInitUnicodeString( &name, wineunixcpW );
value.Buffer = value_buffer;
value.MaximumLength = sizeof(value_buffer);
if (!RtlQueryEnvironmentVariable_U( NULL, &name, &value ))
RtlUnicodeStringToInteger( &value, 10, &unix_cp );
if (unix_cp != CP_UTF8 && !NtGetNlsSectionPtr( 11, unix_cp, NULL, &ptr, &size ))
RtlInitCodePageTable( ptr, &unix_cptable );
return TRUE;
}
static BOOL get_unix_codepage( void )
{
static RTL_RUN_ONCE once = RTL_RUN_ONCE_INIT;
return !RtlRunOnceExecuteOnce( &once, get_unix_codepage_once, NULL, NULL );
}
static DWORD dnsapi_umbstowcs( const char *src, WCHAR *dst, DWORD dstlen )
{
DWORD srclen = strlen( src ) + 1;
DWORD len;
get_unix_codepage();
if (unix_cp == CP_UTF8)
{
RtlUTF8ToUnicodeN( dst, dstlen, &len, src, srclen );
return len;
}
else
{
len = srclen * sizeof(WCHAR);
if (dst) RtlCustomCPToUnicodeN( &unix_cptable, dst, dstlen, &len, src, srclen );
return len;
}
}
static const char *debugstr_type( unsigned short type ) static const char *debugstr_type( unsigned short type )
{ {
const char *str; const char *str;
...@@ -229,6 +277,38 @@ static DNS_STATUS map_h_errno( int error ) ...@@ -229,6 +277,38 @@ static DNS_STATUS map_h_errno( int error )
} }
} }
DNS_STATUS CDECL resolv_get_searchlist( DNS_TXT_DATAW *list, DWORD *len )
{
DWORD i, needed, str_needed = 0;
char *ptr, *end;
init_resolver();
for (i = 0; i < MAXDNSRCH + 1 && _res.dnsrch[i]; i++)
str_needed += dnsapi_umbstowcs( _res.dnsrch[i], NULL, 0 );
needed = FIELD_OFFSET(DNS_TXT_DATAW, pStringArray[i]) + str_needed;
if (!list || *len < needed)
{
*len = needed;
return !list ? ERROR_SUCCESS : ERROR_MORE_DATA;
}
*len = needed;
list->dwStringCount = i;
ptr = (char *)(list->pStringArray + i);
end = ptr + str_needed;
for (i = 0; i < MAXDNSRCH + 1 && _res.dnsrch[i]; i++)
{
list->pStringArray[i] = (WCHAR *)ptr;
ptr += dnsapi_umbstowcs( _res.dnsrch[i], list->pStringArray[i], end - ptr );
}
return ERROR_SUCCESS;
}
static inline int filter( unsigned short sin_family, USHORT family ) static inline int filter( unsigned short sin_family, USHORT family )
{ {
if (sin_family != AF_INET && sin_family != AF_INET6) return TRUE; if (sin_family != AF_INET && sin_family != AF_INET6) return TRUE;
...@@ -851,6 +931,7 @@ exit: ...@@ -851,6 +931,7 @@ exit:
static const struct resolv_funcs funcs = static const struct resolv_funcs funcs =
{ {
resolv_get_searchlist,
resolv_get_serverlist, resolv_get_serverlist,
resolv_query, resolv_query,
resolv_set_serverlist resolv_set_serverlist
......
...@@ -343,7 +343,6 @@ DNS_STATUS WINAPI DnsQueryConfig( DNS_CONFIG_TYPE config, DWORD flag, PCWSTR ada ...@@ -343,7 +343,6 @@ DNS_STATUS WINAPI DnsQueryConfig( DNS_CONFIG_TYPE config, DWORD flag, PCWSTR ada
case DnsConfigAdapterDomainName_A: case DnsConfigAdapterDomainName_A:
case DnsConfigAdapterDomainName_W: case DnsConfigAdapterDomainName_W:
case DnsConfigAdapterDomainName_UTF8: case DnsConfigAdapterDomainName_UTF8:
case DnsConfigSearchList:
case DnsConfigAdapterInfo: case DnsConfigAdapterInfo:
case DnsConfigPrimaryHostNameRegistrationEnabled: case DnsConfigPrimaryHostNameRegistrationEnabled:
case DnsConfigAdapterHostNameRegistrationEnabled: case DnsConfigAdapterHostNameRegistrationEnabled:
...@@ -358,6 +357,9 @@ DNS_STATUS WINAPI DnsQueryConfig( DNS_CONFIG_TYPE config, DWORD flag, PCWSTR ada ...@@ -358,6 +357,9 @@ DNS_STATUS WINAPI DnsQueryConfig( DNS_CONFIG_TYPE config, DWORD flag, PCWSTR ada
case DnsConfigDnsServersIpv6: case DnsConfigDnsServersIpv6:
return resolv_funcs->get_serverlist( AF_INET6, buffer, len ); return resolv_funcs->get_serverlist( AF_INET6, buffer, len );
case DnsConfigSearchList:
return resolv_funcs->get_searchlist( buffer, len );
default: default:
WARN( "unknown config type: %d\n", config ); WARN( "unknown config type: %d\n", config );
break; break;
......
...@@ -514,7 +514,6 @@ static void test_ip_forward( int family ) ...@@ -514,7 +514,6 @@ static void test_ip_forward( int family )
NULL, 0, &count, 0 ); NULL, 0, &count, 0 );
if (!err) break; if (!err) break;
} }
todo_wine_if (family == AF_INET6)
ok( !err, "got %d\n", err ); ok( !err, "got %d\n", err );
if (err) { winetest_pop_context(); return; } if (err) { winetest_pop_context(); return; }
rw_size = rw_sizes[i]; rw_size = rw_sizes[i];
......
...@@ -470,7 +470,8 @@ static NTSTATUS ipv6_forward_enumerate_all( void *key_data, DWORD key_size, void ...@@ -470,7 +470,8 @@ static NTSTATUS ipv6_forward_enumerate_all( void *key_data, DWORD key_size, void
void *static_data, DWORD static_size, DWORD_PTR *count ) void *static_data, DWORD static_size, DWORD_PTR *count )
{ {
FIXME( "not implemented\n" ); FIXME( "not implemented\n" );
return STATUS_NOT_IMPLEMENTED; *count = 0;
return STATUS_SUCCESS;
} }
static struct module_table ipv4_tables[] = static struct module_table ipv4_tables[] =
......
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