Darin Petkov | c64fe5e | 2012-01-11 12:46:13 +0100 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 5 | #ifndef SHILL_CELLULAR_CAPABILITY_H_ |
| 6 | #define SHILL_CELLULAR_CAPABILITY_H_ |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 7 | |
Darin Petkov | b05315f | 2011-11-07 10:14:25 +0100 | [diff] [blame] | 8 | #include <string> |
Eric Shienbrood | 3e20a23 | 2012-02-16 11:35:56 -0500 | [diff] [blame] | 9 | #include <vector> |
Darin Petkov | b05315f | 2011-11-07 10:14:25 +0100 | [diff] [blame] | 10 | |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 11 | #include <base/basictypes.h> |
Eric Shienbrood | 3e20a23 | 2012-02-16 11:35:56 -0500 | [diff] [blame] | 12 | #include <base/callback.h> |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 13 | #include <base/memory/scoped_ptr.h> |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 14 | #include <gtest/gtest_prod.h> // for FRIEND_TEST |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 15 | |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 16 | #include "shill/callbacks.h" |
Eric Shienbrood | 7fce52c | 2012-04-13 19:11:02 -0400 | [diff] [blame] | 17 | #include "shill/cellular.h" |
Darin Petkov | ae0c64e | 2011-11-15 15:50:27 +0100 | [diff] [blame] | 18 | #include "shill/dbus_properties.h" |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 19 | |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 20 | namespace shill { |
| 21 | |
| 22 | class Cellular; |
Darin Petkov | b05315f | 2011-11-07 10:14:25 +0100 | [diff] [blame] | 23 | class Error; |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 24 | class ProxyFactory; |
| 25 | |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 26 | // Cellular devices instantiate subclasses of CellularCapability that |
| 27 | // handle the specific modem technologies and capabilities. |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 28 | // |
| 29 | // The CellularCapability is directly subclassed by: |
| 30 | // * CelllularCapabilityUniversal which handles all modems managed by |
| 31 | // a modem manager using the the org.chromium.ModemManager1 DBUS |
| 32 | // interface |
| 33 | // * CellularCapabilityClassic which handles all modems managed by a |
| 34 | // modem manager using the older org.chromium.ModemManager DBUS |
| 35 | // interface. This class is further subclassed to represent CDMA |
| 36 | // and GSM modems |
| 37 | // |
| 38 | // Pictorially: |
| 39 | // |
| 40 | // CellularCapability |
| 41 | // | |
| 42 | // |-- CellularCapabilityUniversal |
| 43 | // | |
| 44 | // |-- CellularCapabilityClassic |
| 45 | // | |
| 46 | // |-- CellularCapabilityGSM |
| 47 | // | |
| 48 | // |-- CellularCapabilityCDMA |
| 49 | // |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 50 | class CellularCapability { |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 51 | public: |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 52 | // SimLockStatus represents the fields in the Cellular.SIMLockStatus |
| 53 | // DBUS property of the shill device. |
| 54 | struct SimLockStatus { |
| 55 | SimLockStatus() : enabled(false), retries_left(0) {} |
| 56 | |
| 57 | bool enabled; |
| 58 | std::string lock_type; |
| 59 | uint32 retries_left; |
| 60 | }; |
| 61 | |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 62 | static const int kTimeoutActivate; |
| 63 | static const int kTimeoutConnect; |
| 64 | static const int kTimeoutDefault; |
Thieu Le | 049adb5 | 2012-11-12 17:14:51 -0800 | [diff] [blame] | 65 | static const int kTimeoutDisconnect; |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 66 | static const int kTimeoutEnable; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 67 | static const int kTimeoutRegister; |
Ben Chan | 5d0d32c | 2013-01-08 02:05:29 -0800 | [diff] [blame] | 68 | static const int kTimeoutReset; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 69 | static const int kTimeoutScan; |
| 70 | |
Eric Shienbrood | 7fce52c | 2012-04-13 19:11:02 -0400 | [diff] [blame] | 71 | static const char kModemPropertyIMSI[]; |
| 72 | static const char kModemPropertyState[]; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 73 | |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 74 | // |cellular| is the parent Cellular device. |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 75 | CellularCapability(Cellular *cellular, ProxyFactory *proxy_factory); |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 76 | virtual ~CellularCapability(); |
| 77 | |
| 78 | Cellular *cellular() const { return cellular_; } |
| 79 | ProxyFactory *proxy_factory() const { return proxy_factory_; } |
Darin Petkov | 5f316f6 | 2011-11-18 12:10:26 +0100 | [diff] [blame] | 80 | |
| 81 | // Invoked by the parent Cellular device when a new service is created. |
| 82 | virtual void OnServiceCreated() = 0; |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 83 | |
Darin Petkov | ae0c64e | 2011-11-15 15:50:27 +0100 | [diff] [blame] | 84 | virtual void SetupConnectProperties(DBusPropertiesMap *properties) = 0; |
| 85 | |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 86 | // StartModem attempts to put the modem in a state in which it is |
| 87 | // usable for creating services and establishing connections (if |
| 88 | // network conditions permit). It potentially consists of multiple |
| 89 | // non-blocking calls to the modem-manager server. After each call, |
| 90 | // control is passed back up to the main loop. Each time a reply to |
| 91 | // a non-blocking call is received, the operation advances to the next |
| 92 | // step, until either an error occurs in one of them, or all the steps |
| 93 | // have been completed, at which point StartModem() is finished. |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 94 | virtual void StartModem(Error *error, |
| 95 | const ResultCallback &callback) = 0; |
Thieu Le | 923006b | 2012-04-05 16:32:58 -0700 | [diff] [blame] | 96 | // StopModem disconnects and disables a modem asynchronously. |
| 97 | // |callback| is invoked when this completes and the result is passed |
| 98 | // to the callback. |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 99 | virtual void StopModem(Error *error, const ResultCallback &callback) = 0; |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 100 | virtual void Connect(const DBusPropertiesMap &properties, Error *error, |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 101 | const ResultCallback &callback) = 0; |
| 102 | virtual void Disconnect(Error *error, const ResultCallback &callback) = 0; |
Christopher Wiley | 8a46890 | 2012-11-30 11:52:38 -0800 | [diff] [blame] | 103 | // Called when a disconnect completes, successful or not. |
| 104 | virtual void DisconnectCleanup() = 0; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 105 | |
| 106 | // Activates the modem. Returns an Error on failure. |
| 107 | // The default implementation fails by returning a kNotSupported error |
| 108 | // to the caller. |
| 109 | virtual void Activate(const std::string &carrier, |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 110 | Error *error, const ResultCallback &callback) = 0; |
Darin Petkov | a3d3be5 | 2011-11-14 21:34:16 +0100 | [diff] [blame] | 111 | |
Ben Chan | 1578603 | 2012-11-04 21:28:02 -0800 | [diff] [blame] | 112 | // Returns true if service activation is required. Returns false by default |
| 113 | // in this base class. |
| 114 | virtual bool IsServiceActivationRequired() const; |
| 115 | |
Darin Petkov | 184c54e | 2011-11-15 12:44:39 +0100 | [diff] [blame] | 116 | // Network registration. |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 117 | virtual void RegisterOnNetwork(const std::string &network_id, |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 118 | Error *error, |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 119 | const ResultCallback &callback) = 0; |
Darin Petkov | b72cf40 | 2011-11-22 14:51:39 +0100 | [diff] [blame] | 120 | virtual bool IsRegistered() = 0; |
Eric Shienbrood | 7fce52c | 2012-04-13 19:11:02 -0400 | [diff] [blame] | 121 | // If we are informed by means of something other than a signal indicating |
| 122 | // a registration state change that the modem has unregistered from the |
| 123 | // network, we need to update the network-type-specific capability object. |
| 124 | virtual void SetUnregistered(bool searching) = 0; |
Darin Petkov | 184c54e | 2011-11-15 12:44:39 +0100 | [diff] [blame] | 125 | |
Darin Petkov | ac635a8 | 2012-01-10 16:51:58 +0100 | [diff] [blame] | 126 | virtual std::string CreateFriendlyServiceName() = 0; |
| 127 | |
Darin Petkov | c64fe5e | 2012-01-11 12:46:13 +0100 | [diff] [blame] | 128 | // PIN management. The default implementation fails by returning an error. |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 129 | virtual void RequirePIN(const std::string &pin, bool require, |
| 130 | Error *error, const ResultCallback &callback); |
| 131 | virtual void EnterPIN(const std::string &pin, |
| 132 | Error *error, const ResultCallback &callback); |
Darin Petkov | b05315f | 2011-11-07 10:14:25 +0100 | [diff] [blame] | 133 | virtual void UnblockPIN(const std::string &unblock_code, |
| 134 | const std::string &pin, |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 135 | Error *error, const ResultCallback &callback); |
Darin Petkov | b05315f | 2011-11-07 10:14:25 +0100 | [diff] [blame] | 136 | virtual void ChangePIN(const std::string &old_pin, |
| 137 | const std::string &new_pin, |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 138 | Error *error, const ResultCallback &callback); |
Darin Petkov | b05315f | 2011-11-07 10:14:25 +0100 | [diff] [blame] | 139 | |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 140 | // The default implementation fails by returning an error. |
Ben Chan | 5d0d32c | 2013-01-08 02:05:29 -0800 | [diff] [blame] | 141 | virtual void Reset(Error *error, const ResultCallback &callback); |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 142 | virtual void SetCarrier(const std::string &carrier, |
| 143 | Error *error, const ResultCallback &callback); |
| 144 | |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 145 | // Asks the modem to scan for networks. |
| 146 | // |
| 147 | // The default implementation fails by filling error with |
| 148 | // kNotSupported. |
| 149 | // |
| 150 | // Subclasses should implement this by fetching scan results |
| 151 | // asynchronously. When the results are ready, update the |
| 152 | // flimflam::kFoundNetworksProperty and send a property change |
| 153 | // notification. Finally, callback must be invoked to inform the |
| 154 | // caller that the scan has completed. |
| 155 | // |
| 156 | // Errors are not generally reported, but on error the |
| 157 | // kFoundNetworksProperty should be cleared and a property change |
| 158 | // notification sent out. |
| 159 | // |
| 160 | // TODO(jglasgow): Refactor to reuse code by putting notification |
| 161 | // logic into Cellular or CellularCapability. |
| 162 | // |
| 163 | // TODO(jglasgow): Implement real error handling. |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 164 | virtual void Scan(Error *error, const ResultCallback &callback); |
Darin Petkov | 1272a43 | 2011-11-10 15:53:37 +0100 | [diff] [blame] | 165 | |
Darin Petkov | 20c13ec | 2011-11-09 15:07:15 +0100 | [diff] [blame] | 166 | // Returns an empty string if the network technology is unknown. |
| 167 | virtual std::string GetNetworkTechnologyString() const = 0; |
| 168 | |
| 169 | virtual std::string GetRoamingStateString() const = 0; |
| 170 | |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 171 | virtual void GetSignalQuality() = 0; |
| 172 | |
Eric Shienbrood | 0db6a9b | 2012-03-30 16:11:39 -0400 | [diff] [blame] | 173 | virtual std::string GetTypeString() const = 0; |
| 174 | |
Jason Glasgow | 4c0724a | 2012-04-17 15:47:40 -0400 | [diff] [blame] | 175 | // Called when ModemManager has sent a property change notification |
| 176 | // signal over DBUS. |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 177 | virtual void OnDBusPropertiesChanged( |
| 178 | const std::string &interface, |
| 179 | const DBusPropertiesMap &changed_properties, |
| 180 | const std::vector<std::string> &invalidated_properties) = 0; |
Darin Petkov | ae0c64e | 2011-11-15 15:50:27 +0100 | [diff] [blame] | 181 | |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 182 | // Should this device allow roaming? |
| 183 | // The decision to allow roaming or not is based on the home |
| 184 | // provider as well as on the user modifiable "allow_roaming" |
| 185 | // property. |
| 186 | virtual bool AllowRoaming() = 0; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 187 | |
Christopher Wiley | 1582bdd | 2012-11-15 11:31:14 -0800 | [diff] [blame] | 188 | virtual bool IsActivating() const; |
| 189 | |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 190 | protected: |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 191 | // Releases all proxies held by the object. This is most useful |
| 192 | // during unit tests. |
| 193 | virtual void ReleaseProxies() = 0; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 194 | |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 195 | static void OnUnsupportedOperation(const char *operation, Error *error); |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 196 | |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 197 | // accessor for subclasses to read the allow roaming property |
Jason Glasgow | 7b461df | 2012-05-01 16:38:45 -0400 | [diff] [blame] | 198 | bool allow_roaming_property() const { |
| 199 | return cellular_->allow_roaming_property(); |
| 200 | } |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 201 | |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 202 | private: |
Thieu Le | 923006b | 2012-04-05 16:32:58 -0700 | [diff] [blame] | 203 | friend class CellularCapabilityGSMTest; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 204 | friend class CellularCapabilityTest; |
Jason Glasgow | ef96556 | 2012-04-10 16:12:35 -0400 | [diff] [blame] | 205 | friend class CellularCapabilityUniversalTest; |
Thieu Le | 923006b | 2012-04-05 16:32:58 -0700 | [diff] [blame] | 206 | friend class CellularTest; |
Darin Petkov | 9c1dcef | 2012-02-07 15:58:26 +0100 | [diff] [blame] | 207 | FRIEND_TEST(CellularCapabilityTest, AllowRoaming); |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 208 | FRIEND_TEST(CellularTest, Connect); |
Jason Glasgow | 82f9ab3 | 2012-04-04 14:27:19 -0400 | [diff] [blame] | 209 | FRIEND_TEST(CellularTest, TearDown); |
Darin Petkov | 721ac93 | 2011-11-16 15:43:09 +0100 | [diff] [blame] | 210 | |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 211 | Cellular *cellular_; |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 212 | |
| 213 | // Store cached copies of singletons for speed/ease of testing. |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 214 | ProxyFactory *proxy_factory_; |
| 215 | |
Darin Petkov | daf4386 | 2011-10-27 11:37:28 +0200 | [diff] [blame] | 216 | DISALLOW_COPY_AND_ASSIGN(CellularCapability); |
| 217 | }; |
| 218 | |
| 219 | } // namespace shill |
| 220 | |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 221 | #endif // SHILL_CELLULAR_CAPABILITY_H_ |