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_
11 #include "chromeos/network/managed_state.h"
12 #include "chromeos/network/network_ui_data.h"
13 #include "components/onc/onc_constants.h"
17 class DictionaryValue
;
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
28 class CHROMEOS_EXPORT NetworkState
: public ManagedState
{
30 explicit NetworkState(const std::string
& path
);
31 virtual ~NetworkState();
33 // ManagedState overrides
34 // If you change this method, update GetProperties too.
35 virtual bool PropertyChanged(const std::string
& key
,
36 const base::Value
& value
) OVERRIDE
;
37 virtual bool InitialPropertiesReceived(
38 const base::DictionaryValue
& properties
) OVERRIDE
;
40 // Fills |dictionary| with the state properties. All the properties that are
41 // accepted by PropertyChanged are stored in |dictionary|, no other values are
43 void GetProperties(base::DictionaryValue
* dictionary
) const;
45 // Returns true, if the network requires a service activation.
46 bool RequiresActivation() const;
49 const std::string
& security() const { return security_
; }
50 const std::string
& eap_method() const { return eap_method_
; }
51 const std::string
& device_path() const { return device_path_
; }
52 const std::string
& guid() const { return guid_
; }
53 const std::string
& connection_state() const { return connection_state_
; }
54 const std::string
& profile_path() const { return profile_path_
; }
55 const std::string
& error() const { return error_
; }
56 bool connectable() const { return connectable_
; }
58 const NetworkUIData
& ui_data() const { return ui_data_
; }
60 // IPConfig Properties. These require an extra call to ShillIPConfigClient,
61 // so cache them to avoid excessively complex client code.
62 const std::string
& ip_address() const { return ip_address_
; }
63 const std::string
& gateway() const { return gateway_
; }
64 const std::vector
<std::string
>& dns_servers() const { return dns_servers_
; }
65 const GURL
& web_proxy_auto_discovery_url() const {
66 return web_proxy_auto_discovery_url_
;
69 // Wireless property accessors
70 int signal_strength() const { return signal_strength_
; }
72 // Cellular property accessors
73 const std::string
& network_technology() const {
74 return network_technology_
;
76 const std::string
& activation_state() const { return activation_state_
; }
77 const std::string
& roaming() const { return roaming_
; }
78 bool activate_over_non_cellular_networks() const {
79 return activate_over_non_cellular_networks_
;
81 bool cellular_out_of_credits() const { return cellular_out_of_credits_
; }
83 // Whether this network has a CACertNSS nickname set.
84 bool HasCACertNSS() const { return has_ca_cert_nss_
; }
86 // Returns true if |connection_state_| is a connected/connecting state.
87 bool IsConnectedState() const;
88 bool IsConnectingState() const;
90 // Returns true if the network properties are stored in a user profile.
91 bool IsPrivate() const;
93 // Returns a comma separated string of name servers.
94 std::string
GetDnsServersAsString() const;
96 // Converts the prefix length to a netmask string.
97 std::string
GetNetmask() const;
99 // Helpers (used e.g. when a state is cached)
100 static bool StateIsConnected(const std::string
& connection_state
);
101 static bool StateIsConnecting(const std::string
& connection_state
);
103 // Helper to return a full prefixed version of an IPConfig property key.
104 static std::string
IPConfigProperty(const char* key
);
108 friend class MobileActivatorTest
;
109 friend class NetworkStateHandler
;
110 friend class NetworkChangeNotifierChromeosUpdateTest
;
112 // Updates |name_| from WiFi.HexSSID if provided, and validates |name_|.
113 // Returns true if |name_| changes.
114 bool UpdateName(const base::DictionaryValue
& properties
);
116 // Network Service properties. Avoid adding any additional properties here.
117 // Instead use NetworkConfigurationHandler::GetProperties() to asynchronously
118 // request properties from Shill.
119 std::string security_
;
120 std::string eap_method_
; // Needed for WiFi EAP networks
121 std::string device_path_
;
123 std::string connection_state_
;
124 std::string profile_path_
;
128 // This is convenient to keep cached for now, but shouldn't be necessary;
129 // avoid using it if possible.
130 NetworkUIData ui_data_
;
132 // IPConfig properties.
133 // Note: These do not correspond to actual Shill.Service properties
134 // but are derived from the service's corresponding IPConfig object.
135 std::string ip_address_
;
136 std::string gateway_
;
137 std::vector
<std::string
> dns_servers_
;
138 int prefix_length_
; // Used by GetNetmask()
139 GURL web_proxy_auto_discovery_url_
;
141 // Wireless properties, used for icons and Connect logic.
142 int signal_strength_
;
144 // Cellular properties, used for icons, Connect, and Activation.
145 std::string network_technology_
;
146 std::string activation_state_
;
147 std::string roaming_
;
148 bool activate_over_non_cellular_networks_
;
149 bool cellular_out_of_credits_
;
151 // Whether a deprecated CaCertNSS property of this network is set. Required
152 // for migration to PEM.
153 bool has_ca_cert_nss_
;
155 DISALLOW_COPY_AND_ASSIGN(NetworkState
);
158 } // namespace chromeos
160 #endif // CHROMEOS_NETWORK_NETWORK_STATE_H_