Commit dac6d862 authored by Thomas Mullaly's avatar Thomas Mullaly Committed by Alexandre Julliard

urlmon: Made domain mapping support IUri based and added wildcard scheme domain mapping tests.

parent 98d5dfb8
...@@ -444,50 +444,38 @@ static HRESULT search_for_domain_mapping(HKEY domains, LPCWSTR schema, LPCWSTR h ...@@ -444,50 +444,38 @@ static HRESULT search_for_domain_mapping(HKEY domains, LPCWSTR schema, LPCWSTR h
return hres; return hres;
} }
static HRESULT get_zone_from_domains(LPCWSTR url, LPCWSTR schema, DWORD *zone) static HRESULT get_zone_from_domains(IUri *uri, DWORD *zone)
{ {
HRESULT hres; HRESULT hres;
WCHAR *host_name; BSTR host, scheme;
DWORD host_len = lstrlenW(url)+1;
DWORD res; DWORD res;
HKEY domains; HKEY domains;
DWORD scheme_type;
host_name = heap_alloc(host_len*sizeof(WCHAR)); hres = IUri_GetScheme(uri, &scheme_type);
if(!host_name) if(FAILED(hres))
return E_OUTOFMEMORY; return hres;
hres = CoInternetParseUrl(url, PARSE_DOMAIN, 0, host_name, host_len, &host_len, 0);
if(hres == S_FALSE) {
WCHAR *tmp = heap_realloc(host_name, (host_len+1)*sizeof(WCHAR));
if(!tmp) {
heap_free(host_name);
return E_OUTOFMEMORY;
}
host_name = tmp;
hres = CoInternetParseUrl(url, PARSE_DOMAIN, 0, host_name, host_len+1, &host_len, 0);
}
/* Windows doesn't play nice with unknown scheme types when it tries /* Windows doesn't play nice with unknown scheme types when it tries
* to check if a host name maps into any domains. * to check if a host name maps into any domains.
*
* The reason is with how CoInternetParseUrl handles unknown scheme types
* when it's parsing the domain of a URL (IE it always returns E_FAIL).
*
* Windows doesn't compensate for this and simply doesn't check if
* the URL maps into any domains.
*/ */
if(hres != S_OK) { if(scheme_type == URL_SCHEME_UNKNOWN)
heap_free(host_name); return S_FALSE;
if(hres == E_FAIL)
return S_FALSE; hres = IUri_GetHost(uri, &host);
if(FAILED(hres))
return hres;
hres = IUri_GetSchemeName(uri, &scheme);
if(FAILED(hres)) {
SysFreeString(host);
return hres; return hres;
} }
/* First try CURRENT_USER. */ /* First try CURRENT_USER. */
res = RegOpenKeyW(HKEY_CURRENT_USER, wszZoneMapDomainsKey, &domains); res = RegOpenKeyW(HKEY_CURRENT_USER, wszZoneMapDomainsKey, &domains);
if(res == ERROR_SUCCESS) { if(res == ERROR_SUCCESS) {
hres = search_for_domain_mapping(domains, schema, host_name, host_len, zone); hres = search_for_domain_mapping(domains, scheme, host, SysStringLen(host), zone);
RegCloseKey(domains); RegCloseKey(domains);
} else } else
WARN("Failed to open HKCU's %s key\n", debugstr_w(wszZoneMapDomainsKey)); WARN("Failed to open HKCU's %s key\n", debugstr_w(wszZoneMapDomainsKey));
...@@ -496,13 +484,14 @@ static HRESULT get_zone_from_domains(LPCWSTR url, LPCWSTR schema, DWORD *zone) ...@@ -496,13 +484,14 @@ static HRESULT get_zone_from_domains(LPCWSTR url, LPCWSTR schema, DWORD *zone)
if(hres == S_FALSE) { if(hres == S_FALSE) {
res = RegOpenKeyW(HKEY_LOCAL_MACHINE, wszZoneMapDomainsKey, &domains); res = RegOpenKeyW(HKEY_LOCAL_MACHINE, wszZoneMapDomainsKey, &domains);
if(res == ERROR_SUCCESS) { if(res == ERROR_SUCCESS) {
hres = search_for_domain_mapping(domains, schema, host_name, host_len, zone); hres = search_for_domain_mapping(domains, scheme, host, SysStringLen(host), zone);
RegCloseKey(domains); RegCloseKey(domains);
} else } else
WARN("Failed to open HKLM's %s key\n", debugstr_w(wszZoneMapDomainsKey)); WARN("Failed to open HKLM's %s key\n", debugstr_w(wszZoneMapDomainsKey));
} }
heap_free(host_name); SysFreeString(host);
SysFreeString(scheme);
return hres; return hres;
} }
...@@ -563,16 +552,7 @@ static HRESULT map_security_uri_to_zone(IUri *uri, DWORD *zone) ...@@ -563,16 +552,7 @@ static HRESULT map_security_uri_to_zone(IUri *uri, DWORD *zone)
} }
if(*zone == URLZONE_INVALID) { if(*zone == URLZONE_INVALID) {
BSTR secur_url; hres = get_zone_from_domains(uri, zone);
hres = IUri_GetDisplayUri(uri, &secur_url);
if(FAILED(hres)) {
SysFreeString(scheme);
return hres;
}
hres = get_zone_from_domains(secur_url, scheme, zone);
SysFreeString(secur_url);
if(hres == S_FALSE) if(hres == S_FALSE)
hres = get_zone_from_reg(scheme, zone); hres = get_zone_from_reg(scheme, zone);
} }
......
...@@ -604,7 +604,8 @@ static const zone_domain_mapping zone_domain_mappings[] = { ...@@ -604,7 +604,8 @@ static const zone_domain_mapping zone_domain_mappings[] = {
{"www.testing.com",NULL,"http",URLZONE_CUSTOM}, {"www.testing.com",NULL,"http",URLZONE_CUSTOM},
{"www.testing.com","testing","http",URLZONE_CUSTOM2}, {"www.testing.com","testing","http",URLZONE_CUSTOM2},
{"org",NULL,"http",URLZONE_CUSTOM}, {"org",NULL,"http",URLZONE_CUSTOM},
{"org","testing","http",URLZONE_CUSTOM2} {"org","testing","http",URLZONE_CUSTOM2},
{"wine.testing",NULL,"*",URLZONE_CUSTOM2}
}; };
static void register_zone_domains(void) static void register_zone_domains(void)
...@@ -751,7 +752,10 @@ static const zone_mapping_test zone_mapping_tests[] = { ...@@ -751,7 +752,10 @@ static const zone_mapping_test zone_mapping_tests[] = {
/* Tests for "org" zone mappings. */ /* Tests for "org" zone mappings. */
{"http://google.org/",URLZONE_INTERNET,FALSE,URLZONE_CUSTOM}, {"http://google.org/",URLZONE_INTERNET,FALSE,URLZONE_CUSTOM},
{"http://org/",URLZONE_CUSTOM}, {"http://org/",URLZONE_CUSTOM},
{"http://testing.org/",URLZONE_CUSTOM2} {"http://testing.org/",URLZONE_CUSTOM2},
/* Tests for "wine.testing" mapping */
{"*:wine.testing/test",URLZONE_CUSTOM2},
{"http://wine.testing/testing",URLZONE_CUSTOM2}
}; };
static void test_zone_domain_mappings(void) static void test_zone_domain_mappings(void)
......
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