Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS 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. |
| 4 | |
| 5 | #include "shill/mm1_sim_proxy.h" |
| 6 | |
Ben Chan | fad4a0b | 2012-04-18 15:49:59 -0700 | [diff] [blame] | 7 | #include "shill/cellular_error.h" |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 8 | #include "shill/dbus_async_call_helper.h" |
Christopher Wiley | b691efd | 2012-08-09 13:51:51 -0700 | [diff] [blame] | 9 | #include "shill/logging.h" |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 10 | |
| 11 | using std::string; |
| 12 | |
| 13 | namespace shill { |
| 14 | namespace mm1 { |
| 15 | |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 16 | template<typename TraceMsgT, typename CallT, typename CallbackT, |
| 17 | typename... ArgTypes> |
| 18 | void SimProxy::BeginCall( |
Alex Vakulenko | 8a53229 | 2014-06-16 17:18:44 -0700 | [diff] [blame] | 19 | const TraceMsgT &trace_msg, const CallT &call, const CallbackT &callback, |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 20 | Error *error, int timeout, ArgTypes... rest) { |
| 21 | BeginAsyncDBusCall(trace_msg, proxy_, call, callback, error, |
| 22 | &CellularError::FromMM1DBusError, timeout, rest...); |
| 23 | } |
| 24 | |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 25 | SimProxy::SimProxy(DBus::Connection *connection, |
| 26 | const string &path, |
| 27 | const string &service) |
| 28 | : proxy_(connection, path, service) {} |
| 29 | |
| 30 | SimProxy::~SimProxy() {} |
| 31 | |
| 32 | |
| 33 | void SimProxy::SendPin(const string &pin, |
| 34 | Error *error, |
| 35 | const ResultCallback &callback, |
| 36 | int timeout) { |
| 37 | // pin is intentionally not logged. |
Ben Chan | fad4a0b | 2012-04-18 15:49:59 -0700 | [diff] [blame] | 38 | SLOG(Modem, 2) << __func__ << "( XXX, " << timeout << ")"; |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 39 | BeginCall(__func__, &Proxy::SendPinAsync, callback, error, timeout, |
| 40 | pin); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 41 | } |
| 42 | |
| 43 | void SimProxy::SendPuk(const string &puk, |
| 44 | const string &pin, |
| 45 | Error *error, |
| 46 | const ResultCallback &callback, |
| 47 | int timeout) { |
| 48 | // pin and puk are intentionally not logged. |
Ben Chan | fad4a0b | 2012-04-18 15:49:59 -0700 | [diff] [blame] | 49 | SLOG(Modem, 2) << __func__ << "( XXX, XXX, " << timeout << ")"; |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 50 | BeginCall(__func__, &Proxy::SendPukAsync, callback, error, timeout, |
| 51 | puk, pin); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 52 | } |
| 53 | |
| 54 | void SimProxy::EnablePin(const string &pin, |
| 55 | const bool enabled, |
| 56 | Error *error, |
| 57 | const ResultCallback &callback, |
| 58 | int timeout) { |
| 59 | // pin is intentionally not logged. |
Ben Chan | fad4a0b | 2012-04-18 15:49:59 -0700 | [diff] [blame] | 60 | SLOG(Modem, 2) << __func__ << "( XXX, " << enabled << ", " << timeout << ")"; |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 61 | BeginCall(__func__, &Proxy::EnablePinAsync, callback, error, timeout, |
| 62 | pin, enabled); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 63 | } |
| 64 | |
| 65 | void SimProxy::ChangePin(const string &old_pin, |
| 66 | const string &new_pin, |
| 67 | Error *error, |
| 68 | const ResultCallback &callback, |
| 69 | int timeout) { |
| 70 | // old_pin and new_pin are intentionally not logged. |
Ben Chan | fad4a0b | 2012-04-18 15:49:59 -0700 | [diff] [blame] | 71 | SLOG(Modem, 2) << __func__ << "( XXX, XXX, " << timeout << ")"; |
mukesh agrawal | 0e9e9d1 | 2014-04-18 16:09:58 -0700 | [diff] [blame] | 72 | BeginCall(__func__, &Proxy::ChangePinAsync, callback, error, timeout, |
| 73 | old_pin, new_pin); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 74 | } |
| 75 | |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 76 | SimProxy::Proxy::Proxy(DBus::Connection *connection, |
| 77 | const string &path, |
| 78 | const string &service) |
| 79 | : DBus::ObjectProxy(*connection, path, service.c_str()) {} |
| 80 | |
| 81 | SimProxy::Proxy::~Proxy() {} |
| 82 | |
| 83 | |
| 84 | // Method callbacks inherited from |
| 85 | // org::freedesktop::ModemManager1::SimProxy |
| 86 | void SimProxy::Proxy::SendPinCallback(const ::DBus::Error &dberror, |
| 87 | void *data) { |
mukesh agrawal | 06175d7 | 2012-04-23 16:46:01 -0700 | [diff] [blame] | 88 | SLOG(DBus, 2) << __func__; |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 89 | scoped_ptr<ResultCallback> callback(reinterpret_cast<ResultCallback *>(data)); |
| 90 | Error error; |
Arman Uguray | 763df86 | 2013-07-02 12:49:10 -0700 | [diff] [blame] | 91 | CellularError::FromMM1DBusError(dberror, &error); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 92 | callback->Run(error); |
| 93 | } |
| 94 | |
| 95 | void SimProxy::Proxy::SendPukCallback(const ::DBus::Error &dberror, |
mukesh agrawal | 06175d7 | 2012-04-23 16:46:01 -0700 | [diff] [blame] | 96 | void *data) { |
| 97 | SLOG(DBus, 2) << __func__; |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 98 | scoped_ptr<ResultCallback> callback(reinterpret_cast<ResultCallback *>(data)); |
| 99 | Error error; |
Arman Uguray | 763df86 | 2013-07-02 12:49:10 -0700 | [diff] [blame] | 100 | CellularError::FromMM1DBusError(dberror, &error); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 101 | callback->Run(error); |
| 102 | } |
| 103 | |
Gary Morain | abb30da | 2012-05-08 16:59:59 -0700 | [diff] [blame] | 104 | void SimProxy::Proxy::EnablePinCallback(const ::DBus::Error &dberror, |
| 105 | void *data) { |
mukesh agrawal | 06175d7 | 2012-04-23 16:46:01 -0700 | [diff] [blame] | 106 | SLOG(DBus, 2) << __func__; |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 107 | scoped_ptr<ResultCallback> callback(reinterpret_cast<ResultCallback *>(data)); |
| 108 | Error error; |
Arman Uguray | 763df86 | 2013-07-02 12:49:10 -0700 | [diff] [blame] | 109 | CellularError::FromMM1DBusError(dberror, &error); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 110 | callback->Run(error); |
| 111 | } |
| 112 | |
Gary Morain | abb30da | 2012-05-08 16:59:59 -0700 | [diff] [blame] | 113 | void SimProxy::Proxy::ChangePinCallback(const ::DBus::Error &dberror, |
| 114 | void *data) { |
mukesh agrawal | 06175d7 | 2012-04-23 16:46:01 -0700 | [diff] [blame] | 115 | SLOG(DBus, 2) << __func__; |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 116 | scoped_ptr<ResultCallback> callback(reinterpret_cast<ResultCallback *>(data)); |
| 117 | Error error; |
Arman Uguray | 763df86 | 2013-07-02 12:49:10 -0700 | [diff] [blame] | 118 | CellularError::FromMM1DBusError(dberror, &error); |
Jason Glasgow | 74f5ef2 | 2012-03-29 16:15:04 -0400 | [diff] [blame] | 119 | callback->Run(error); |
| 120 | } |
| 121 | |
| 122 | } // namespace mm1 |
| 123 | } // namespace shill |