2 * Internet Security and Zone Manager
4 * Copyright (c) 2004 Huw D M Davies
5 * Copyright 2004 Jacek Caban
6 * Copyright 2009 Detlef Riekenberg
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
25 #include "urlmon_main.h"
29 #include "wine/debug.h"
31 WINE_DEFAULT_DEBUG_CHANNEL(urlmon
);
33 static const WCHAR currentlevelW
[] = {'C','u','r','r','e','n','t','L','e','v','e','l',0};
34 static const WCHAR descriptionW
[] = {'D','e','s','c','r','i','p','t','i','o','n',0};
35 static const WCHAR displaynameW
[] = {'D','i','s','p','l','a','y','N','a','m','e',0};
36 static const WCHAR fileW
[] = {'f','i','l','e',0};
37 static const WCHAR flagsW
[] = {'F','l','a','g','s',0};
38 static const WCHAR iconW
[] = {'I','c','o','n',0};
39 static const WCHAR minlevelW
[] = {'M','i','n','L','e','v','e','l',0};
40 static const WCHAR recommendedlevelW
[] = {'R','e','c','o','m','m','e','n','d','e','d',
41 'L','e','v','e','l',0};
42 static const WCHAR wszZonesKey
[] = {'S','o','f','t','w','a','r','e','\\',
43 'M','i','c','r','o','s','o','f','t','\\',
44 'W','i','n','d','o','w','s','\\',
45 'C','u','r','r','e','n','t','V','e','r','s','i','o','n','\\',
46 'I','n','t','e','r','n','e','t',' ','S','e','t','t','i','n','g','s','\\',
47 'Z','o','n','e','s','\\',0};
49 /********************************************************************
50 * get_string_from_reg [internal]
52 * helper to get a string from the reg.
55 static void get_string_from_reg(HKEY hcu
, HKEY hklm
, LPCWSTR name
, LPWSTR out
, DWORD maxlen
)
58 DWORD len
= maxlen
* sizeof(WCHAR
);
61 res
= RegQueryValueExW(hcu
, name
, NULL
, &type
, (LPBYTE
) out
, &len
);
64 len
= maxlen
* sizeof(WCHAR
);
66 res
= RegQueryValueExW(hklm
, name
, NULL
, &type
, (LPBYTE
) out
, &len
);
70 TRACE("%s failed: %d\n", debugstr_w(name
), res
);
75 /********************************************************************
76 * get_dword_from_reg [internal]
78 * helper to get a dword from the reg.
81 static void get_dword_from_reg(HKEY hcu
, HKEY hklm
, LPCWSTR name
, LPDWORD out
)
83 DWORD type
= REG_DWORD
;
84 DWORD len
= sizeof(DWORD
);
87 res
= RegQueryValueExW(hcu
, name
, NULL
, &type
, (LPBYTE
) out
, &len
);
92 res
= RegQueryValueExW(hklm
, name
, NULL
, &type
, (LPBYTE
) out
, &len
);
96 TRACE("%s failed: %d\n", debugstr_w(name
), res
);
101 static HRESULT
get_zone_from_reg(LPCWSTR schema
, DWORD
*zone
)
106 static const WCHAR wszZoneMapProtocolKey
[] =
107 {'S','o','f','t','w','a','r','e','\\',
108 'M','i','c','r','o','s','o','f','t','\\',
109 'W','i','n','d','o','w','s','\\',
110 'C','u','r','r','e','n','t','V','e','r','s','i','o','n','\\',
111 'I','n','t','e','r','n','e','t',' ','S','e','t','t','i','n','g','s','\\',
112 'Z','o','n','e','M','a','p','\\',
113 'P','r','o','t','o','c','o','l','D','e','f','a','u','l','t','s',0};
115 res
= RegOpenKeyW(HKEY_CURRENT_USER
, wszZoneMapProtocolKey
, &hkey
);
116 if(res
!= ERROR_SUCCESS
) {
117 ERR("Could not open key %s\n", debugstr_w(wszZoneMapProtocolKey
));
121 size
= sizeof(DWORD
);
122 res
= RegQueryValueExW(hkey
, schema
, NULL
, NULL
, (PBYTE
)zone
, &size
);
124 if(res
== ERROR_SUCCESS
)
127 res
= RegOpenKeyW(HKEY_LOCAL_MACHINE
, wszZoneMapProtocolKey
, &hkey
);
128 if(res
!= ERROR_SUCCESS
) {
129 ERR("Could not open key %s\n", debugstr_w(wszZoneMapProtocolKey
));
133 size
= sizeof(DWORD
);
134 res
= RegQueryValueExW(hkey
, schema
, NULL
, NULL
, (PBYTE
)zone
, &size
);
136 if(res
== ERROR_SUCCESS
)
143 static HRESULT
map_url_to_zone(LPCWSTR url
, DWORD
*zone
, LPWSTR
*ret_url
)
150 secur_url
= heap_alloc(INTERNET_MAX_URL_LENGTH
*sizeof(WCHAR
));
153 hres
= CoInternetParseUrl(url
, PARSE_SECURITY_URL
, 0, secur_url
, INTERNET_MAX_URL_LENGTH
, &size
, 0);
155 strcpyW(secur_url
, url
);
157 hres
= CoInternetParseUrl(secur_url
, PARSE_SCHEMA
, 0, schema
, sizeof(schema
)/sizeof(WCHAR
), &size
, 0);
158 if(FAILED(hres
) || !*schema
) {
159 heap_free(secur_url
);
163 /* file protocol is a special case */
164 if(!strcmpW(schema
, fileW
)) {
165 WCHAR path
[MAX_PATH
], root
[20];
168 hres
= CoInternetParseUrl(secur_url
, PARSE_PATH_FROM_URL
, 0, path
,
169 sizeof(path
)/sizeof(WCHAR
), &size
, 0);
171 if(SUCCEEDED(hres
) && (ptr
= strchrW(path
, '\\')) && ptr
-path
< sizeof(root
)/sizeof(WCHAR
)) {
174 memcpy(root
, path
, (ptr
-path
)*sizeof(WCHAR
));
177 type
= GetDriveTypeW(root
);
181 case DRIVE_NO_ROOT_DIR
:
183 case DRIVE_REMOVABLE
:
195 FIXME("unsupported drive type %d\n", type
);
201 WARN("domains are not yet implemented\n");
202 hres
= get_zone_from_reg(schema
, zone
);
205 if(FAILED(hres
) || !ret_url
)
206 heap_free(secur_url
);
208 *ret_url
= secur_url
;
213 static HRESULT
open_zone_key(HKEY parent_key
, DWORD zone
, HKEY
*hkey
)
215 static const WCHAR wszFormat
[] = {'%','s','%','l','d',0};
217 WCHAR key_name
[sizeof(wszZonesKey
)/sizeof(WCHAR
)+8];
220 wsprintfW(key_name
, wszFormat
, wszZonesKey
, zone
);
222 res
= RegOpenKeyW(parent_key
, key_name
, hkey
);
224 if(res
!= ERROR_SUCCESS
) {
225 WARN("RegOpenKey failed\n");
232 static HRESULT
get_action_policy(DWORD zone
, DWORD action
, BYTE
*policy
, DWORD size
, URLZONEREG zone_reg
)
240 case URLACTION_SCRIPT_OVERRIDE_SAFETY
:
241 case URLACTION_ACTIVEX_OVERRIDE_SCRIPT_SAFETY
:
242 *(DWORD
*)policy
= URLPOLICY_DISALLOW
;
247 case URLZONEREG_DEFAULT
:
248 case URLZONEREG_HKCU
:
249 parent_key
= HKEY_CURRENT_USER
;
251 case URLZONEREG_HKLM
:
252 parent_key
= HKEY_LOCAL_MACHINE
;
255 WARN("Unknown URLZONEREG: %d\n", zone_reg
);
259 hres
= open_zone_key(parent_key
, zone
, &hkey
);
260 if(SUCCEEDED(hres
)) {
261 WCHAR action_str
[16];
264 static const WCHAR formatW
[] = {'%','X',0};
266 wsprintfW(action_str
, formatW
, action
);
268 res
= RegQueryValueExW(hkey
, action_str
, NULL
, NULL
, policy
, &len
);
269 if(res
== ERROR_MORE_DATA
) {
271 }else if(res
== ERROR_FILE_NOT_FOUND
) {
273 }else if(res
!= ERROR_SUCCESS
) {
274 ERR("RegQueryValue failed: %d\n", res
);
281 if(FAILED(hres
) && zone_reg
== URLZONEREG_DEFAULT
)
282 return get_action_policy(zone
, action
, policy
, size
, URLZONEREG_HKLM
);
287 /***********************************************************************
288 * InternetSecurityManager implementation
292 const IInternetSecurityManagerVtbl
* lpInternetSecurityManagerVtbl
;
296 IInternetSecurityMgrSite
*mgrsite
;
297 IInternetSecurityManager
*custom_manager
;
300 #define SECMGR_THIS(iface) DEFINE_THIS(SecManagerImpl, InternetSecurityManager, iface)
302 static HRESULT WINAPI
SecManagerImpl_QueryInterface(IInternetSecurityManager
* iface
,REFIID riid
,void** ppvObject
)
304 SecManagerImpl
*This
= SECMGR_THIS(iface
);
306 TRACE("(%p)->(%s,%p)\n",This
,debugstr_guid(riid
),ppvObject
);
308 /* Perform a sanity check on the parameters.*/
309 if ( (This
==0) || (ppvObject
==0) )
312 /* Initialize the return parameter */
315 /* Compare the riid with the interface IDs implemented by this object.*/
316 if (IsEqualIID(&IID_IUnknown
, riid
) ||
317 IsEqualIID(&IID_IInternetSecurityManager
, riid
))
320 /* Check that we obtained an interface.*/
322 WARN("not supported interface %s\n", debugstr_guid(riid
));
323 return E_NOINTERFACE
;
326 /* Query Interface always increases the reference count by one when it is successful */
327 IInternetSecurityManager_AddRef(iface
);
332 static ULONG WINAPI
SecManagerImpl_AddRef(IInternetSecurityManager
* iface
)
334 SecManagerImpl
*This
= SECMGR_THIS(iface
);
335 ULONG refCount
= InterlockedIncrement(&This
->ref
);
337 TRACE("(%p) ref=%u\n", This
, refCount
);
342 static ULONG WINAPI
SecManagerImpl_Release(IInternetSecurityManager
* iface
)
344 SecManagerImpl
*This
= SECMGR_THIS(iface
);
345 ULONG refCount
= InterlockedDecrement(&This
->ref
);
347 TRACE("(%p) ref=%u\n", This
, refCount
);
349 /* destroy the object if there's no more reference on it */
352 IInternetSecurityMgrSite_Release(This
->mgrsite
);
353 if(This
->custom_manager
)
354 IInternetSecurityManager_Release(This
->custom_manager
);
358 URLMON_UnlockModule();
364 static HRESULT WINAPI
SecManagerImpl_SetSecuritySite(IInternetSecurityManager
*iface
,
365 IInternetSecurityMgrSite
*pSite
)
367 SecManagerImpl
*This
= SECMGR_THIS(iface
);
369 TRACE("(%p)->(%p)\n", This
, pSite
);
372 IInternetSecurityMgrSite_Release(This
->mgrsite
);
374 if(This
->custom_manager
) {
375 IInternetSecurityManager_Release(This
->custom_manager
);
376 This
->custom_manager
= NULL
;
379 This
->mgrsite
= pSite
;
382 IServiceProvider
*servprov
;
385 IInternetSecurityMgrSite_AddRef(pSite
);
387 hres
= IInternetSecurityMgrSite_QueryInterface(pSite
, &IID_IServiceProvider
,
389 if(SUCCEEDED(hres
)) {
390 IServiceProvider_QueryService(servprov
, &SID_SInternetSecurityManager
,
391 &IID_IInternetSecurityManager
, (void**)&This
->custom_manager
);
392 IServiceProvider_Release(servprov
);
399 static HRESULT WINAPI
SecManagerImpl_GetSecuritySite(IInternetSecurityManager
*iface
,
400 IInternetSecurityMgrSite
**ppSite
)
402 SecManagerImpl
*This
= SECMGR_THIS(iface
);
404 TRACE("(%p)->(%p)\n", This
, ppSite
);
410 IInternetSecurityMgrSite_AddRef(This
->mgrsite
);
412 *ppSite
= This
->mgrsite
;
416 static HRESULT WINAPI
SecManagerImpl_MapUrlToZone(IInternetSecurityManager
*iface
,
417 LPCWSTR pwszUrl
, DWORD
*pdwZone
,
420 SecManagerImpl
*This
= SECMGR_THIS(iface
);
423 TRACE("(%p)->(%s %p %08x)\n", iface
, debugstr_w(pwszUrl
), pdwZone
, dwFlags
);
425 if(This
->custom_manager
) {
426 hres
= IInternetSecurityManager_MapUrlToZone(This
->custom_manager
,
427 pwszUrl
, pdwZone
, dwFlags
);
428 if(hres
!= INET_E_DEFAULT_ACTION
)
438 FIXME("not supported flags: %08x\n", dwFlags
);
440 return map_url_to_zone(pwszUrl
, pdwZone
, NULL
);
443 static HRESULT WINAPI
SecManagerImpl_GetSecurityId(IInternetSecurityManager
*iface
,
444 LPCWSTR pwszUrl
, BYTE
*pbSecurityId
, DWORD
*pcbSecurityId
, DWORD_PTR dwReserved
)
446 SecManagerImpl
*This
= SECMGR_THIS(iface
);
447 LPWSTR url
, ptr
, ptr2
;
451 static const WCHAR wszFile
[] = {'f','i','l','e',':'};
453 TRACE("(%p)->(%s %p %p %08lx)\n", iface
, debugstr_w(pwszUrl
), pbSecurityId
,
454 pcbSecurityId
, dwReserved
);
456 if(This
->custom_manager
) {
457 hres
= IInternetSecurityManager_GetSecurityId(This
->custom_manager
,
458 pwszUrl
, pbSecurityId
, pcbSecurityId
, dwReserved
);
459 if(hres
!= INET_E_DEFAULT_ACTION
)
463 if(!pwszUrl
|| !pbSecurityId
|| !pcbSecurityId
)
467 FIXME("dwReserved is not supported\n");
469 hres
= map_url_to_zone(pwszUrl
, &zone
, &url
);
471 return hres
== 0x80041001 ? E_INVALIDARG
: hres
;
473 /* file protocol is a special case */
474 if(strlenW(url
) >= sizeof(wszFile
)/sizeof(WCHAR
)
475 && !memcmp(url
, wszFile
, sizeof(wszFile
)) && strchrW(url
, '\\')) {
477 static const BYTE secidFile
[] = {'f','i','l','e',':'};
481 if(*pcbSecurityId
< sizeof(secidFile
)+sizeof(zone
))
482 return HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER
);
484 memcpy(pbSecurityId
, secidFile
, sizeof(secidFile
));
485 *(DWORD
*)(pbSecurityId
+sizeof(secidFile
)) = zone
;
487 *pcbSecurityId
= sizeof(secidFile
)+sizeof(zone
);
491 ptr
= strchrW(url
, ':');
496 memmove(ptr
, ptr2
, (strlenW(ptr2
)+1)*sizeof(WCHAR
));
498 ptr
= strchrW(ptr
, '/');
502 len
= WideCharToMultiByte(CP_ACP
, 0, url
, -1, NULL
, 0, NULL
, NULL
)-1;
504 if(len
+sizeof(DWORD
) > *pcbSecurityId
) {
506 return HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER
);
509 WideCharToMultiByte(CP_ACP
, 0, url
, -1, (LPSTR
)pbSecurityId
, len
, NULL
, NULL
);
512 *(DWORD
*)(pbSecurityId
+len
) = zone
;
514 *pcbSecurityId
= len
+sizeof(DWORD
);
520 static HRESULT WINAPI
SecManagerImpl_ProcessUrlAction(IInternetSecurityManager
*iface
,
521 LPCWSTR pwszUrl
, DWORD dwAction
,
522 BYTE
*pPolicy
, DWORD cbPolicy
,
523 BYTE
*pContext
, DWORD cbContext
,
524 DWORD dwFlags
, DWORD dwReserved
)
526 SecManagerImpl
*This
= SECMGR_THIS(iface
);
530 TRACE("(%p)->(%s %08x %p %08x %p %08x %08x %08x)\n", iface
, debugstr_w(pwszUrl
), dwAction
,
531 pPolicy
, cbPolicy
, pContext
, cbContext
, dwFlags
, dwReserved
);
533 if(This
->custom_manager
) {
534 hres
= IInternetSecurityManager_ProcessUrlAction(This
->custom_manager
, pwszUrl
, dwAction
,
535 pPolicy
, cbPolicy
, pContext
, cbContext
, dwFlags
, dwReserved
);
536 if(hres
!= INET_E_DEFAULT_ACTION
)
540 if(dwFlags
|| dwReserved
)
541 FIXME("Unsupported arguments\n");
546 hres
= map_url_to_zone(pwszUrl
, &zone
, NULL
);
550 hres
= get_action_policy(zone
, dwAction
, (BYTE
*)&policy
, sizeof(policy
), URLZONEREG_DEFAULT
);
554 TRACE("policy %x\n", policy
);
555 if(cbPolicy
>= sizeof(DWORD
))
556 *(DWORD
*)pPolicy
= policy
;
558 switch(GetUrlPolicyPermissions(policy
)) {
559 case URLPOLICY_ALLOW
:
560 case URLPOLICY_CHANNEL_SOFTDIST_PRECACHE
:
562 case URLPOLICY_DISALLOW
:
564 case URLPOLICY_QUERY
:
565 FIXME("URLPOLICY_QUERY not implemented\n");
568 FIXME("Not implemented policy %x\n", policy
);
575 static HRESULT WINAPI
SecManagerImpl_QueryCustomPolicy(IInternetSecurityManager
*iface
,
576 LPCWSTR pwszUrl
, REFGUID guidKey
,
577 BYTE
**ppPolicy
, DWORD
*pcbPolicy
,
578 BYTE
*pContext
, DWORD cbContext
,
581 SecManagerImpl
*This
= SECMGR_THIS(iface
);
584 TRACE("(%p)->(%s %s %p %p %p %08x %08x )\n", iface
, debugstr_w(pwszUrl
), debugstr_guid(guidKey
),
585 ppPolicy
, pcbPolicy
, pContext
, cbContext
, dwReserved
);
587 if(This
->custom_manager
) {
588 hres
= IInternetSecurityManager_QueryCustomPolicy(This
->custom_manager
, pwszUrl
, guidKey
,
589 ppPolicy
, pcbPolicy
, pContext
, cbContext
, dwReserved
);
590 if(hres
!= INET_E_DEFAULT_ACTION
)
594 WARN("Unknown guidKey %s\n", debugstr_guid(guidKey
));
595 return HRESULT_FROM_WIN32(ERROR_NOT_FOUND
);
598 static HRESULT WINAPI
SecManagerImpl_SetZoneMapping(IInternetSecurityManager
*iface
,
599 DWORD dwZone
, LPCWSTR pwszPattern
, DWORD dwFlags
)
601 SecManagerImpl
*This
= SECMGR_THIS(iface
);
604 TRACE("(%p)->(%08x %s %08x)\n", iface
, dwZone
, debugstr_w(pwszPattern
),dwFlags
);
606 if(This
->custom_manager
) {
607 hres
= IInternetSecurityManager_SetZoneMapping(This
->custom_manager
, dwZone
,
608 pwszPattern
, dwFlags
);
609 if(hres
!= INET_E_DEFAULT_ACTION
)
613 FIXME("Default action is not implemented\n");
617 static HRESULT WINAPI
SecManagerImpl_GetZoneMappings(IInternetSecurityManager
*iface
,
618 DWORD dwZone
, IEnumString
**ppenumString
, DWORD dwFlags
)
620 SecManagerImpl
*This
= SECMGR_THIS(iface
);
623 TRACE("(%p)->(%08x %p %08x)\n", iface
, dwZone
, ppenumString
,dwFlags
);
625 if(This
->custom_manager
) {
626 hres
= IInternetSecurityManager_GetZoneMappings(This
->custom_manager
, dwZone
,
627 ppenumString
, dwFlags
);
628 if(hres
!= INET_E_DEFAULT_ACTION
)
632 FIXME("Default action is not implemented\n");
636 static const IInternetSecurityManagerVtbl VT_SecManagerImpl
=
638 SecManagerImpl_QueryInterface
,
639 SecManagerImpl_AddRef
,
640 SecManagerImpl_Release
,
641 SecManagerImpl_SetSecuritySite
,
642 SecManagerImpl_GetSecuritySite
,
643 SecManagerImpl_MapUrlToZone
,
644 SecManagerImpl_GetSecurityId
,
645 SecManagerImpl_ProcessUrlAction
,
646 SecManagerImpl_QueryCustomPolicy
,
647 SecManagerImpl_SetZoneMapping
,
648 SecManagerImpl_GetZoneMappings
651 HRESULT
SecManagerImpl_Construct(IUnknown
*pUnkOuter
, LPVOID
*ppobj
)
653 SecManagerImpl
*This
;
655 TRACE("(%p,%p)\n",pUnkOuter
,ppobj
);
656 This
= heap_alloc(sizeof(*This
));
658 /* Initialize the virtual function table. */
659 This
->lpInternetSecurityManagerVtbl
= &VT_SecManagerImpl
;
662 This
->mgrsite
= NULL
;
663 This
->custom_manager
= NULL
;
672 /***********************************************************************
673 * InternetZoneManager implementation
677 const IInternetZoneManagerEx2Vtbl
* lpVtbl
;
684 /***********************************************************************
685 * build_zonemap_from_reg [internal]
687 * Enumerate the Zones in the Registry and return the Zones in a DWORD-array
688 * The number of the Zones is returned in data[0]
690 static LPDWORD
build_zonemap_from_reg(void)
695 DWORD allocated
= 6; /* space for the zonecount and Zone "0" up to Zone "4" */
701 res
= RegOpenKeyW(HKEY_CURRENT_USER
, wszZonesKey
, &hkey
);
705 data
= heap_alloc(allocated
* sizeof(DWORD
));
711 len
= sizeof(name
) / sizeof(name
[0]);
712 res
= RegEnumKeyExW(hkey
, used
, name
, &len
, NULL
, NULL
, NULL
, NULL
);
716 if (used
== allocated
) {
720 new_data
= heap_realloc_zero(data
, allocated
* sizeof(DWORD
));
726 data
[used
] = atoiW(name
);
736 /* something failed */
742 /********************************************************************
743 * IInternetZoneManager_QueryInterface
745 static HRESULT WINAPI
ZoneMgrImpl_QueryInterface(IInternetZoneManagerEx2
* iface
, REFIID riid
, void** ppvObject
)
747 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
749 TRACE("(%p)->(%s,%p)\n", This
, debugstr_guid(riid
), ppvObject
);
751 if(!This
|| !ppvObject
)
754 if(IsEqualIID(&IID_IUnknown
, riid
)) {
755 TRACE("(%p)->(IID_IUnknown %p)\n", This
, ppvObject
);
756 }else if(IsEqualIID(&IID_IInternetZoneManager
, riid
)) {
757 TRACE("(%p)->(IID_InternetZoneManager %p)\n", This
, ppvObject
);
758 }else if(IsEqualIID(&IID_IInternetZoneManagerEx
, riid
)) {
759 TRACE("(%p)->(IID_InternetZoneManagerEx %p)\n", This
, ppvObject
);
760 }else if(IsEqualIID(&IID_IInternetZoneManagerEx2
, riid
)) {
761 TRACE("(%p)->(IID_InternetZoneManagerEx2 %p)\n", This
, ppvObject
);
765 FIXME("Unknown interface: %s\n", debugstr_guid(riid
));
767 return E_NOINTERFACE
;
771 IInternetZoneManager_AddRef(iface
);
775 /********************************************************************
776 * IInternetZoneManager_AddRef
778 static ULONG WINAPI
ZoneMgrImpl_AddRef(IInternetZoneManagerEx2
* iface
)
780 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
781 ULONG refCount
= InterlockedIncrement(&This
->ref
);
783 TRACE("(%p)->(ref before=%u)\n",This
, refCount
- 1);
788 /********************************************************************
789 * IInternetZoneManager_Release
791 static ULONG WINAPI
ZoneMgrImpl_Release(IInternetZoneManagerEx2
* iface
)
793 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
794 ULONG refCount
= InterlockedDecrement(&This
->ref
);
796 TRACE("(%p)->(ref before=%u)\n",This
, refCount
+ 1);
799 while (This
->zonemap_count
) heap_free(This
->zonemaps
[--This
->zonemap_count
]);
800 heap_free(This
->zonemaps
);
802 URLMON_UnlockModule();
808 /********************************************************************
809 * IInternetZoneManager_GetZoneAttributes
811 static HRESULT WINAPI
ZoneMgrImpl_GetZoneAttributes(IInternetZoneManagerEx2
* iface
,
813 ZONEATTRIBUTES
* pZoneAttributes
)
815 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
820 TRACE("(%p)->(%d %p)\n", This
, dwZone
, pZoneAttributes
);
822 if (!pZoneAttributes
)
825 hr
= open_zone_key(HKEY_CURRENT_USER
, dwZone
, &hcu
);
827 return S_OK
; /* IE6 and older returned E_FAIL here */
829 hr
= open_zone_key(HKEY_LOCAL_MACHINE
, dwZone
, &hklm
);
831 TRACE("Zone %d not in HKLM\n", dwZone
);
833 get_string_from_reg(hcu
, hklm
, displaynameW
, pZoneAttributes
->szDisplayName
, MAX_ZONE_PATH
);
834 get_string_from_reg(hcu
, hklm
, descriptionW
, pZoneAttributes
->szDescription
, MAX_ZONE_DESCRIPTION
);
835 get_string_from_reg(hcu
, hklm
, iconW
, pZoneAttributes
->szIconPath
, MAX_ZONE_PATH
);
836 get_dword_from_reg(hcu
, hklm
, minlevelW
, &pZoneAttributes
->dwTemplateMinLevel
);
837 get_dword_from_reg(hcu
, hklm
, currentlevelW
, &pZoneAttributes
->dwTemplateCurrentLevel
);
838 get_dword_from_reg(hcu
, hklm
, recommendedlevelW
, &pZoneAttributes
->dwTemplateRecommended
);
839 get_dword_from_reg(hcu
, hklm
, flagsW
, &pZoneAttributes
->dwFlags
);
846 /********************************************************************
847 * IInternetZoneManager_SetZoneAttributes
849 static HRESULT WINAPI
ZoneMgrImpl_SetZoneAttributes(IInternetZoneManagerEx2
* iface
,
851 ZONEATTRIBUTES
* pZoneAttributes
)
853 FIXME("(%p)->(%08x %p) stub\n", iface
, dwZone
, pZoneAttributes
);
857 /********************************************************************
858 * IInternetZoneManager_GetZoneCustomPolicy
860 static HRESULT WINAPI
ZoneMgrImpl_GetZoneCustomPolicy(IInternetZoneManagerEx2
* iface
,
865 URLZONEREG ulrZoneReg
)
867 FIXME("(%p)->(%08x %s %p %p %08x) stub\n", iface
, dwZone
, debugstr_guid(guidKey
),
868 ppPolicy
, pcbPolicy
, ulrZoneReg
);
872 /********************************************************************
873 * IInternetZoneManager_SetZoneCustomPolicy
875 static HRESULT WINAPI
ZoneMgrImpl_SetZoneCustomPolicy(IInternetZoneManagerEx2
* iface
,
880 URLZONEREG ulrZoneReg
)
882 FIXME("(%p)->(%08x %s %p %08x %08x) stub\n", iface
, dwZone
, debugstr_guid(guidKey
),
883 ppPolicy
, cbPolicy
, ulrZoneReg
);
887 /********************************************************************
888 * IInternetZoneManager_GetZoneActionPolicy
890 static HRESULT WINAPI
ZoneMgrImpl_GetZoneActionPolicy(IInternetZoneManagerEx2
* iface
,
891 DWORD dwZone
, DWORD dwAction
, BYTE
* pPolicy
, DWORD cbPolicy
, URLZONEREG urlZoneReg
)
893 TRACE("(%p)->(%d %08x %p %d %d)\n", iface
, dwZone
, dwAction
, pPolicy
,
894 cbPolicy
, urlZoneReg
);
899 return get_action_policy(dwZone
, dwAction
, pPolicy
, cbPolicy
, urlZoneReg
);
902 /********************************************************************
903 * IInternetZoneManager_SetZoneActionPolicy
905 static HRESULT WINAPI
ZoneMgrImpl_SetZoneActionPolicy(IInternetZoneManagerEx2
* iface
,
910 URLZONEREG urlZoneReg
)
912 FIXME("(%p)->(%08x %08x %p %08x %08x) stub\n", iface
, dwZone
, dwAction
, pPolicy
,
913 cbPolicy
, urlZoneReg
);
917 /********************************************************************
918 * IInternetZoneManager_PromptAction
920 static HRESULT WINAPI
ZoneMgrImpl_PromptAction(IInternetZoneManagerEx2
* iface
,
927 FIXME("%p %08x %p %s %s %08x\n", iface
, dwAction
, hwndParent
,
928 debugstr_w(pwszUrl
), debugstr_w(pwszText
), dwPromptFlags
);
932 /********************************************************************
933 * IInternetZoneManager_LogAction
935 static HRESULT WINAPI
ZoneMgrImpl_LogAction(IInternetZoneManagerEx2
* iface
,
941 FIXME("(%p)->(%08x %s %s %08x) stub\n", iface
, dwAction
, debugstr_w(pwszUrl
),
942 debugstr_w(pwszText
), dwLogFlags
);
946 /********************************************************************
947 * IInternetZoneManager_CreateZoneEnumerator
949 static HRESULT WINAPI
ZoneMgrImpl_CreateZoneEnumerator(IInternetZoneManagerEx2
* iface
,
954 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
959 TRACE("(%p)->(%p, %p, 0x%08x)\n", This
, pdwEnum
, pdwCount
, dwFlags
);
960 if (!pdwEnum
|| !pdwCount
|| (dwFlags
!= 0))
963 data
= build_zonemap_from_reg();
964 TRACE("found %d zones\n", data
? data
[0] : -1);
969 for (i
= 0; i
< This
->zonemap_count
; i
++) {
970 if (This
->zonemaps
&& !This
->zonemaps
[i
]) {
971 This
->zonemaps
[i
] = data
;
978 if (This
->zonemaps
) {
979 /* try to double the nr. of pointers in the array */
980 new_maps
= heap_realloc_zero(This
->zonemaps
, This
->zonemap_count
* 2 * sizeof(LPDWORD
));
982 This
->zonemap_count
*= 2;
986 This
->zonemap_count
= 2;
987 new_maps
= heap_alloc_zero(This
->zonemap_count
* sizeof(LPDWORD
));
994 This
->zonemaps
= new_maps
;
995 This
->zonemaps
[i
] = data
;
1001 /********************************************************************
1002 * IInternetZoneManager_GetZoneAt
1004 static HRESULT WINAPI
ZoneMgrImpl_GetZoneAt(IInternetZoneManagerEx2
* iface
,
1009 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
1012 TRACE("(%p)->(0x%08x, %d, %p)\n", This
, dwEnum
, dwIndex
, pdwZone
);
1014 /* make sure, that dwEnum and dwIndex are in the valid range */
1015 if (dwEnum
< This
->zonemap_count
) {
1016 if ((data
= This
->zonemaps
[dwEnum
])) {
1017 if (dwIndex
< data
[0]) {
1018 *pdwZone
= data
[dwIndex
+ 1];
1023 return E_INVALIDARG
;
1026 /********************************************************************
1027 * IInternetZoneManager_DestroyZoneEnumerator
1029 static HRESULT WINAPI
ZoneMgrImpl_DestroyZoneEnumerator(IInternetZoneManagerEx2
* iface
,
1032 ZoneMgrImpl
* This
= (ZoneMgrImpl
*)iface
;
1035 TRACE("(%p)->(0x%08x)\n", This
, dwEnum
);
1036 /* make sure, that dwEnum is valid */
1037 if (dwEnum
< This
->zonemap_count
) {
1038 if ((data
= This
->zonemaps
[dwEnum
])) {
1039 This
->zonemaps
[dwEnum
] = NULL
;
1044 return E_INVALIDARG
;
1047 /********************************************************************
1048 * IInternetZoneManager_CopyTemplatePoliciesToZone
1050 static HRESULT WINAPI
ZoneMgrImpl_CopyTemplatePoliciesToZone(IInternetZoneManagerEx2
* iface
,
1055 FIXME("(%p)->(%08x %08x %08x) stub\n", iface
, dwTemplate
, dwZone
, dwReserved
);
1059 /********************************************************************
1060 * IInternetZoneManagerEx_GetZoneActionPolicyEx
1062 static HRESULT WINAPI
ZoneMgrImpl_GetZoneActionPolicyEx(IInternetZoneManagerEx2
* iface
,
1067 URLZONEREG urlZoneReg
,
1070 TRACE("(%p)->(%d, 0x%x, %p, %d, %d, 0x%x)\n", iface
, dwZone
,
1071 dwAction
, pPolicy
, cbPolicy
, urlZoneReg
, dwFlags
);
1074 return E_INVALIDARG
;
1077 FIXME("dwFlags 0x%x ignored\n", dwFlags
);
1079 return get_action_policy(dwZone
, dwAction
, pPolicy
, cbPolicy
, urlZoneReg
);
1082 /********************************************************************
1083 * IInternetZoneManagerEx_SetZoneActionPolicyEx
1085 static HRESULT WINAPI
ZoneMgrImpl_SetZoneActionPolicyEx(IInternetZoneManagerEx2
* iface
,
1090 URLZONEREG urlZoneReg
,
1093 FIXME("(%p)->(%d, 0x%x, %p, %d, %d, 0x%x) stub\n", iface
, dwZone
, dwAction
, pPolicy
,
1094 cbPolicy
, urlZoneReg
, dwFlags
);
1098 /********************************************************************
1099 * IInternetZoneManagerEx2_GetZoneAttributesEx
1101 static HRESULT WINAPI
ZoneMgrImpl_GetZoneAttributesEx(IInternetZoneManagerEx2
* iface
,
1103 ZONEATTRIBUTES
* pZoneAttributes
,
1106 TRACE("(%p)->(%d, %p, 0x%x)\n", iface
, dwZone
, pZoneAttributes
, dwFlags
);
1109 FIXME("dwFlags 0x%x ignored\n", dwFlags
);
1111 return IInternetZoneManager_GetZoneAttributes(iface
, dwZone
, pZoneAttributes
);
1115 /********************************************************************
1116 * IInternetZoneManagerEx2_GetZoneSecurityState
1118 static HRESULT WINAPI
ZoneMgrImpl_GetZoneSecurityState(IInternetZoneManagerEx2
* iface
,
1120 BOOL fRespectPolicy
,
1122 BOOL
*pfPolicyEncountered
)
1124 FIXME("(%p)->(%d, %d, %p, %p) stub\n", iface
, dwZoneIndex
, fRespectPolicy
,
1125 pdwState
, pfPolicyEncountered
);
1127 *pdwState
= SECURITY_IE_STATE_GREEN
;
1129 if (pfPolicyEncountered
)
1130 *pfPolicyEncountered
= FALSE
;
1135 /********************************************************************
1136 * IInternetZoneManagerEx2_GetIESecurityState
1138 static HRESULT WINAPI
ZoneMgrImpl_GetIESecurityState(IInternetZoneManagerEx2
* iface
,
1139 BOOL fRespectPolicy
,
1141 BOOL
*pfPolicyEncountered
,
1144 FIXME("(%p)->(%d, %p, %p, %d) stub\n", iface
, fRespectPolicy
, pdwState
,
1145 pfPolicyEncountered
, fNoCache
);
1147 *pdwState
= SECURITY_IE_STATE_GREEN
;
1149 if (pfPolicyEncountered
)
1150 *pfPolicyEncountered
= FALSE
;
1155 /********************************************************************
1156 * IInternetZoneManagerEx2_FixInsecureSettings
1158 static HRESULT WINAPI
ZoneMgrImpl_FixInsecureSettings(IInternetZoneManagerEx2
* iface
)
1160 FIXME("(%p) stub\n", iface
);
1164 /********************************************************************
1165 * IInternetZoneManager_Construct
1167 static const IInternetZoneManagerEx2Vtbl ZoneMgrImplVtbl
= {
1168 ZoneMgrImpl_QueryInterface
,
1170 ZoneMgrImpl_Release
,
1171 /* IInternetZoneManager */
1172 ZoneMgrImpl_GetZoneAttributes
,
1173 ZoneMgrImpl_SetZoneAttributes
,
1174 ZoneMgrImpl_GetZoneCustomPolicy
,
1175 ZoneMgrImpl_SetZoneCustomPolicy
,
1176 ZoneMgrImpl_GetZoneActionPolicy
,
1177 ZoneMgrImpl_SetZoneActionPolicy
,
1178 ZoneMgrImpl_PromptAction
,
1179 ZoneMgrImpl_LogAction
,
1180 ZoneMgrImpl_CreateZoneEnumerator
,
1181 ZoneMgrImpl_GetZoneAt
,
1182 ZoneMgrImpl_DestroyZoneEnumerator
,
1183 ZoneMgrImpl_CopyTemplatePoliciesToZone
,
1184 /* IInternetZoneManagerEx */
1185 ZoneMgrImpl_GetZoneActionPolicyEx
,
1186 ZoneMgrImpl_SetZoneActionPolicyEx
,
1187 /* IInternetZoneManagerEx2 */
1188 ZoneMgrImpl_GetZoneAttributesEx
,
1189 ZoneMgrImpl_GetZoneSecurityState
,
1190 ZoneMgrImpl_GetIESecurityState
,
1191 ZoneMgrImpl_FixInsecureSettings
,
1194 HRESULT
ZoneMgrImpl_Construct(IUnknown
*pUnkOuter
, LPVOID
*ppobj
)
1196 ZoneMgrImpl
* ret
= heap_alloc_zero(sizeof(ZoneMgrImpl
));
1198 TRACE("(%p %p)\n", pUnkOuter
, ppobj
);
1199 ret
->lpVtbl
= &ZoneMgrImplVtbl
;
1201 *ppobj
= (IInternetZoneManagerEx
*)ret
;
1203 URLMON_LockModule();
1208 /***********************************************************************
1209 * CoInternetCreateSecurityManager (URLMON.@)
1212 HRESULT WINAPI
CoInternetCreateSecurityManager( IServiceProvider
*pSP
,
1213 IInternetSecurityManager
**ppSM
, DWORD dwReserved
)
1215 TRACE("%p %p %d\n", pSP
, ppSM
, dwReserved
);
1218 FIXME("pSP not supported\n");
1220 return SecManagerImpl_Construct(NULL
, (void**) ppSM
);
1223 /********************************************************************
1224 * CoInternetCreateZoneManager (URLMON.@)
1226 HRESULT WINAPI
CoInternetCreateZoneManager(IServiceProvider
* pSP
, IInternetZoneManager
** ppZM
, DWORD dwReserved
)
1228 TRACE("(%p %p %x)\n", pSP
, ppZM
, dwReserved
);
1229 return ZoneMgrImpl_Construct(NULL
, (void**)ppZM
);
1232 /********************************************************************
1233 * CoInternetGetSecurityUrl (URLMON.@)
1235 HRESULT WINAPI
CoInternetGetSecurityUrl(LPCWSTR pwzUrl
, LPWSTR
*ppwzSecUrl
, PSUACTION psuAction
, DWORD dwReserved
)
1237 WCHAR url
[INTERNET_MAX_URL_LENGTH
], domain
[INTERNET_MAX_URL_LENGTH
];
1241 TRACE("(%p,%p,%u,%u)\n", pwzUrl
, ppwzSecUrl
, psuAction
, dwReserved
);
1243 hres
= CoInternetParseUrl(pwzUrl
, PARSE_SECURITY_URL
, 0, url
, INTERNET_MAX_URL_LENGTH
, &len
, 0);
1245 if(psuAction
== PSU_DEFAULT
)
1246 hres
= CoInternetParseUrl(url
, PARSE_SECURITY_DOMAIN
, 0, domain
,
1247 INTERNET_MAX_URL_LENGTH
, &len
, 0);
1249 if(psuAction
==PSU_SECURITY_URL_ONLY
|| hres
!=S_OK
) {
1250 len
= lstrlenW(url
)+1;
1251 *ppwzSecUrl
= CoTaskMemAlloc(len
*sizeof(WCHAR
));
1253 return E_OUTOFMEMORY
;
1255 memcpy(*ppwzSecUrl
, url
, len
*sizeof(WCHAR
));
1260 *ppwzSecUrl
= CoTaskMemAlloc(len
*sizeof(WCHAR
));
1262 return E_OUTOFMEMORY
;
1264 memcpy(*ppwzSecUrl
, domain
, len
*sizeof(WCHAR
));
1268 if(psuAction
== PSU_DEFAULT
) {
1269 hres
= CoInternetParseUrl(pwzUrl
, PARSE_ROOTDOCUMENT
, 0, url
, 0, &len
, 0);
1270 if(hres
== S_FALSE
) {
1271 hres
= CoInternetParseUrl(pwzUrl
, PARSE_SCHEMA
, 0, domain
,
1272 INTERNET_MAX_URL_LENGTH
, &len
, 0);
1275 hres
= CoInternetParseUrl(pwzUrl
, PARSE_DOMAIN
, 0, domain
+len
+1,
1276 INTERNET_MAX_URL_LENGTH
-len
-1, &len
, 0);
1278 len
= lstrlenW(domain
)+1;
1279 *ppwzSecUrl
= CoTaskMemAlloc(len
*sizeof(WCHAR
));
1281 return E_OUTOFMEMORY
;
1283 memcpy(*ppwzSecUrl
, domain
, len
*sizeof(WCHAR
));
1290 len
= lstrlenW(pwzUrl
)+1;
1291 *ppwzSecUrl
= CoTaskMemAlloc(len
*sizeof(WCHAR
));
1293 return E_OUTOFMEMORY
;
1295 memcpy(*ppwzSecUrl
, pwzUrl
, len
*sizeof(WCHAR
));