//
// Copyright (C) 2015 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#include "shill/dbus/chromeos_service_dbus_adaptor.h"
#include <map>
#include <string>
#include "shill/error.h"
#include "shill/logging.h"
#include "shill/service.h"
using brillo::dbus_utils::AsyncEventSequencer;
using brillo::dbus_utils::ExportedObjectManager;
using std::map;
using std::string;
using std::vector;
namespace shill {
namespace Logging {
static auto kModuleLogScope = ScopeLogger::kDBus;
static string ObjectID(ChromeosServiceDBusAdaptor* s) {
return s->GetRpcIdentifier() + " (" + s->service()->unique_name() + ")";
}
}
// static
const char ChromeosServiceDBusAdaptor::kPath[] = "/service/";
ChromeosServiceDBusAdaptor::ChromeosServiceDBusAdaptor(
const scoped_refptr<dbus::Bus>& bus,
Service* service)
: org::chromium::flimflam::ServiceAdaptor(this),
ChromeosDBusAdaptor(bus, kPath + service->unique_name()),
service_(service) {
// Register DBus object.
RegisterWithDBusObject(dbus_object());
dbus_object()->RegisterAndBlock();
}
ChromeosServiceDBusAdaptor::~ChromeosServiceDBusAdaptor() {
dbus_object()->UnregisterAsync();
service_ = nullptr;
}
void ChromeosServiceDBusAdaptor::EmitBoolChanged(const string& name,
bool value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitUint8Changed(const string& name,
uint8_t value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitUint16Changed(const string& name,
uint16_t value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitUint16sChanged(const string& name,
const Uint16s& value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitUintChanged(const string& name,
uint32_t value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitIntChanged(const string& name, int value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitRpcIdentifierChanged(const string& name,
const string& value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(dbus::ObjectPath(value)));
}
void ChromeosServiceDBusAdaptor::EmitStringChanged(const string& name,
const string& value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
void ChromeosServiceDBusAdaptor::EmitStringmapChanged(const string& name,
const Stringmap& value) {
SLOG(this, 2) << __func__ << ": " << name;
SendPropertyChangedSignal(name, brillo::Any(value));
}
bool ChromeosServiceDBusAdaptor::GetProperties(
brillo::ErrorPtr* error, brillo::VariantDictionary* properties) {
SLOG(this, 2) << __func__;
return ChromeosDBusAdaptor::GetProperties(service_->store(),
properties,
error);
}
bool ChromeosServiceDBusAdaptor::SetProperty(
brillo::ErrorPtr* error, const string& name, const brillo::Any& value) {
SLOG(this, 2) << __func__ << ": " << name;
return ChromeosDBusAdaptor::SetProperty(service_->mutable_store(),
name,
value,
error);
}
bool ChromeosServiceDBusAdaptor::SetProperties(
brillo::ErrorPtr* error, const brillo::VariantDictionary& args) {
SLOG(this, 2) << __func__;
KeyValueStore args_store;
KeyValueStore::ConvertFromVariantDictionary(args, &args_store);
Error configure_error;
service_->Configure(args_store, &configure_error);
return !configure_error.ToChromeosError(error);
}
bool ChromeosServiceDBusAdaptor::ClearProperty(brillo::ErrorPtr* error,
const string& name) {
SLOG(this, 2) << __func__ << ": " << name;
bool status = ChromeosDBusAdaptor::ClearProperty(service_->mutable_store(),
name,
error);
if (status) {
service_->OnPropertyChanged(name);
}
return status;
}
bool ChromeosServiceDBusAdaptor::ClearProperties(brillo::ErrorPtr* /*error*/,
const vector<string>& names,
vector<bool>* results) {
SLOG(this, 2) << __func__;
vector<string>::const_iterator it;
for (it = names.begin(); it != names.end(); ++it) {
results->push_back(ClearProperty(nullptr, *it));
}
return true;
}
bool ChromeosServiceDBusAdaptor::Connect(brillo::ErrorPtr* error) {
SLOG(this, 2) << __func__;
Error e;
service_->UserInitiatedConnect(&e);
return !e.ToChromeosError(error);
}
bool ChromeosServiceDBusAdaptor::Disconnect(brillo::ErrorPtr* error) {
SLOG(this, 2) << __func__;
Error e;
service_->UserInitiatedDisconnect(&e);
return !e.ToChromeosError(error);
}
bool ChromeosServiceDBusAdaptor::Remove(brillo::ErrorPtr* error) {
SLOG(this, 2) << __func__;
Error e;
service_->Remove(&e);
return !e.ToChromeosError(error);
}
void ChromeosServiceDBusAdaptor::ActivateCellularModem(
DBusMethodResponsePtr<> response, const string& carrier) {
SLOG(this, 2) << __func__;
Error e(Error::kOperationInitiated);
ResultCallback callback = GetMethodReplyCallback(std::move(response));
service_->ActivateCellularModem(carrier, &e, callback);
ReturnResultOrDefer(callback, e);
}
bool ChromeosServiceDBusAdaptor::CompleteCellularActivation(
brillo::ErrorPtr* error) {
SLOG(this, 2) << __func__;
Error e;
service_->CompleteCellularActivation(&e);
return !e.ToChromeosError(error);
}
bool ChromeosServiceDBusAdaptor::GetLoadableProfileEntries(
brillo::ErrorPtr* /*error*/, map<dbus::ObjectPath, string>* entries) {
SLOG(this, 2) << __func__;
map<string, string> profile_entry_strings =
service_->GetLoadableProfileEntries();
for (const auto& entry : profile_entry_strings) {
entries->insert(
std::make_pair(dbus::ObjectPath(entry.first), entry.second));
}
return true;
}
} // namespace shill