blob: 0d86f7f566cc32332a9c89e88b79d0b336ced607 [file] [log] [blame]
mukesh agrawal8a3188d2011-12-01 20:56:44 +00001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Paul Stewart75897df2011-04-27 09:05:53 -07002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
Darin Petkov002c58e2012-06-19 02:56:05 +02005#ifndef SHILL_MANAGER_H_
6#define SHILL_MANAGER_H_
Paul Stewart75897df2011-04-27 09:05:53 -07007
Darin Petkova5e07ef2012-07-09 14:27:57 +02008#include <map>
Chris Masone9be4a9d2011-05-16 15:44:09 -07009#include <string>
Paul Stewart75897df2011-04-27 09:05:53 -070010#include <vector>
Chris Masone487b8bf2011-05-13 16:27:57 -070011
Paul Stewartdfa46052012-06-26 09:44:14 -070012#include <base/cancelable_callback.h>
Paul Stewarte6132022011-08-16 09:11:02 -070013#include <base/file_path.h>
Chris Masone9be4a9d2011-05-16 15:44:09 -070014#include <base/memory/ref_counted.h>
Chris Masone487b8bf2011-05-13 16:27:57 -070015#include <base/memory/scoped_ptr.h>
Eric Shienbrood3e20a232012-02-16 11:35:56 -050016#include <base/memory/weak_ptr.h>
Chris Masone88cbd5f2011-07-03 14:30:04 -070017#include <chromeos/dbus/service_constants.h>
Liam McLoughlin0fec81c2013-02-28 10:31:47 -050018#include <base/gtest_prod_util.h> // for FRIEND_TEST_ALL_PREFIXES
Paul Stewart22aa71b2011-09-16 12:15:11 -070019#include <gtest/gtest_prod.h> // for FRIEND_TEST
Paul Stewart75897df2011-04-27 09:05:53 -070020
Christopher Wiley1057cd72013-02-28 15:21:29 -080021#include "shill/crypto_util_proxy.h"
Paul Stewart75897df2011-04-27 09:05:53 -070022#include "shill/device.h"
Paul Stewart0af98bf2011-05-10 17:38:08 -070023#include "shill/device_info.h"
Paul Stewart26b327e2011-10-19 11:38:09 -070024#include "shill/event_dispatcher.h"
Gaurav Shahb790aa22012-10-23 12:51:12 -070025#include "shill/geolocation_info.h"
Gary Moraina9fb3252012-05-31 12:05:31 -070026#include "shill/hook_table.h"
Arman Ugurayab22c162012-10-08 19:08:38 -070027#include "shill/metrics.h"
Darin Petkov887f2982011-07-14 16:10:17 -070028#include "shill/modem_info.h"
Gary Morainac1bdb42012-02-16 17:42:29 -080029#include "shill/power_manager.h"
Paul Stewartf3eced92013-04-17 12:18:22 -070030#include "shill/profile.h"
Chris Masoneb925cc82011-06-22 15:39:57 -070031#include "shill/property_store.h"
Chris Masone9be4a9d2011-05-16 15:44:09 -070032#include "shill/service.h"
mukesh agrawal7a4e4002011-09-06 11:26:05 -070033#include "shill/wifi.h"
Darin Petkovb72b62e2012-05-15 16:55:36 +020034#include "shill/wimax_provider.h"
Paul Stewart75897df2011-04-27 09:05:53 -070035
36namespace shill {
37
Chris Masoned0ceb8c2011-06-02 10:05:39 -070038class ControlInterface;
Darin Petkov002c58e2012-06-19 02:56:05 +020039class DBusManager;
Paul Stewart4d5efb72012-09-17 12:24:34 -070040class DefaultProfile;
Chris Masone8fe2c7e2011-06-09 15:51:19 -070041class Error;
Paul Stewart35eff132013-04-12 12:08:40 -070042class EthernetEapProvider;
Chris Masoned0ceb8c2011-06-02 10:05:39 -070043class EventDispatcher;
Prathmesh Prabhuba99b592013-04-17 15:13:14 -070044class IPAddressStore;
Thieu Le3426c8f2012-01-11 17:35:11 -080045class ManagerAdaptorInterface;
Paul Stewart4d5efb72012-09-17 12:24:34 -070046class Resolver;
Paul Stewart85aea152013-01-22 09:31:56 -080047class StoreInterface;
Darin Petkovc3505a52013-03-18 15:13:29 +010048class VPNProvider;
Paul Stewart3c504012013-01-17 17:49:58 -080049class WiFiProvider;
Chris Masoned0ceb8c2011-06-02 10:05:39 -070050
Eric Shienbrood3e20a232012-02-16 11:35:56 -050051class Manager : public base::SupportsWeakPtr<Manager> {
Paul Stewart75897df2011-04-27 09:05:53 -070052 public:
Darin Petkova5e07ef2012-07-09 14:27:57 +020053 typedef base::Callback<void(const ServiceRefPtr &service)> ServiceCallback;
54
Chris Masone88cbd5f2011-07-03 14:30:04 -070055 struct Properties {
56 public:
Paul Stewartc681fa02012-03-02 19:40:04 -080057 Properties()
Paul Stewartd408fdf2012-05-07 17:15:57 -070058 : offline_mode(false),
59 portal_check_interval_seconds(0),
60 arp_gateway(true) {}
Chris Masone88cbd5f2011-07-03 14:30:04 -070061 bool offline_mode;
62 std::string check_portal_list;
63 std::string country;
Paul Stewartc681fa02012-03-02 19:40:04 -080064 int32 portal_check_interval_seconds;
Chris Masone88cbd5f2011-07-03 14:30:04 -070065 std::string portal_url;
Paul Stewartd32f4842012-01-11 16:08:13 -080066 std::string host_name;
Paul Stewartd408fdf2012-05-07 17:15:57 -070067 // Whether to ARP for the default gateway in the DHCP client after
68 // acquiring a lease.
69 bool arp_gateway;
Paul Stewart036dba02012-08-07 12:34:41 -070070 // Comma-separated list of technologies for which link-monitoring is
71 // enabled.
72 std::string link_monitor_technologies;
Paul Stewart4d5efb72012-09-17 12:24:34 -070073 // Comma-separated list of DNS search paths to be ignored.
74 std::string ignored_dns_search_paths;
Chris Masone88cbd5f2011-07-03 14:30:04 -070075 };
76
Chris Masone9be4a9d2011-05-16 15:44:09 -070077 Manager(ControlInterface *control_interface,
Darin Petkov887f2982011-07-14 16:10:17 -070078 EventDispatcher *dispatcher,
Thieu Le3426c8f2012-01-11 17:35:11 -080079 Metrics *metrics,
Chris Masone2ae797d2011-08-23 20:41:00 -070080 GLib *glib,
81 const std::string &run_directory,
82 const std::string &storage_directory,
83 const std::string &user_storage_format);
Chris Masone3bd3c8c2011-06-13 08:20:26 -070084 virtual ~Manager();
mukesh agrawal8f317b62011-07-15 11:53:23 -070085
86 void AddDeviceToBlackList(const std::string &device_name);
Gary Morainac1bdb42012-02-16 17:42:29 -080087
Thieu Lefb46caf2012-03-08 11:57:15 -080088 virtual void Start();
Thieu Le6c1e3bb2013-02-06 15:20:35 -080089 virtual void Stop();
Darin Petkovcb0b5662012-12-13 09:59:44 +010090 bool running() const { return running_; }
Paul Stewart75897df2011-04-27 09:05:53 -070091
Paul Stewart1b253142012-01-26 14:05:52 -080092 const ProfileRefPtr &ActiveProfile() const;
93 bool IsActiveProfile(const ProfileRefPtr &profile) const;
Chris Masone6515aab2011-10-12 16:19:09 -070094 bool MoveServiceToProfile(const ServiceRefPtr &to_move,
95 const ProfileRefPtr &destination);
Paul Stewart7f61e522012-03-22 11:13:45 -070096 ProfileRefPtr LookupProfileByRpcIdentifier(const std::string &profile_rpcid);
Chris Masone7aa5f902011-07-11 11:13:35 -070097
Paul Stewart1b1a7f22012-01-06 16:24:06 -080098 // Called via RPC call on Service (|to_set|) to set the "Profile" property.
Paul Stewartad0e5982013-07-02 08:47:47 -070099 virtual void SetProfileForService(const ServiceRefPtr &to_set,
100 const std::string &profile,
101 Error *error);
Paul Stewart1b1a7f22012-01-06 16:24:06 -0800102
Paul Stewart8c116a92012-05-02 18:30:03 -0700103 virtual void RegisterDevice(const DeviceRefPtr &to_manage);
104 virtual void DeregisterDevice(const DeviceRefPtr &to_forget);
Chris Masone9be4a9d2011-05-16 15:44:09 -0700105
mukesh agrawal4eb4d782011-12-05 17:34:37 +0000106 virtual bool HasService(const ServiceRefPtr &service);
mukesh agrawal8a3188d2011-12-01 20:56:44 +0000107 // Register a Service with the Manager. Manager may choose to
108 // connect to it immediately.
mukesh agrawal32399322011-09-01 10:53:43 -0700109 virtual void RegisterService(const ServiceRefPtr &to_manage);
mukesh agrawal8a3188d2011-12-01 20:56:44 +0000110 // Deregister a Service from the Manager. Caller is responsible
111 // for disconnecting the Service before-hand.
Chris Masone6515aab2011-10-12 16:19:09 -0700112 virtual void DeregisterService(const ServiceRefPtr &to_forget);
mukesh agrawal00917ce2011-11-22 23:56:55 +0000113 virtual void UpdateService(const ServiceRefPtr &to_update);
Chris Masone9be4a9d2011-05-16 15:44:09 -0700114
Darin Petkove7c6ad32012-06-29 10:22:09 +0200115 // Persists |to_update| into an appropriate profile.
116 virtual void UpdateDevice(const DeviceRefPtr &to_update);
117
Wade Guthrie60a37062013-04-02 11:39:09 -0700118 virtual void UpdateWiFiProvider();
119
Paul Stewartfdd16072011-09-16 12:41:35 -0700120 void FilterByTechnology(Technology::Identifier tech,
Paul Stewart3c504012013-01-17 17:49:58 -0800121 std::vector<DeviceRefPtr> *found) const;
Chris Masone9be4a9d2011-05-16 15:44:09 -0700122
Chris Masonee0dea762011-06-09 09:06:03 -0700123 ServiceRefPtr FindService(const std::string& name);
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800124 std::vector<std::string> EnumerateAvailableServices(Error *error);
Chris Masone9be4a9d2011-05-16 15:44:09 -0700125
Paul Stewart3c504012013-01-17 17:49:58 -0800126 // Return the complete list of services, including those that are not visible.
127 std::vector<std::string> EnumerateCompleteServices(Error *error);
128
mukesh agrawal32399322011-09-01 10:53:43 -0700129 // called via RPC (e.g., from ManagerDBusAdaptor)
Paul Stewart967eaeb2013-04-25 19:53:07 -0700130 std::map<std::string, std::string> GetLoadableProfileEntriesForService(
131 const ServiceConstRefPtr &service);
Darin Petkovb65c2452012-02-23 15:17:06 +0100132 ServiceRefPtr GetService(const KeyValueStore &args, Error *error);
Paul Stewart7f5ad572012-06-04 15:18:54 -0700133 ServiceRefPtr ConfigureService(const KeyValueStore &args, Error *error);
Paul Stewartd2e1c362013-03-03 19:06:07 -0800134 ServiceRefPtr ConfigureServiceForProfile(
135 const std::string &profile_rpcid,
136 const KeyValueStore &args,
137 Error *error);
Paul Stewart7a20aa42013-01-17 12:21:41 -0800138 ServiceRefPtr FindMatchingService(const KeyValueStore &args, Error *error);
Gaurav Shahb790aa22012-10-23 12:51:12 -0700139 std::map<std::string, GeolocationInfos> GetNetworksForGeolocation();
Paul Stewart39db5ca2013-03-18 14:15:17 -0700140 void ConnectToBestServices(Error *error);
Paul Stewart7f61e522012-03-22 11:13:45 -0700141
Paul Stewartc681fa02012-03-02 19:40:04 -0800142 // Request portal detection checks on each registered device until a portal
143 // detection attempt starts on one of them.
144 void RecheckPortal(Error *error);
Paul Stewartd215af62012-04-24 23:25:50 -0700145 // Request portal detection be restarted on the device connected to
146 // |service|.
147 virtual void RecheckPortalOnService(const ServiceRefPtr &service);
148
Wade Guthrie68d41092013-04-02 12:56:02 -0700149 virtual void RequestScan(Device::ScanType scan_type,
150 const std::string &technology, Error *error);
Paul Stewart22aa71b2011-09-16 12:15:11 -0700151 std::string GetTechnologyOrder();
152 void SetTechnologyOrder(const std::string &order, Error *error);
Gaurav Shah71354762011-11-28 19:22:49 -0800153 // Set up the profile list starting with a default profile along with
154 // an (optional) list of startup profiles.
155 void InitializeProfiles();
Paul Stewart19c871d2011-12-15 16:10:13 -0800156 // Create a profile. This does not affect the profile stack. Returns
157 // the RPC path of the created profile in |path|.
158 void CreateProfile(const std::string &name, std::string *path, Error *error);
Paul Stewart5dc40aa2011-10-28 19:43:43 -0700159 // Pushes existing profile with name |name| onto stack of managed profiles.
Paul Stewart19c871d2011-12-15 16:10:13 -0800160 // Returns the RPC path of the pushed profile in |path|.
161 void PushProfile(const std::string &name, std::string *path, Error *error);
Paul Stewartf3eced92013-04-17 12:18:22 -0700162 // Insert an existing user profile with name |name| into the stack of
163 // managed profiles. Associate |user_hash| with this profile entry.
164 // Returns the RPC path of the pushed profile in |path|.
165 void InsertUserProfile(const std::string &name,
166 const std::string &user_hash,
167 std::string *path,
168 Error *error);
Paul Stewart5dc40aa2011-10-28 19:43:43 -0700169 // Pops profile named |name| off the top of the stack of managed profiles.
170 void PopProfile(const std::string &name, Error *error);
171 // Remove the active profile.
172 void PopAnyProfile(Error *error);
Paul Stewart307c2502013-03-23 12:32:10 -0700173 // Remove all user profiles from the stack of managed profiles leaving only
174 // default profiles.
175 void PopAllUserProfiles(Error *error);
Paul Stewarte73d05c2012-03-29 16:26:05 -0700176 // Remove the underlying persistent storage for a profile.
177 void RemoveProfile(const std::string &name, Error *error);
Paul Stewart75225512012-01-26 22:51:33 -0800178 // Handle the event where a profile is about to remove a profile entry.
179 // Any Services that are dependent on this storage identifier will need
180 // to find new profiles. Return true if any service has been moved to a new
181 // profile. Any such services will have had the profile group removed from
182 // the profile.
183 virtual bool HandleProfileEntryDeletion(const ProfileRefPtr &profile,
184 const std::string &entry_name);
Paul Stewart13ed2252012-03-21 12:52:46 -0700185 // Find a registered service that contains a GUID property that
186 // matches |guid|.
187 virtual ServiceRefPtr GetServiceWithGUID(const std::string &guid,
188 Error *error);
Paul Stewart0756db92012-01-27 08:34:47 -0800189 // Find a service that is both the member of |profile| and has a
190 // storage identifier that matches |entry_name|. This function is
191 // called by the Profile in order to return a profile entry's properties.
192 virtual ServiceRefPtr GetServiceWithStorageIdentifier(
193 const ProfileRefPtr &profile,
194 const std::string &entry_name,
195 Error *error);
Paul Stewarte2bad7c2012-03-14 08:55:33 -0700196 // Return a reference to the Service associated with the default connection.
197 // If there is no such connection, this function returns a reference to NULL.
198 virtual ServiceRefPtr GetDefaultService() const;
Paul Stewart0756db92012-01-27 08:34:47 -0800199
Eric Shienbrood9a245532012-03-07 14:20:39 -0500200 // Enable all devices for the named technology.
201 void EnableTechnology(const std::string &technology_name,
202 Error *error,
203 const ResultCallback &callback);
204 // Disable all devices for the named technology.
205 void DisableTechnology(const std::string &technology_name,
206 Error *error,
207 const ResultCallback &callback);
Paul Stewart20088d82012-02-16 06:58:55 -0800208 // Return whether a technology is marked as enabled for portal detection.
209 virtual bool IsPortalDetectionEnabled(Technology::Identifier tech);
Paul Stewart10e9e4e2012-04-26 19:46:28 -0700210 // Set the start-up value for the portal detection list. This list will
211 // be used until a value set explicitly over the control API. Until
212 // then, we ignore but do not overwrite whatever value is stored in the
213 // profile.
214 void SetStartupPortalList(const std::string &portal_list);
Paul Stewart20088d82012-02-16 06:58:55 -0800215
Paul Stewartd2e1c362013-03-03 19:06:07 -0800216 // Returns true if profile |a| has been pushed on the Manager's
217 // |profiles_| stack before profile |b|.
218 bool IsProfileBefore(const ProfileRefPtr &a,
219 const ProfileRefPtr &b) const;
220
Paul Stewart10ccbb32012-04-26 15:59:30 -0700221 // Return whether a service belongs to the ephemeral profile.
222 virtual bool IsServiceEphemeral(const ServiceConstRefPtr &service) const;
223
Paul Stewart3c504012013-01-17 17:49:58 -0800224 // Return whether a Technology has any connected Services.
225 virtual bool IsTechnologyConnected(Technology::Identifier technology) const;
226
Paul Stewart036dba02012-08-07 12:34:41 -0700227 // Return whether a technology is enabled for link monitoring.
228 virtual bool IsTechnologyLinkMonitorEnabled(
229 Technology::Identifier technology) const;
230
Paul Stewart3c504012013-01-17 17:49:58 -0800231 // Called by Profile when a |storage| completes initialization.
232 void OnProfileStorageInitialized(StoreInterface *storage);
233
234 // Return a Device with technology |technology| in the enabled state.
235 DeviceRefPtr GetEnabledDeviceWithTechnology(
236 Technology::Identifier technology) const;
Paul Stewart85aea152013-01-22 09:31:56 -0800237
Darin Petkov4cbff5b2013-01-29 16:29:05 +0100238 // Returns true if at least one connection exists, and false if there's no
239 // connected service.
240 virtual bool IsOnline() const;
Paul Stewart38fd24c2012-04-25 14:06:29 -0700241 std::string CalculateState(Error *error);
242
Paul Stewartc681fa02012-03-02 19:40:04 -0800243 virtual int GetPortalCheckInterval() const {
244 return props_.portal_check_interval_seconds;
245 }
Paul Stewart20088d82012-02-16 06:58:55 -0800246 virtual const std::string &GetPortalCheckURL() const {
247 return props_.portal_url;
248 }
mukesh agrawal32399322011-09-01 10:53:43 -0700249
Darin Petkov2b8e44e2012-06-25 15:13:26 +0200250 DBusManager *dbus_manager() const { return dbus_manager_.get(); }
Chris Masone626719f2011-08-18 16:58:48 -0700251 virtual DeviceInfo *device_info() { return &device_info_; }
Paul Stewart8c116a92012-05-02 18:30:03 -0700252 virtual ModemInfo *modem_info() { return &modem_info_; }
Darin Petkovcb0b5662012-12-13 09:59:44 +0100253 PowerManager *power_manager() const { return power_manager_.get(); }
Paul Stewart35eff132013-04-12 12:08:40 -0700254 virtual EthernetEapProvider *ethernet_eap_provider() const {
255 return ethernet_eap_provider_.get();
256 }
Darin Petkovc3505a52013-03-18 15:13:29 +0100257 VPNProvider *vpn_provider() const { return vpn_provider_.get(); }
258 WiFiProvider *wifi_provider() const { return wifi_provider_.get(); }
Darin Petkovb72b62e2012-05-15 16:55:36 +0200259 virtual WiMaxProvider *wimax_provider() { return &wimax_provider_; }
mukesh agrawalde29fa82011-09-16 16:16:36 -0700260 PropertyStore *mutable_store() { return &store_; }
261 virtual const PropertyStore &store() const { return store_; }
Darin Petkov36a3ace2012-03-06 17:22:14 +0100262 GLib *glib() const { return glib_; }
Albert Chaulk0e1cdea2013-02-27 15:32:55 -0800263 virtual const base::FilePath &run_path() const { return run_path_; }
264 const base::FilePath &storage_path() const { return storage_path_; }
Prathmesh Prabhuba99b592013-04-17 15:13:14 -0700265 IPAddressStore * health_checker_remote_ips() const {
266 return health_checker_remote_ips_.get();
267 }
Chris Masoneb925cc82011-06-22 15:39:57 -0700268
Paul Stewartd408fdf2012-05-07 17:15:57 -0700269 bool GetArpGateway() const { return props_.arp_gateway; }
270 const std::string &GetHostName() const { return props_.host_name; }
Chris Masone877ff982011-09-21 16:18:24 -0700271
Daniel Erat0818cca2012-12-14 10:16:21 -0800272 int suspend_delay_id_for_testing() const { return suspend_delay_id_; }
273
Eric Shienbrood9a245532012-03-07 14:20:39 -0500274 virtual void UpdateEnabledTechnologies();
Ben Chan5086b972013-01-15 21:51:38 -0800275 virtual void UpdateUninitializedTechnologies();
Gary Morainac1bdb42012-02-16 17:42:29 -0800276
Gary Moraind93615e2012-04-27 11:50:03 -0700277 // Writes the service |to_update| to persistant storage. If the service's is
278 // ephemeral, it is moved to the current profile.
279 void SaveServiceToProfile(const ServiceRefPtr &to_update);
280
Gary Moraina9fb3252012-05-31 12:05:31 -0700281 // Adds a closure to be executed when ChromeOS suspends or shill terminates.
282 // |name| should be unique; otherwise, a previous closure by the same name
283 // will be replaced. |start| will be called when RunTerminationActions() is
284 // called. When an action completed, TerminationActionComplete() must be
285 // called.
286 void AddTerminationAction(const std::string &name,
287 const base::Closure &start);
288
289 // Users call this function to report the completion of an action |name|.
290 // This function should be called once for each action.
291 void TerminationActionComplete(const std::string &name);
292
293 // Removes the action associtated with |name|.
294 void RemoveTerminationAction(const std::string &name);
295
Arman Ugurayab22c162012-10-08 19:08:38 -0700296 // Runs the termination actions and notifies the metrics framework
297 // that the termination actions started running, only if any termination
298 // actions have been registered. |reason| specifies whether this method was
299 // called due to termination or suspend. If all actions complete within
Darin Petkov3ec55342012-09-28 14:04:44 +0200300 // |kTerminationActionsTimeoutMilliseconds|, |done| is called with a value of
Arman Ugurayab22c162012-10-08 19:08:38 -0700301 // Error::kSuccess. Otherwise, it is called with Error::kOperationTimeout.
302 //
303 // Returns true, if termination actions were run.
304 bool RunTerminationActionsAndNotifyMetrics(
305 const base::Callback<void(const Error &)> &done,
306 Metrics::TerminationActionReason reason);
Gary Moraina9fb3252012-05-31 12:05:31 -0700307
Darin Petkova5e07ef2012-07-09 14:27:57 +0200308 // Registers a |callback| that's invoked whenever the default service
309 // changes. Returns a unique tag that can be used to deregister the
310 // callback. A tag equal to 0 is invalid.
311 virtual int RegisterDefaultServiceCallback(const ServiceCallback &callback);
312 virtual void DeregisterDefaultServiceCallback(int tag);
313
Christopher Wiley0d9cf0c2013-02-19 19:24:57 -0800314 // Verifies that the destination described by certificate is valid, and that
315 // we're currently connected to that destination. A full description of the
316 // rules being enforced is in doc/manager-api.txt. Returns true iff all
317 // checks pass, false otherwise. On false, error is filled with a
318 // descriptive error code and message.
319 //
320 // |certificate| is a PEM encoded x509 certificate, |public_key| is a base64
321 // encoded public half of an RSA key, |nonce| is a random string, and
322 // |signed_data| is a base64 encoded string as described in
323 // doc/manager-api.txt.
324 void VerifyDestination(const std::string &certificate,
325 const std::string &public_key,
326 const std::string &nonce,
327 const std::string &signed_data,
328 const std::string &destination_udn,
Christopher Wileycdde79f2013-05-01 14:26:56 -0700329 const std::string &hotspot_ssid,
330 const std::string &hotspot_bssid,
Christopher Wiley0d9cf0c2013-02-19 19:24:57 -0800331 const ResultBoolCallback &cb,
332 Error *error);
333
334 // After verifying the destination, encrypt the string data with
335 // |public_key|, the base64 encoded public half of an RSA key pair. Returns
336 // the base64 encoded result if successful, or an empty string on failure.
337 // On failure, |error| will be filled with an appropriately descriptive
338 // message and error code.
339 void VerifyAndEncryptData(const std::string &certificate,
340 const std::string &public_key,
341 const std::string &nonce,
342 const std::string &signed_data,
343 const std::string &destination_udn,
Christopher Wileycdde79f2013-05-01 14:26:56 -0700344 const std::string &hotspot_ssid,
345 const std::string &hotspot_bssid,
Christopher Wiley0d9cf0c2013-02-19 19:24:57 -0800346 const std::string &data,
347 const ResultStringCallback &cb,
348 Error *error);
349
350 // After verifying the destination, encrypt the password for |network_path|
351 // under |public_key|. Similar to EncryptData above except that the
352 // information being encrypted is implicitly the authentication credentials
353 // of the given network.
354 void VerifyAndEncryptCredentials(const std::string &certificate,
355 const std::string &public_key,
356 const std::string &nonce,
357 const std::string &signed_data,
358 const std::string &destination_udn,
Christopher Wileycdde79f2013-05-01 14:26:56 -0700359 const std::string &hotspot_ssid,
360 const std::string &hotspot_bssid,
Christopher Wiley0d9cf0c2013-02-19 19:24:57 -0800361 const std::string &network_path,
362 const ResultStringCallback &cb,
363 Error *error);
364
Paul Stewart75897df2011-04-27 09:05:53 -0700365 private:
Arman Ugurayab22c162012-10-08 19:08:38 -0700366 friend class CellularTest;
Darin Petkovc3505a52013-03-18 15:13:29 +0100367 friend class DeviceInfoTest;
Darin Petkov6f9eaa32011-08-09 15:26:44 -0700368 friend class ManagerAdaptorInterface;
Paul Stewart22aa71b2011-09-16 12:15:11 -0700369 friend class ManagerTest;
Darin Petkovcb0b5662012-12-13 09:59:44 +0100370 friend class ServiceTest;
Darin Petkovc3505a52013-03-18 15:13:29 +0100371 friend class VPNServiceTest;
Paul Stewarte369ece2012-05-22 09:11:03 -0700372 friend class WiFiObjectTest;
Darin Petkovb501ad22012-07-03 12:50:52 +0200373 friend class WiMaxProviderTest;
Arman Ugurayab22c162012-10-08 19:08:38 -0700374
Liam McLoughlin0fec81c2013-02-28 10:31:47 -0500375 FRIEND_TEST_ALL_PREFIXES(CellularTest, ConnectAddsTerminationAction);
Arman Uguray32c76402012-11-27 14:01:13 -0800376 FRIEND_TEST(CellularTest, LinkEventWontDestroyService);
Gaurav Shah435de2c2011-11-17 19:01:07 -0800377 FRIEND_TEST(ManagerTest, AvailableTechnologies);
378 FRIEND_TEST(ManagerTest, ConnectedTechnologies);
Paul Stewart39db5ca2013-03-18 14:15:17 -0700379 FRIEND_TEST(ManagerTest, ConnectToBestServices);
Gaurav Shah435de2c2011-11-17 19:01:07 -0800380 FRIEND_TEST(ManagerTest, DefaultTechnology);
Paul Stewart1b253142012-01-26 14:05:52 -0800381 FRIEND_TEST(ManagerTest, DeviceRegistrationAndStart);
Darin Petkova5e07ef2012-07-09 14:27:57 +0200382 FRIEND_TEST(ManagerTest, DisableTechnology);
383 FRIEND_TEST(ManagerTest, EnableTechnology);
Paul Stewart1b253142012-01-26 14:05:52 -0800384 FRIEND_TEST(ManagerTest, EnumerateProfiles);
Paul Stewart65512e12012-03-26 18:01:08 -0700385 FRIEND_TEST(ManagerTest, HandleProfileEntryDeletionWithUnload);
mukesh agrawal00752532013-05-03 15:46:55 -0700386 FRIEND_TEST(ManagerTest, InitializeProfilesInformsProviders);
387 FRIEND_TEST(ManagerTest, InitializeProfilesHandlesDefaults);
Paul Stewart3c504012013-01-17 17:49:58 -0800388 FRIEND_TEST(ManagerTest, IsDefaultProfile);
Paul Stewart036dba02012-08-07 12:34:41 -0700389 FRIEND_TEST(ManagerTest, LinkMonitorEnabled);
Darin Petkova5e07ef2012-07-09 14:27:57 +0200390 FRIEND_TEST(ManagerTest, NotifyDefaultServiceChanged);
Paul Stewart65512e12012-03-26 18:01:08 -0700391 FRIEND_TEST(ManagerTest, PopProfileWithUnload);
Arman Ugurayab22c162012-10-08 19:08:38 -0700392 FRIEND_TEST(ManagerTest, RunTerminationActions);
Paul Stewart1b253142012-01-26 14:05:52 -0800393 FRIEND_TEST(ManagerTest, SortServices);
394 FRIEND_TEST(ManagerTest, SortServicesWithConnection);
Paul Stewart10e9e4e2012-04-26 19:46:28 -0700395 FRIEND_TEST(ManagerTest, StartupPortalList);
Darin Petkov6f9eaa32011-08-09 15:26:44 -0700396
Darin Petkovb65c2452012-02-23 15:17:06 +0100397 static const char kErrorNoDevice[];
398 static const char kErrorTypeRequired[];
399 static const char kErrorUnsupportedServiceType[];
400
Darin Petkov3ec55342012-09-28 14:04:44 +0200401 // Time to wait for termination actions to complete.
402 static const int kTerminationActionsTimeoutMilliseconds;
403
404 static const char kPowerManagerKey[];
405
mukesh agrawal8a3188d2011-12-01 20:56:44 +0000406 void AutoConnect();
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800407 std::vector<std::string> AvailableTechnologies(Error *error);
408 std::vector<std::string> ConnectedTechnologies(Error *error);
409 std::string DefaultTechnology(Error *error);
410 std::vector<std::string> EnabledTechnologies(Error *error);
Ben Chan5086b972013-01-15 21:51:38 -0800411 std::vector<std::string> UninitializedTechnologies(Error *error);
Paul Stewartcb3eb892012-06-07 14:24:46 -0700412 RpcIdentifiers EnumerateDevices(Error *error);
413 RpcIdentifiers EnumerateProfiles(Error *error);
Chris Masone6791a432011-07-12 13:23:19 -0700414 // TODO(cmasone): This should be implemented by filtering |services_|.
Paul Stewartcb3eb892012-06-07 14:24:46 -0700415 RpcIdentifiers EnumerateWatchedServices(Error *error);
Paul Stewart1b253142012-01-26 14:05:52 -0800416 std::string GetActiveProfileRpcIdentifier(Error *error);
Paul Stewart10e9e4e2012-04-26 19:46:28 -0700417 std::string GetCheckPortalList(Error *error);
Paul Stewart49739c02012-08-08 17:24:03 -0700418 RpcIdentifier GetDefaultServiceRpcIdentifier(Error *error);
Paul Stewart4d5efb72012-09-17 12:24:34 -0700419 std::string GetIgnoredDNSSearchPaths(Error *error);
Paul Stewart7f5ad572012-06-04 15:18:54 -0700420 ServiceRefPtr GetServiceInner(const KeyValueStore &args, Error *error);
mukesh agrawalbebf1b82013-04-23 15:06:33 -0700421 bool SetCheckPortalList(const std::string &portal_list, Error *error);
422 bool SetIgnoredDNSSearchPaths(const std::string &ignored_paths, Error *error);
Paul Stewart49739c02012-08-08 17:24:03 -0700423 void EmitDefaultService();
Paul Stewart036dba02012-08-07 12:34:41 -0700424 bool IsTechnologyInList(const std::string &technology_list,
425 Technology::Identifier tech) const;
Paul Stewart3c504012013-01-17 17:49:58 -0800426 bool IsDefaultProfile(StoreInterface *storage);
Eric Shienbrood8839a892012-03-29 10:33:48 -0400427 void EmitDeviceProperties();
Chris Masoneb925cc82011-06-22 15:39:57 -0700428
Paul Stewart65512e12012-03-26 18:01:08 -0700429 // Unload a service while iterating through |services_|. Returns true if
430 // service was erased (which means the caller loop should not increment
431 // |service_iterator|), false otherwise (meaning the caller should
432 // increment |service_iterator|).
433 bool UnloadService(std::vector<ServiceRefPtr>::iterator *service_iterator);
434
Paul Stewart4d5efb72012-09-17 12:24:34 -0700435 // Load Manager default properties from |profile|.
436 bool LoadProperties(const scoped_refptr<DefaultProfile> &profile);
437
Paul Stewart3c504012013-01-17 17:49:58 -0800438 // Configure the device with profile data from all current profiles.
439 void LoadDeviceFromProfiles(const DeviceRefPtr &device);
440
Paul Stewart49739c02012-08-08 17:24:03 -0700441 void HelpRegisterConstDerivedRpcIdentifier(
442 const std::string &name,
443 RpcIdentifier(Manager::*get)(Error *));
mukesh agrawal2366eed2012-03-20 18:21:50 -0700444 void HelpRegisterConstDerivedRpcIdentifiers(
445 const std::string &name,
446 RpcIdentifiers(Manager::*get)(Error *));
mukesh agrawalffa3d042011-10-06 15:26:10 -0700447 void HelpRegisterDerivedString(
448 const std::string &name,
Gaurav Shah1b7a6162011-11-09 11:41:01 -0800449 std::string(Manager::*get)(Error *),
mukesh agrawalbebf1b82013-04-23 15:06:33 -0700450 bool(Manager::*set)(const std::string&, Error *));
451 void HelpRegisterConstDerivedStrings(
mukesh agrawalffa3d042011-10-06 15:26:10 -0700452 const std::string &name,
mukesh agrawalbebf1b82013-04-23 15:06:33 -0700453 Strings(Manager::*get)(Error *));
Chris Masone27c4aa52011-07-02 13:10:14 -0700454
Paul Stewartf3eced92013-04-17 12:18:22 -0700455 bool HasProfile(const Profile::Identifier &ident);
456 void PushProfileInternal(const Profile::Identifier &ident,
457 std::string *path,
458 Error *error);
Paul Stewart5dc40aa2011-10-28 19:43:43 -0700459 void PopProfileInternal();
Paul Stewart78af94c2013-04-17 16:02:06 -0700460 void OnProfilesChanged();
461
Paul Stewart22aa71b2011-09-16 12:15:11 -0700462 void SortServices();
Paul Stewartdfa46052012-06-26 09:44:14 -0700463 void SortServicesTask();
Paul Stewart75225512012-01-26 22:51:33 -0800464 bool MatchProfileWithService(const ServiceRefPtr &service);
Paul Stewart22aa71b2011-09-16 12:15:11 -0700465
Paul Stewartd2e1c362013-03-03 19:06:07 -0800466 // Sets the profile of |service| to |profile|, without notifying its
467 // previous profile. Configures a |service| with |args|, then saves
468 // the resulting configuration to |profile|. This method is useful
469 // when copying a service configuration from one profile to another,
470 // or writing a newly created service config to a specific profile.
471 static void SetupServiceInProfile(ServiceRefPtr service,
472 ProfileRefPtr profile,
473 const KeyValueStore &args,
474 Error *error);
475
Paul Stewart39db5ca2013-03-18 14:15:17 -0700476 // For each technology present, connect to the "best" service available,
477 // as determined by sorting all services independent of their current state.
478 void ConnectToBestServicesTask();
479
Darin Petkova5e07ef2012-07-09 14:27:57 +0200480 void NotifyDefaultServiceChanged(const ServiceRefPtr &service);
481
Arman Ugurayab22c162012-10-08 19:08:38 -0700482 // Runs the termination actions. If all actions complete within
483 // |kTerminationActionsTimeoutMilliseconds|, |done| is called with a value of
484 // Error::kSuccess. Otherwise, it is called with Error::kOperationTimeout.
485 void RunTerminationActions(const base::Callback<void(const Error &)> &done);
486
Darin Petkovca621542012-07-25 14:25:56 +0200487 void OnPowerStateChanged(PowerManagerProxyDelegate::SuspendState power_state);
Daniel Erat0818cca2012-12-14 10:16:21 -0800488 void OnSuspendImminent(int suspend_id);
Darin Petkov3ec55342012-09-28 14:04:44 +0200489
Daniel Erat0818cca2012-12-14 10:16:21 -0800490 void OnSuspendActionsComplete(int suspend_id, const Error &error);
Christopher Wiley1057cd72013-02-28 15:21:29 -0800491 void VerifyToEncryptLink(std::string public_key, std::string data,
492 ResultStringCallback cb, const Error &error,
493 bool success);
Darin Petkovca621542012-07-25 14:25:56 +0200494
Thieu Lea20cbc22012-01-09 22:01:43 +0000495 // For unit testing.
496 void set_metrics(Metrics *metrics) { metrics_ = metrics; }
497
Gary Morainac1bdb42012-02-16 17:42:29 -0800498 // Used by tests to set a mock PowerManager. Takes ownership of
499 // power_manager.
500 void set_power_manager(PowerManager *power_manager) {
501 power_manager_.reset(power_manager);
502 }
503
mukesh agrawal8a3188d2011-12-01 20:56:44 +0000504 EventDispatcher *dispatcher_;
Albert Chaulk0e1cdea2013-02-27 15:32:55 -0800505 const base::FilePath run_path_;
506 const base::FilePath storage_path_;
Chris Masone2ae797d2011-08-23 20:41:00 -0700507 const std::string user_storage_format_;
mukesh agrawald142fd62013-05-01 16:50:57 -0700508 base::FilePath user_profile_list_path_; // Changed in tests.
Paul Stewart0af98bf2011-05-10 17:38:08 -0700509 scoped_ptr<ManagerAdaptorInterface> adaptor_;
Darin Petkov002c58e2012-06-19 02:56:05 +0200510 scoped_ptr<DBusManager> dbus_manager_;
Paul Stewart0af98bf2011-05-10 17:38:08 -0700511 DeviceInfo device_info_;
Darin Petkov887f2982011-07-14 16:10:17 -0700512 ModemInfo modem_info_;
Paul Stewart35eff132013-04-12 12:08:40 -0700513 scoped_ptr<EthernetEapProvider> ethernet_eap_provider_;
Darin Petkovc3505a52013-03-18 15:13:29 +0100514 scoped_ptr<VPNProvider> vpn_provider_;
Paul Stewart3c504012013-01-17 17:49:58 -0800515 scoped_ptr<WiFiProvider> wifi_provider_;
Darin Petkovb72b62e2012-05-15 16:55:36 +0200516 WiMaxProvider wimax_provider_;
Paul Stewart4d5efb72012-09-17 12:24:34 -0700517 // Hold pointer to singleton Resolver instance for testing purposes.
518 Resolver *resolver_;
Paul Stewart75897df2011-04-27 09:05:53 -0700519 bool running_;
Paul Stewart5dc40aa2011-10-28 19:43:43 -0700520 // Used to facilitate unit tests which can't use RPC.
521 bool connect_profiles_to_rpc_;
Chris Masonec1e50412011-06-07 13:04:53 -0700522 std::vector<DeviceRefPtr> devices_;
Chris Masone6791a432011-07-12 13:23:19 -0700523 // We store Services in a vector, because we want to keep them sorted.
Gary Morain028545d2012-04-07 14:55:52 -0700524 // Services that are connected appear first in the vector. See
525 // Service::Compare() for details of the sorting criteria.
Chris Masonec1e50412011-06-07 13:04:53 -0700526 std::vector<ServiceRefPtr> services_;
Gaurav Shah71354762011-11-28 19:22:49 -0800527 // List of startup profile names to push on the profile stack on startup.
Chris Masone7aa5f902011-07-11 11:13:35 -0700528 std::vector<ProfileRefPtr> profiles_;
529 ProfileRefPtr ephemeral_profile_;
Chris Masone2ae797d2011-08-23 20:41:00 -0700530 ControlInterface *control_interface_;
Thieu Le3426c8f2012-01-11 17:35:11 -0800531 Metrics *metrics_;
Chris Masone2ae797d2011-08-23 20:41:00 -0700532 GLib *glib_;
Gary Morainac1bdb42012-02-16 17:42:29 -0800533 scoped_ptr<PowerManager> power_manager_;
Chris Masone3bd3c8c2011-06-13 08:20:26 -0700534
Paul Stewart22aa71b2011-09-16 12:15:11 -0700535 // The priority order of technologies
536 std::vector<Technology::Identifier> technology_order_;
537
Paul Stewart49739c02012-08-08 17:24:03 -0700538 // This is the last Service RPC Identifier for which we emitted a
539 // "DefaultService" signal for.
540 RpcIdentifier default_service_rpc_identifier_;
541
Paul Stewart10e9e4e2012-04-26 19:46:28 -0700542 // Manager can be optionally configured with a list of technologies to
543 // do portal detection on at startup. We need to keep track of that list
544 // as well as a flag that tells us whether we should continue using it
545 // instead of the configured portal list.
546 std::string startup_portal_list_;
547 bool use_startup_portal_list_;
548
Chris Masoneb925cc82011-06-22 15:39:57 -0700549 // Properties to be get/set via PropertyStore calls.
Chris Masone88cbd5f2011-07-03 14:30:04 -0700550 Properties props_;
Chris Masone27c4aa52011-07-02 13:10:14 -0700551 PropertyStore store_;
Gary Moraina9fb3252012-05-31 12:05:31 -0700552
Paul Stewartdfa46052012-06-26 09:44:14 -0700553 base::CancelableClosure sort_services_task_;
Darin Petkov3ec55342012-09-28 14:04:44 +0200554
555 // TODO(petkov): Currently this handles both terminate and suspend
556 // actions. Rename all relevant identifiers to capture this.
Gary Moraina9fb3252012-05-31 12:05:31 -0700557 HookTable termination_actions_;
Darin Petkova5e07ef2012-07-09 14:27:57 +0200558
Daniel Erat0818cca2012-12-14 10:16:21 -0800559 // Is a suspend delay currently registered with the power manager?
560 bool suspend_delay_registered_;
561
562 // If |suspend_delay_registered_| is true, contains the unique ID
563 // corresponding to the suspend delay.
564 int suspend_delay_id_;
565
Darin Petkova5e07ef2012-07-09 14:27:57 +0200566 // Maps tags to callbacks for monitoring default service changes.
567 std::map<int, ServiceCallback> default_service_callbacks_;
568 int default_service_callback_tag_;
Christopher Wiley1057cd72013-02-28 15:21:29 -0800569
570 // Delegate to handle destination verification operations for the manager.
571 scoped_ptr<CryptoUtilProxy> crypto_util_proxy_;
Prathmesh Prabhuba99b592013-04-17 15:13:14 -0700572
573 // Stores IP addresses of some remote hosts that accept port 80 TCP
574 // connections. ConnectionHealthChecker uses these IPs.
575 // The store resides in Manager so that it persists across Device reset.
576 scoped_ptr<IPAddressStore> health_checker_remote_ips_;
Paul Stewart75897df2011-04-27 09:05:53 -0700577};
578
579} // namespace shill
580
Darin Petkov002c58e2012-06-19 02:56:05 +0200581#endif // SHILL_MANAGER_H_