//
// Copyright 2015 Google, Inc.
//
// 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 "service/settings.h"
#include <base/base_switches.h>
#include <base/command_line.h>
#include <base/logging.h>
#include "service/switches.h"
namespace bluetooth {
Settings::Settings() : initialized_(false), enable_on_start_(false) {}
Settings::~Settings() {}
bool Settings::Init() {
CHECK(!initialized_);
auto command_line = base::CommandLine::ForCurrentProcess();
const auto& switches = command_line->GetSwitches();
for (const auto& iter : switches) {
if (iter.first == switches::kCreateIPCSocketPath) {
// kCreateIPCSocketPath: An optional argument that initializes an IPC
// socket path for IPC.
base::FilePath path(iter.second);
if (path.empty() || path.EndsWithSeparator()) {
LOG(ERROR) << "Invalid IPC create socket path";
return false;
}
create_ipc_socket_path_ = path;
} else if (iter.first == switches::kAndroidIPCSocketSuffix) {
// kAndroidIPCSocketSuffix: An optional argument used to express
// a socket that Android init created for us. We bind to this.
const std::string& suffix = iter.second;
if (suffix.empty()) {
LOG(ERROR) << "Invalid Android socket suffix";
return false;
}
android_ipc_socket_suffix_ = suffix;
} else if (iter.first == switches::kEnableOnStart) {
if (iter.second == "true") {
enable_on_start_ = true;
} else if (iter.second == "false") {
enable_on_start_ = false;
} else {
LOG(ERROR) << "Invalid value for " << switches::kEnableOnStart << ": "
<< iter.second << ". Expect 'true' or 'false'";
return false;
}
}
// Check for libbase logging switches. These get processed by
// logging::InitLogging directly.
else if (iter.first != ::switches::kV) {
LOG(ERROR) << "Unexpected command-line switches found: " << iter.first;
return false;
}
}
// Two IPC methods/paths were provided.
if (!android_ipc_socket_suffix_.empty() && !create_ipc_socket_path_.empty()) {
LOG(ERROR) << "Too many IPC methods provided";
return false;
}
// The daemon has no arguments
if (command_line->GetArgs().size()) {
LOG(ERROR) << "Unexpected command-line arguments found";
return false;
}
initialized_ = true;
return true;
}
} // namespace bluetooth