blob: 42ba42a3b344e9e9bb9b8652c3ef409bda41586d [file] [log] [blame]
Darin Petkovc64fe5e2012-01-11 12:46:13 +01001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Chris Masone3bd3c8c2011-06-13 08:20:26 -07002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef SHILL_CELLULAR_
6#define SHILL_CELLULAR_
7
8#include <string>
9
10#include <base/basictypes.h>
Darin Petkovc5f56562011-08-06 16:40:05 -070011#include <base/task.h>
Darin Petkove9d12e02011-07-27 15:09:37 -070012#include <gtest/gtest_prod.h> // for FRIEND_TEST
Chris Masone3bd3c8c2011-06-13 08:20:26 -070013
Darin Petkovc5f56562011-08-06 16:40:05 -070014#include "shill/dbus_properties.h"
Chris Masone3bd3c8c2011-06-13 08:20:26 -070015#include "shill/device.h"
Paul Stewart26b327e2011-10-19 11:38:09 -070016#include "shill/event_dispatcher.h"
Darin Petkovc5f56562011-08-06 16:40:05 -070017#include "shill/modem_proxy_interface.h"
Chris Masone2b105542011-06-22 10:58:09 -070018#include "shill/refptr_types.h"
Chris Masone3bd3c8c2011-06-13 08:20:26 -070019
Darin Petkov137884a2011-10-26 18:52:47 +020020struct mobile_provider_db;
21
Chris Masone3bd3c8c2011-06-13 08:20:26 -070022namespace shill {
23
Darin Petkovdaf43862011-10-27 11:37:28 +020024class CellularCapability;
Darin Petkov4d6d9412011-08-24 13:19:54 -070025class Error;
Darin Petkove604f702011-07-28 15:51:17 -070026class ModemSimpleProxyInterface;
Darin Petkovab565bb2011-10-06 02:55:51 -070027class ProxyFactory;
Darin Petkove9d12e02011-07-27 15:09:37 -070028
Darin Petkovd9661952011-08-03 16:25:42 -070029class Cellular : public Device,
Darin Petkov580c7af2011-10-24 12:32:50 +020030 public ModemProxyDelegate {
Chris Masone3bd3c8c2011-06-13 08:20:26 -070031 public:
Darin Petkove9d12e02011-07-27 15:09:37 -070032 enum Type {
33 kTypeGSM,
34 kTypeCDMA
35 };
36
Darin Petkov0828f5f2011-08-11 10:18:52 -070037 // The device states progress linearly from Disabled to Linked.
Darin Petkove9d12e02011-07-27 15:09:37 -070038 enum State {
Darin Petkov0828f5f2011-08-11 10:18:52 -070039 // This is the initial state of the modem and indicates that the modem radio
40 // is not turned on.
Darin Petkove9d12e02011-07-27 15:09:37 -070041 kStateDisabled,
Darin Petkov0828f5f2011-08-11 10:18:52 -070042 // This state indicates that the modem radio is turned on, and it should be
43 // possible to measure signal strength.
Darin Petkove9d12e02011-07-27 15:09:37 -070044 kStateEnabled,
Darin Petkov0828f5f2011-08-11 10:18:52 -070045 // The modem has registered with a network and has signal quality
Darin Petkov51489002011-08-18 13:13:20 -070046 // measurements. A cellular service object is created.
Darin Petkove9d12e02011-07-27 15:09:37 -070047 kStateRegistered,
Darin Petkov0828f5f2011-08-11 10:18:52 -070048 // The modem has connected to a network.
Darin Petkove9d12e02011-07-27 15:09:37 -070049 kStateConnected,
Darin Petkov0828f5f2011-08-11 10:18:52 -070050 // The network interface is UP.
51 kStateLinked,
Darin Petkove9d12e02011-07-27 15:09:37 -070052 };
53
Darin Petkovbac96002011-08-09 13:22:00 -070054 // These should be kept in sync with ModemManager's mm-modem.h:MMModemState.
55 enum ModemState {
56 kModemStateUnknown = 0,
57 kModemStateDisabled = 10,
58 kModemStateDisabling = 20,
59 kModemStateEnabling = 30,
60 kModemStateEnabled = 40,
61 kModemStateSearching = 50,
62 kModemStateRegistered = 60,
63 kModemStateDisconnecting = 70,
64 kModemStateConnecting = 80,
65 kModemStateConnected = 90,
66 };
67
Darin Petkov3335b372011-08-22 11:05:32 -070068 class Operator {
69 public:
70 Operator();
71 ~Operator();
72
73 void CopyFrom(const Operator &oper);
74
75 const std::string &GetName() const;
76 void SetName(const std::string &name);
77
78 const std::string &GetCode() const;
79 void SetCode(const std::string &code);
80
81 const std::string &GetCountry() const;
82 void SetCountry(const std::string &country);
83
84 const Stringmap &ToDict() const;
85
86 private:
87 Stringmap dict_;
88
89 DISALLOW_COPY_AND_ASSIGN(Operator);
90 };
91
Darin Petkovc5f56562011-08-06 16:40:05 -070092 static const char kConnectPropertyPhoneNumber[];
Darin Petkov0a4dfeb2011-11-18 19:36:13 +010093 static const char kPropertyIMSI[];
Darin Petkovc5f56562011-08-06 16:40:05 -070094
Darin Petkove9d12e02011-07-27 15:09:37 -070095 // |owner| is the ModemManager DBus service owner (e.g., ":1.17"). |path| is
96 // the ModemManager.Modem DBus object path (e.g.,
97 // "/org/chromium/ModemManager/Gobi/0").
Chris Masone3bd3c8c2011-06-13 08:20:26 -070098 Cellular(ControlInterface *control_interface,
99 EventDispatcher *dispatcher,
Thieu Le3426c8f2012-01-11 17:35:11 -0800100 Metrics *metrics,
Chris Masone3bd3c8c2011-06-13 08:20:26 -0700101 Manager *manager,
Darin Petkove9d12e02011-07-27 15:09:37 -0700102 const std::string &link_name,
Chris Masone626719f2011-08-18 16:58:48 -0700103 const std::string &address,
Darin Petkove9d12e02011-07-27 15:09:37 -0700104 int interface_index,
105 Type type,
106 const std::string &owner,
Darin Petkov137884a2011-10-26 18:52:47 +0200107 const std::string &path,
108 mobile_provider_db *provider_db);
Darin Petkove9d12e02011-07-27 15:09:37 -0700109 virtual ~Cellular();
110
Darin Petkov4d6d9412011-08-24 13:19:54 -0700111 // Asynchronously connects the modem to the network. Populates |error| on
112 // failure, leaves it unchanged otherwise.
113 void Connect(Error *error);
Darin Petkovc5f56562011-08-06 16:40:05 -0700114
Darin Petkovb100ae72011-08-24 16:19:45 -0700115 // Asynchronously activates the modem. Populates |error| on failure, leaves it
116 // unchanged otherwise.
117 void Activate(const std::string &carrier, Error *error);
Darin Petkovc408e692011-08-17 13:47:15 -0700118
Darin Petkov3e509242011-11-10 14:46:44 +0100119 const CellularServiceRefPtr &service() const { return service_; }
120
Darin Petkova3d3be52011-11-14 21:34:16 +0100121 static std::string GetStateString(State state);
122
Darin Petkovac635a82012-01-10 16:51:58 +0100123 std::string CreateFriendlyServiceName();
124
Darin Petkova3d3be52011-11-14 21:34:16 +0100125 State state() const { return state_; }
126
Darin Petkovbac96002011-08-09 13:22:00 -0700127 void set_modem_state(ModemState state) { modem_state_ = state; }
128 ModemState modem_state() const { return modem_state_; }
129
Darin Petkov1272a432011-11-10 15:53:37 +0100130 mobile_provider_db *provider_db() const { return provider_db_; }
131
Darin Petkovdaf43862011-10-27 11:37:28 +0200132 const std::string &dbus_owner() const { return dbus_owner_; }
133 const std::string &dbus_path() const { return dbus_path_; }
134
Darin Petkovac635a82012-01-10 16:51:58 +0100135 const std::string &carrier() const { return carrier_; }
136
Darin Petkovae0c64e2011-11-15 15:50:27 +0100137 const Operator &home_provider() const { return home_provider_; }
138 void set_home_provider(const Operator &oper);
Darin Petkov184c54e2011-11-15 12:44:39 +0100139
Darin Petkovcb547732011-11-09 13:55:26 +0100140 const std::string &meid() const { return meid_; }
141 void set_meid(const std::string &meid) { meid_ = meid; }
142
143 const std::string &imei() const { return imei_; }
144 void set_imei(const std::string &imei) { imei_ = imei; }
145
146 const std::string &imsi() const { return imsi_; }
147 void set_imsi(const std::string &imsi) { imsi_ = imsi; }
148
Darin Petkovcb547732011-11-09 13:55:26 +0100149 const std::string &mdn() const { return mdn_; }
150 void set_mdn(const std::string &mdn) { mdn_ = mdn; }
151
Darin Petkov184c54e2011-11-15 12:44:39 +0100152 const std::string &min() const { return min_; }
153 void set_min(const std::string &min) { min_ = min; }
Darin Petkovdaf43862011-10-27 11:37:28 +0200154
Darin Petkov184c54e2011-11-15 12:44:39 +0100155 ProxyFactory *proxy_factory() const { return proxy_factory_; }
Darin Petkovdaf43862011-10-27 11:37:28 +0200156
Darin Petkov3e509242011-11-10 14:46:44 +0100157 void HandleNewSignalQuality(uint32 strength);
158
Darin Petkov184c54e2011-11-15 12:44:39 +0100159 // Processes a change in the modem registration state, possibly creating,
160 // destroying or updating the CellularService.
161 void HandleNewRegistrationState();
162
Darin Petkovae0c64e2011-11-15 15:50:27 +0100163 void OnModemManagerPropertiesChanged(const DBusPropertiesMap &properties);
Darin Petkov184c54e2011-11-15 12:44:39 +0100164
Darin Petkove9d12e02011-07-27 15:09:37 -0700165 // Inherited from Device.
166 virtual void Start();
167 virtual void Stop();
Paul Stewartfdd16072011-09-16 12:41:35 -0700168 virtual bool TechnologyIs(Technology::Identifier type) const;
Darin Petkov0828f5f2011-08-11 10:18:52 -0700169 virtual void LinkEvent(unsigned int flags, unsigned int change);
Darin Petkovc0865312011-09-16 15:31:20 -0700170 virtual void Scan(Error *error);
Darin Petkov9ae310f2011-08-30 15:41:13 -0700171 virtual void RegisterOnNetwork(const std::string &network_id, Error *error);
Darin Petkovc64fe5e2012-01-11 12:46:13 +0100172 virtual void RequirePIN(
173 const std::string &pin, bool require, ReturnerInterface *returner);
Darin Petkove5bc2cb2011-12-07 14:47:32 +0100174 virtual void EnterPIN(const std::string &pin, ReturnerInterface *returner);
Darin Petkove42e1012011-08-31 12:35:04 -0700175 virtual void UnblockPIN(const std::string &unblock_code,
176 const std::string &pin,
Darin Petkovc64fe5e2012-01-11 12:46:13 +0100177 ReturnerInterface *returner);
Darin Petkove42e1012011-08-31 12:35:04 -0700178 virtual void ChangePIN(const std::string &old_pin,
179 const std::string &new_pin,
Darin Petkovc64fe5e2012-01-11 12:46:13 +0100180 ReturnerInterface *returner);
Chris Masone3bd3c8c2011-06-13 08:20:26 -0700181
182 private:
Darin Petkovab565bb2011-10-06 02:55:51 -0700183 friend class CellularTest;
Darin Petkov20c13ec2011-11-09 15:07:15 +0100184 friend class CellularCapabilityCDMATest;
185 friend class CellularCapabilityGSMTest;
Darin Petkov721ac932011-11-16 15:43:09 +0100186 friend class ModemTest;
Darin Petkovac635a82012-01-10 16:51:58 +0100187 FRIEND_TEST(CellularCapabilityCDMATest, CreateFriendlyServiceName);
188 FRIEND_TEST(CellularCapabilityGSMTest, CreateFriendlyServiceName);
189 FRIEND_TEST(CellularServiceTest, FriendlyName);
Darin Petkov3335b372011-08-22 11:05:32 -0700190 FRIEND_TEST(CellularTest, CreateService);
Darin Petkovc5f56562011-08-06 16:40:05 -0700191 FRIEND_TEST(CellularTest, Connect);
Darin Petkovceb68172011-07-29 14:47:48 -0700192 FRIEND_TEST(CellularTest, GetModemInfo);
193 FRIEND_TEST(CellularTest, GetModemStatus);
Darin Petkov721ac932011-11-16 15:43:09 +0100194 FRIEND_TEST(CellularTest, InitProxies);
Darin Petkovbac96002011-08-09 13:22:00 -0700195 FRIEND_TEST(CellularTest, StartConnected);
Darin Petkova1e0a1c2011-08-25 15:08:33 -0700196 FRIEND_TEST(CellularTest, StartCDMARegister);
Darin Petkov9bac6fe2011-08-26 12:49:05 -0700197 FRIEND_TEST(CellularTest, StartGSMRegister);
Darin Petkov0828f5f2011-08-11 10:18:52 -0700198 FRIEND_TEST(CellularTest, StartLinked);
Darin Petkove9d12e02011-07-27 15:09:37 -0700199
Darin Petkov0828f5f2011-08-11 10:18:52 -0700200 void SetState(State state);
201
Darin Petkovc5f56562011-08-06 16:40:05 -0700202 void ConnectTask(const DBusPropertiesMap &properties);
203
Darin Petkovbac96002011-08-09 13:22:00 -0700204 // Invoked when the modem is connected to the cellular network to transition
205 // to the network-connected state and bring the network interface up.
206 void EstablishLink();
207
Darin Petkov5f316f62011-11-18 12:10:26 +0100208 void InitCapability(Type type);
Darin Petkovbec79a22011-08-01 14:47:17 -0700209 void InitProxies();
210
Darin Petkovf5f61e02011-07-29 11:35:40 -0700211 void EnableModem();
212 void GetModemStatus();
Darin Petkovceb68172011-07-29 14:47:48 -0700213
Darin Petkovd9661952011-08-03 16:25:42 -0700214 // Obtains modem's manufacturer, model ID, and hardware revision.
Darin Petkovceb68172011-07-29 14:47:48 -0700215 void GetModemInfo();
Darin Petkovf5f61e02011-07-29 11:35:40 -0700216
Darin Petkov0828f5f2011-08-11 10:18:52 -0700217 void HandleNewRegistrationStateTask();
Darin Petkovd9661952011-08-03 16:25:42 -0700218
219 void CreateService();
Darin Petkov2c377382012-01-11 11:40:43 +0100220 void DestroyService();
Darin Petkovd9661952011-08-03 16:25:42 -0700221
Darin Petkov580c7af2011-10-24 12:32:50 +0200222 // Signal callbacks inherited from ModemProxyDelegate.
Darin Petkovc5f56562011-08-06 16:40:05 -0700223 virtual void OnModemStateChanged(uint32 old_state,
224 uint32 new_state,
225 uint32 reason);
226
Darin Petkovab565bb2011-10-06 02:55:51 -0700227 // Store cached copies of singletons for speed/ease of testing.
228 ProxyFactory *proxy_factory_;
229
Darin Petkove9d12e02011-07-27 15:09:37 -0700230 State state_;
Darin Petkovbac96002011-08-09 13:22:00 -0700231 ModemState modem_state_;
Darin Petkove9d12e02011-07-27 15:09:37 -0700232
Darin Petkovdaf43862011-10-27 11:37:28 +0200233 scoped_ptr<CellularCapability> capability_;
234
Darin Petkove9d12e02011-07-27 15:09:37 -0700235 const std::string dbus_owner_; // ModemManager.Modem
236 const std::string dbus_path_; // ModemManager.Modem
237 scoped_ptr<ModemProxyInterface> proxy_;
Darin Petkove604f702011-07-28 15:51:17 -0700238 scoped_ptr<ModemSimpleProxyInterface> simple_proxy_;
Darin Petkovbec79a22011-08-01 14:47:17 -0700239
Darin Petkov137884a2011-10-26 18:52:47 +0200240 mobile_provider_db *provider_db_;
241
Darin Petkovd9661952011-08-03 16:25:42 -0700242 CellularServiceRefPtr service_;
Chris Masone853b81b2011-06-24 14:11:41 -0700243
Darin Petkovc5f56562011-08-06 16:40:05 -0700244 ScopedRunnableMethodFactory<Cellular> task_factory_;
245
Chris Masoneb925cc82011-06-22 15:39:57 -0700246 // Properties
247 bool allow_roaming_;
248 std::string carrier_;
249 std::string meid_;
250 std::string imei_;
251 std::string imsi_;
252 std::string esn_;
253 std::string mdn_;
254 std::string min_;
255 std::string model_id_;
256 std::string manufacturer_;
257 std::string firmware_revision_;
258 std::string hardware_revision_;
Darin Petkov3335b372011-08-22 11:05:32 -0700259 Operator home_provider_;
Chris Masoneb925cc82011-06-22 15:39:57 -0700260
Chris Masone3bd3c8c2011-06-13 08:20:26 -0700261 DISALLOW_COPY_AND_ASSIGN(Cellular);
262};
263
264} // namespace shill
265
266#endif // SHILL_CELLULAR_