athena: Re-add ui_chromeos resources in athena_resources.pak.
[chromium-blink-merge.git] / chromeos / network / network_state.h
blob90b78cd954921ab38c2c6c8eaebf907a3b59a39c
1 // Copyright (c) 2012 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 CHROMEOS_NETWORK_NETWORK_STATE_H_
6 #define CHROMEOS_NETWORK_NETWORK_STATE_H_
8 #include <string>
9 #include <vector>
11 #include "base/values.h"
12 #include "chromeos/network/managed_state.h"
13 #include "components/onc/onc_constants.h"
14 #include "url/gurl.h"
16 namespace base {
17 class DictionaryValue;
18 class Value;
21 namespace chromeos {
23 // Simple class to provide network state information about a network service.
24 // This class should always be passed as a const* and should never be held
25 // on to. Store network_state->path() (defined in ManagedState) instead and
26 // call NetworkStateHandler::GetNetworkState(path) to retrieve the state for
27 // the network.
29 // Note: NetworkStateHandler will store an entry for each member of
30 // Manager.ServiceCompleteList. The visible() method indicates whether the
31 // network is visible, and the IsInProfile() method indicates whether the
32 // network is saved in a profile.
33 class CHROMEOS_EXPORT NetworkState : public ManagedState {
34 public:
35 explicit NetworkState(const std::string& path);
36 virtual ~NetworkState();
38 // ManagedState overrides
39 // If you change this method, update GetProperties too.
40 virtual bool PropertyChanged(const std::string& key,
41 const base::Value& value) OVERRIDE;
42 virtual bool InitialPropertiesReceived(
43 const base::DictionaryValue& properties) OVERRIDE;
44 virtual void GetStateProperties(
45 base::DictionaryValue* dictionary) const OVERRIDE;
47 void IPConfigPropertiesChanged(const base::DictionaryValue& properties);
49 // Returns true, if the network requires a service activation.
50 bool RequiresActivation() const;
52 // Accessors
53 bool visible() const { return visible_; }
54 const std::string& security() const { return security_; }
55 const std::string& device_path() const { return device_path_; }
56 const std::string& guid() const { return guid_; }
57 const std::string& profile_path() const { return profile_path_; }
58 const std::string& error() const { return error_; }
59 const std::string& last_error() const { return last_error_; }
60 void clear_last_error() { last_error_.clear(); }
62 // Returns |connection_state_| if visible, kStateDisconnect otherwise.
63 std::string connection_state() const;
65 const base::DictionaryValue& proxy_config() const { return proxy_config_; }
67 // IPConfig Properties. These require an extra call to ShillIPConfigClient,
68 // so cache them to avoid excessively complex client code.
69 const std::string& ip_address() const { return ip_address_; }
70 const std::string& gateway() const { return gateway_; }
71 const std::vector<std::string>& dns_servers() const { return dns_servers_; }
72 const GURL& web_proxy_auto_discovery_url() const {
73 return web_proxy_auto_discovery_url_;
76 // Wireless property accessors
77 bool connectable() const { return connectable_; }
78 int signal_strength() const { return signal_strength_; }
80 // Wifi property accessors
81 const std::string& eap_method() const { return eap_method_; }
83 // Cellular property accessors
84 const std::string& network_technology() const {
85 return network_technology_;
87 const std::string& activation_state() const { return activation_state_; }
88 const std::string& roaming() const { return roaming_; }
89 bool activate_over_non_cellular_networks() const {
90 return activate_over_non_cellular_networks_;
92 bool cellular_out_of_credits() const { return cellular_out_of_credits_; }
94 // Whether this network has a CACertNSS nickname set.
95 bool HasCACertNSS() const { return has_ca_cert_nss_; }
97 // Returns true if |connection_state_| is a connected/connecting state.
98 bool IsConnectedState() const;
99 bool IsConnectingState() const;
101 // Returns true if this is a network stored in a profile.
102 bool IsInProfile() const;
104 // Returns true if the network properties are stored in a user profile.
105 bool IsPrivate() const;
107 // Returns a comma separated string of name servers.
108 std::string GetDnsServersAsString() const;
110 // Converts the prefix length to a netmask string.
111 std::string GetNetmask() const;
113 // Returns a specifier for identifying this network in the absence of a GUID.
114 // This should only be used by NetworkStateHandler for keeping track of
115 // GUIDs assigned to unsaved networks.
116 std::string GetSpecifier() const;
118 // Set the GUID. Called exclusively by NetworkStateHandler.
119 void SetGuid(const std::string& guid);
121 // Helpers (used e.g. when a state or error is cached)
122 static bool StateIsConnected(const std::string& connection_state);
123 static bool StateIsConnecting(const std::string& connection_state);
124 static bool ErrorIsValid(const std::string& error);
126 private:
127 friend class MobileActivatorTest;
128 friend class NetworkStateHandler;
129 friend class NetworkChangeNotifierChromeosUpdateTest;
131 // Updates |name_| from WiFi.HexSSID if provided, and validates |name_|.
132 // Returns true if |name_| changes.
133 bool UpdateName(const base::DictionaryValue& properties);
135 // Set to true if the network is a member of Manager.Services.
136 bool visible_;
138 // Network Service properties. Avoid adding any additional properties here.
139 // Instead use NetworkConfigurationHandler::GetProperties() to asynchronously
140 // request properties from Shill.
141 std::string security_;
142 std::string eap_method_; // Needed for WiFi EAP networks
143 std::string device_path_;
144 std::string guid_;
145 std::string connection_state_;
146 std::string profile_path_;
147 bool connectable_;
149 // Reflects the current Shill Service.Error property. This might get cleared
150 // by Shill shortly after a failure.
151 std::string error_;
153 // Last non empty Service.Error property. Cleared by NetworkConnectionHandler
154 // when a connection attempt is initiated.
155 std::string last_error_;
157 // IPConfig properties.
158 // Note: These do not correspond to actual Shill.Service properties
159 // but are derived from the service's corresponding IPConfig object.
160 std::string ip_address_;
161 std::string gateway_;
162 std::vector<std::string> dns_servers_;
163 int prefix_length_; // Used by GetNetmask()
164 GURL web_proxy_auto_discovery_url_;
166 // Wireless properties, used for icons and Connect logic.
167 int signal_strength_;
169 // Cellular properties, used for icons, Connect, and Activation.
170 std::string network_technology_;
171 std::string activation_state_;
172 std::string roaming_;
173 bool activate_over_non_cellular_networks_;
174 bool cellular_out_of_credits_;
176 // Whether a deprecated CaCertNSS property of this network is set. Required
177 // for migration to PEM.
178 bool has_ca_cert_nss_;
180 // TODO(pneubeck): Remove this once (Managed)NetworkConfigurationHandler
181 // provides proxy configuration. crbug.com/241775
182 base::DictionaryValue proxy_config_;
184 DISALLOW_COPY_AND_ASSIGN(NetworkState);
187 } // namespace chromeos
189 #endif // CHROMEOS_NETWORK_NETWORK_STATE_H_