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_H_
6 #define NET_PROXY_PROXY_CONFIG_SERVICE_H_
8 #include "net/base/net_export.h"
14 // Service for watching when the proxy settings have changed.
15 class NET_EXPORT ProxyConfigService
{
17 // Indicates whether proxy configuration is valid, and if not, why.
18 enum ConfigAvailability
{
19 // Configuration is pending, observers will be notified later.
21 // Configuration is present and valid.
23 // No configuration is set.
27 // Observer for being notified when the proxy settings have changed.
28 class NET_EXPORT Observer
{
30 virtual ~Observer() {}
31 // Notification callback that should be invoked by ProxyConfigService
32 // implementors whenever the configuration changes. |availability| indicates
33 // the new availability status and can be CONFIG_UNSET or CONFIG_VALID (in
34 // which case |config| contains the configuration). Implementors must not
35 // pass CONFIG_PENDING.
36 virtual void OnProxyConfigChanged(const ProxyConfig
& config
,
37 ConfigAvailability availability
) = 0;
40 virtual ~ProxyConfigService() {}
42 // Adds/Removes an observer that will be called whenever the proxy
43 // configuration has changed.
44 virtual void AddObserver(Observer
* observer
) = 0;
45 virtual void RemoveObserver(Observer
* observer
) = 0;
47 // Gets the most recent availability status. If a configuration is present,
48 // the proxy configuration is written to |config| and CONFIG_VALID is
49 // returned. Returns CONFIG_PENDING if it is not available yet. In this case,
50 // it is guaranteed that subscribed observers will be notified of a change at
51 // some point in the future once the configuration is available.
52 // Note that to avoid re-entrancy problems, implementations should not
53 // dispatch any change notifications from within this function.
54 virtual ConfigAvailability
GetLatestProxyConfig(ProxyConfig
* config
) = 0;
56 // ProxyService will call this periodically during periods of activity.
57 // It can be used as a signal for polling-based implementations.
59 // Note that this is purely used as an optimization -- polling
60 // implementations could simply set a global timer that goes off every
61 // X seconds at which point they check for changes. However that has
62 // the disadvantage of doing continuous work even during idle periods.
63 virtual void OnLazyPoll() {}
68 #endif // NET_PROXY_PROXY_CONFIG_SERVICE_H_