Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [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 | |
| 5 | #include "shill/modem_cdma_proxy.h" |
| 6 | |
| 7 | #include <base/logging.h> |
| 8 | |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 9 | #include "cellular_error.h" |
| 10 | |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 11 | using std::string; |
| 12 | |
| 13 | namespace shill { |
| 14 | |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 15 | ModemCDMAProxy::ModemCDMAProxy(ModemCDMAProxyDelegate *delegate, |
Darin Petkov | d966195 | 2011-08-03 16:25:42 -0700 | [diff] [blame] | 16 | DBus::Connection *connection, |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 17 | const string &path, |
| 18 | const string &service) |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 19 | : proxy_(delegate, connection, path, service) {} |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 20 | |
| 21 | ModemCDMAProxy::~ModemCDMAProxy() {} |
| 22 | |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 23 | void ModemCDMAProxy::Activate(const string &carrier, |
| 24 | AsyncCallHandler *call_handler, int timeout) { |
| 25 | proxy_.Activate(carrier, call_handler, timeout); |
Darin Petkov | c408e69 | 2011-08-17 13:47:15 -0700 | [diff] [blame] | 26 | } |
| 27 | |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 28 | void ModemCDMAProxy::GetRegistrationState(uint32 *cdma_1x_state, |
| 29 | uint32 *evdo_state) { |
| 30 | proxy_.GetRegistrationState(*cdma_1x_state, *evdo_state); |
| 31 | } |
| 32 | |
Darin Petkov | d966195 | 2011-08-03 16:25:42 -0700 | [diff] [blame] | 33 | uint32 ModemCDMAProxy::GetSignalQuality() { |
| 34 | return proxy_.GetSignalQuality(); |
| 35 | } |
| 36 | |
Darin Petkov | 975b5e7 | 2011-08-30 11:48:08 -0700 | [diff] [blame] | 37 | const string ModemCDMAProxy::MEID() { |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 38 | LOG(INFO) << "ModemCDMAProxy::" << __func__; |
Darin Petkov | 975b5e7 | 2011-08-30 11:48:08 -0700 | [diff] [blame] | 39 | return proxy_.Meid(); |
| 40 | } |
| 41 | |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 42 | ModemCDMAProxy::Proxy::Proxy(ModemCDMAProxyDelegate *delegate, |
Darin Petkov | d966195 | 2011-08-03 16:25:42 -0700 | [diff] [blame] | 43 | DBus::Connection *connection, |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 44 | const string &path, |
| 45 | const string &service) |
Darin Petkov | d966195 | 2011-08-03 16:25:42 -0700 | [diff] [blame] | 46 | : DBus::ObjectProxy(*connection, path, service.c_str()), |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 47 | delegate_(delegate) {} |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 48 | |
| 49 | ModemCDMAProxy::Proxy::~Proxy() {} |
| 50 | |
| 51 | void ModemCDMAProxy::Proxy::ActivationStateChanged( |
| 52 | const uint32 &activation_state, |
| 53 | const uint32 &activation_error, |
| 54 | const DBusPropertiesMap &status_changes) { |
Darin Petkov | b27e544 | 2011-08-16 14:36:45 -0700 | [diff] [blame] | 55 | VLOG(2) << __func__ << "(" << activation_state << ", " << activation_error |
| 56 | << ")"; |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 57 | delegate_->OnCDMAActivationStateChanged( |
Darin Petkov | b27e544 | 2011-08-16 14:36:45 -0700 | [diff] [blame] | 58 | activation_state, activation_error, status_changes); |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 59 | } |
| 60 | |
| 61 | void ModemCDMAProxy::Proxy::SignalQuality(const uint32 &quality) { |
Darin Petkov | d966195 | 2011-08-03 16:25:42 -0700 | [diff] [blame] | 62 | VLOG(2) << __func__ << "(" << quality << ")"; |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 63 | delegate_->OnCDMASignalQualityChanged(quality); |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 64 | } |
| 65 | |
| 66 | void ModemCDMAProxy::Proxy::RegistrationStateChanged( |
Darin Petkov | d966195 | 2011-08-03 16:25:42 -0700 | [diff] [blame] | 67 | const uint32 &cdma_1x_state, |
| 68 | const uint32 &evdo_state) { |
| 69 | VLOG(2) << __func__ << "(" << cdma_1x_state << ", " << evdo_state << ")"; |
Darin Petkov | 580c7af | 2011-10-24 12:32:50 +0200 | [diff] [blame] | 70 | delegate_->OnCDMARegistrationStateChanged(cdma_1x_state, evdo_state); |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 71 | } |
| 72 | |
Eric Shienbrood | 5de44ab | 2011-12-05 10:46:27 -0500 | [diff] [blame] | 73 | void ModemCDMAProxy::Proxy::ActivateCallback(const uint32 &status, |
| 74 | const DBus::Error &dberror, |
| 75 | void *data) { |
| 76 | VLOG(2) << __func__ << "(" << status << ")"; |
| 77 | AsyncCallHandler *call_handler = reinterpret_cast<AsyncCallHandler *>(data); |
| 78 | Error error; |
| 79 | CellularError::FromDBusError(dberror, &error), |
| 80 | delegate_->OnActivateCallback(status, error, call_handler); |
| 81 | } |
| 82 | |
Darin Petkov | bec79a2 | 2011-08-01 14:47:17 -0700 | [diff] [blame] | 83 | } // namespace shill |