1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_PROXY_PROXY_CONFIG_SERVICE_WIN_H_
6 #define NET_PROXY_PROXY_CONFIG_SERVICE_WIN_H_
13 #include "base/compiler_specific.h"
14 #include "base/gtest_prod_util.h"
15 #include "base/win/object_watcher.h"
16 #include "net/proxy/polling_proxy_config_service.h"
20 // Implementation of ProxyConfigService that retrieves the system proxy
23 // It works by calling WinHttpGetIEProxyConfigForCurrentUser() to fetch the
24 // Internet Explorer proxy settings.
26 // We use two different strategies to notice when the configuration has
29 // (1) Watch the internet explorer settings registry keys for changes. When
30 // one of the registry keys pertaining to proxy settings has changed, we
31 // call WinHttpGetIEProxyConfigForCurrentUser() again to read the
32 // configuration's new value.
34 // (2) Do regular polling every 10 seconds during network activity to see if
35 // WinHttpGetIEProxyConfigForCurrentUser() returns something different.
37 // Ideally strategy (1) should be sufficient to pick up all of the changes.
38 // However we still do the regular polling as a precaution in case the
39 // implementation details of WinHttpGetIEProxyConfigForCurrentUser() ever
40 // change, or in case we got it wrong (and are not checking all possible
41 // registry dependencies).
42 class NET_EXPORT_PRIVATE ProxyConfigServiceWin
43 : public PollingProxyConfigService
,
44 public base::win::ObjectWatcher::Delegate
{
46 ProxyConfigServiceWin();
47 virtual ~ProxyConfigServiceWin();
49 // Overrides a function from PollingProxyConfigService.
50 virtual void AddObserver(Observer
* observer
) OVERRIDE
;
53 FRIEND_TEST_ALL_PREFIXES(ProxyConfigServiceWinTest
, SetFromIEConfig
);
55 typedef std::vector
<KeyEntry
*> KeyEntryList
;
57 // Registers change observers on the registry keys relating to proxy settings.
58 void StartWatchingRegistryForChanges();
60 // Creates a new KeyEntry and appends it to |keys_to_watch_|. If the key
61 // fails to be created, it is not appended to the list and we return false.
62 bool AddKeyToWatchList(HKEY rootkey
, const wchar_t* subkey
);
64 // ObjectWatcher::Delegate methods:
65 // This is called whenever one of the registry keys we are watching change.
66 virtual void OnObjectSignaled(HANDLE object
) OVERRIDE
;
68 static void GetCurrentProxyConfig(ProxyConfig
* config
);
70 // Set |config| using the proxy configuration values of |ie_config|.
71 static void SetFromIEConfig(
73 const WINHTTP_CURRENT_USER_IE_PROXY_CONFIG
& ie_config
);
75 KeyEntryList keys_to_watch_
;
80 #endif // NET_PROXY_PROXY_CONFIG_SERVICE_WIN_H_