// // 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/ppp_daemon.h" #include <stdint.h> #include <map> #include <string> #include <vector> #include <base/files/file_path.h> #include <base/memory/weak_ptr.h> #include <base/strings/string_number_conversions.h> #include "shill/control_interface.h" #include "shill/error.h" #include "shill/external_task.h" #include "shill/ppp_device.h" namespace shill { const char PPPDaemon::kDaemonPath[] = "/usr/sbin/pppd"; const char PPPDaemon::kShimPluginPath[] = SHIMDIR "/shill-pppd-plugin.so"; const char PPPDaemon::kPPPoEPluginPath[] = "rp-pppoe.so"; const uint32_t PPPDaemon::kUnspecifiedValue = UINT32_MAX; std::unique_ptr<ExternalTask> PPPDaemon::Start( ControlInterface* control_interface, ProcessManager* process_manager, const base::WeakPtr<RPCTaskDelegate>& task_delegate, const PPPDaemon::Options& options, const std::string& device, const PPPDaemon::DeathCallback& death_callback, Error* error) { std::vector<std::string> arguments; if (options.debug) { arguments.push_back("debug"); } if (options.no_detach) { arguments.push_back("nodetach"); } if (options.no_default_route) { arguments.push_back("nodefaultroute"); } if (options.use_peer_dns) { arguments.push_back("usepeerdns"); } if (options.use_shim_plugin) { arguments.push_back("plugin"); arguments.push_back(kShimPluginPath); } if (options.use_pppoe_plugin) { arguments.push_back("plugin"); arguments.push_back(kPPPoEPluginPath); } if (options.lcp_echo_interval != kUnspecifiedValue) { arguments.push_back("lcp-echo-interval"); arguments.push_back(base::UintToString(options.lcp_echo_interval)); } if (options.lcp_echo_failure != kUnspecifiedValue) { arguments.push_back("lcp-echo-failure"); arguments.push_back(base::UintToString(options.lcp_echo_failure)); } if (options.max_fail != kUnspecifiedValue) { arguments.push_back("maxfail"); arguments.push_back(base::UintToString(options.max_fail)); } if (options.use_ipv6) { arguments.push_back("+ipv6"); arguments.push_back("ipv6cp-use-ipaddr"); } arguments.push_back(device); std::unique_ptr<ExternalTask> task(new ExternalTask( control_interface, process_manager, task_delegate, death_callback)); std::map<std::string, std::string> environment; if (task->Start(base::FilePath(kDaemonPath), arguments, environment, true, error)) { return task; } return nullptr; } } // namespace shill