Ben Chan | fad4a0b | 2012-04-18 15:49:59 -0700 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
Darin Petkov | 50308cd | 2011-06-01 18:25:07 -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/dhcp_provider.h" |
| 6 | |
Ben Chan | 11c213f | 2014-09-05 08:21:06 -0700 | [diff] [blame] | 7 | #include <base/files/file_util.h> |
Ben Chan | a0ddf46 | 2014-02-06 11:32:42 -0800 | [diff] [blame] | 8 | #include <base/strings/stringprintf.h> |
Albert Chaulk | 0e1cdea | 2013-02-27 15:32:55 -0800 | [diff] [blame] | 9 | |
Chris Masone | 19e3040 | 2011-07-19 15:48:47 -0700 | [diff] [blame] | 10 | #include "shill/control_interface.h" |
Chris Masone | 2b10554 | 2011-06-22 10:58:09 -0700 | [diff] [blame] | 11 | #include "shill/dhcp_config.h" |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 12 | #include "shill/dhcpcd_proxy.h" |
Christopher Wiley | b691efd | 2012-08-09 13:51:51 -0700 | [diff] [blame] | 13 | #include "shill/logging.h" |
Paul Stewart | 8dc5e7b | 2014-12-11 19:24:50 -0800 | [diff] [blame] | 14 | #include "shill/shared_dbus_connection.h" |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 15 | |
Albert Chaulk | 0e1cdea | 2013-02-27 15:32:55 -0800 | [diff] [blame] | 16 | using base::FilePath; |
Darin Petkov | f65e928 | 2011-06-21 14:29:56 -0700 | [diff] [blame] | 17 | using std::string; |
| 18 | |
Darin Petkov | 50308cd | 2011-06-01 18:25:07 -0700 | [diff] [blame] | 19 | namespace shill { |
| 20 | |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 21 | namespace Logging { |
| 22 | static auto kModuleLogScope = ScopeLogger::kDHCP; |
| 23 | static string ObjectID(DHCPProvider *d) { return "(dhcp_provider)"; } |
| 24 | } |
| 25 | |
Darin Petkov | e636c69 | 2012-05-31 10:22:17 +0200 | [diff] [blame] | 26 | namespace { |
| 27 | base::LazyInstance<DHCPProvider> g_dhcp_provider = LAZY_INSTANCE_INITIALIZER; |
| 28 | } // namespace |
Paul Stewart | 0d2ada3 | 2011-08-09 17:01:57 -0700 | [diff] [blame] | 29 | |
mukesh agrawal | 88fb16f | 2014-04-24 10:37:39 -0700 | [diff] [blame] | 30 | constexpr char DHCPProvider::kDHCPCDPathFormatLease[]; |
Albert Chaulk | 0e1cdea | 2013-02-27 15:32:55 -0800 | [diff] [blame] | 31 | |
Darin Petkov | a7b8949 | 2011-07-27 12:48:17 -0700 | [diff] [blame] | 32 | DHCPProvider::DHCPProvider() |
Paul Stewart | 8dc5e7b | 2014-12-11 19:24:50 -0800 | [diff] [blame] | 33 | : shared_dbus_connection_(SharedDBusConnection::GetInstance()), |
Albert Chaulk | 0e1cdea | 2013-02-27 15:32:55 -0800 | [diff] [blame] | 34 | root_("/"), |
Ben Chan | cc225ef | 2014-09-30 13:26:51 -0700 | [diff] [blame] | 35 | control_interface_(nullptr), |
| 36 | dispatcher_(nullptr), |
| 37 | glib_(nullptr), |
| 38 | metrics_(nullptr) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 39 | SLOG(this, 2) << __func__; |
Darin Petkov | 50308cd | 2011-06-01 18:25:07 -0700 | [diff] [blame] | 40 | } |
| 41 | |
| 42 | DHCPProvider::~DHCPProvider() { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 43 | SLOG(this, 2) << __func__; |
Darin Petkov | 50308cd | 2011-06-01 18:25:07 -0700 | [diff] [blame] | 44 | } |
| 45 | |
| 46 | DHCPProvider* DHCPProvider::GetInstance() { |
Paul Stewart | 0d2ada3 | 2011-08-09 17:01:57 -0700 | [diff] [blame] | 47 | return g_dhcp_provider.Pointer(); |
Darin Petkov | 50308cd | 2011-06-01 18:25:07 -0700 | [diff] [blame] | 48 | } |
| 49 | |
Darin Petkov | a7b8949 | 2011-07-27 12:48:17 -0700 | [diff] [blame] | 50 | void DHCPProvider::Init(ControlInterface *control_interface, |
| 51 | EventDispatcher *dispatcher, |
Paul Stewart | 3bdf1ab | 2014-07-17 19:22:26 -0700 | [diff] [blame] | 52 | GLib *glib, |
| 53 | Metrics *metrics) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 54 | SLOG(this, 2) << __func__; |
Paul Stewart | 04f00c6 | 2015-01-08 15:59:10 -0800 | [diff] [blame] | 55 | DBus::Connection *connection = shared_dbus_connection_->GetProxyConnection(); |
Paul Stewart | 8dc5e7b | 2014-12-11 19:24:50 -0800 | [diff] [blame] | 56 | listener_.reset(new DHCPCDListener(connection, this)); |
Darin Petkov | f7897bc | 2011-06-08 17:13:36 -0700 | [diff] [blame] | 57 | glib_ = glib; |
Chris Masone | 19e3040 | 2011-07-19 15:48:47 -0700 | [diff] [blame] | 58 | control_interface_ = control_interface; |
Darin Petkov | a7b8949 | 2011-07-27 12:48:17 -0700 | [diff] [blame] | 59 | dispatcher_ = dispatcher; |
Paul Stewart | 3bdf1ab | 2014-07-17 19:22:26 -0700 | [diff] [blame] | 60 | metrics_ = metrics; |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 61 | } |
| 62 | |
Paul Stewart | 8dc5e7b | 2014-12-11 19:24:50 -0800 | [diff] [blame] | 63 | void DHCPProvider::Stop() { |
| 64 | listener_.reset(); |
| 65 | } |
| 66 | |
Paul Stewart | d32f484 | 2012-01-11 16:08:13 -0800 | [diff] [blame] | 67 | DHCPConfigRefPtr DHCPProvider::CreateConfig(const string &device_name, |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 68 | const string &host_name, |
| 69 | const string &lease_file_suffix, |
Paul Stewart | b108318 | 2014-06-25 03:04:53 -0700 | [diff] [blame] | 70 | bool arp_gateway) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 71 | SLOG(this, 2) << __func__ << " device: " << device_name; |
Paul Stewart | d408fdf | 2012-05-07 17:15:57 -0700 | [diff] [blame] | 72 | return new DHCPConfig(control_interface_, |
| 73 | dispatcher_, |
| 74 | this, |
| 75 | device_name, |
| 76 | host_name, |
| 77 | lease_file_suffix, |
| 78 | arp_gateway, |
Paul Stewart | 3bdf1ab | 2014-07-17 19:22:26 -0700 | [diff] [blame] | 79 | glib_, |
| 80 | metrics_); |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 81 | } |
| 82 | |
Darin Petkov | 98dd6a0 | 2011-06-10 15:12:57 -0700 | [diff] [blame] | 83 | DHCPConfigRefPtr DHCPProvider::GetConfig(int pid) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 84 | SLOG(this, 2) << __func__ << " pid: " << pid; |
Darin Petkov | f9b0ca8 | 2011-06-20 12:10:23 -0700 | [diff] [blame] | 85 | PIDConfigMap::const_iterator it = configs_.find(pid); |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 86 | if (it == configs_.end()) { |
Ben Chan | cc225ef | 2014-09-30 13:26:51 -0700 | [diff] [blame] | 87 | return nullptr; |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 88 | } |
| 89 | return it->second; |
| 90 | } |
| 91 | |
Chris Masone | 2b10554 | 2011-06-22 10:58:09 -0700 | [diff] [blame] | 92 | void DHCPProvider::BindPID(int pid, const DHCPConfigRefPtr &config) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 93 | SLOG(this, 2) << __func__ << " pid: " << pid; |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 94 | configs_[pid] = config; |
| 95 | } |
| 96 | |
Darin Petkov | 92c4390 | 2011-06-09 20:46:06 -0700 | [diff] [blame] | 97 | void DHCPProvider::UnbindPID(int pid) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 98 | SLOG(this, 2) << __func__ << " pid: " << pid; |
Darin Petkov | d1b715b | 2011-06-02 21:21:22 -0700 | [diff] [blame] | 99 | configs_.erase(pid); |
| 100 | } |
| 101 | |
Albert Chaulk | 0e1cdea | 2013-02-27 15:32:55 -0800 | [diff] [blame] | 102 | void DHCPProvider::DestroyLease(const string &name) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 103 | SLOG(this, 2) << __func__ << " name: " << name; |
Ben Chan | a0ddf46 | 2014-02-06 11:32:42 -0800 | [diff] [blame] | 104 | base::DeleteFile(root_.Append( |
Albert Chaulk | 0e1cdea | 2013-02-27 15:32:55 -0800 | [diff] [blame] | 105 | base::StringPrintf(kDHCPCDPathFormatLease, |
| 106 | name.c_str())), false); |
| 107 | } |
| 108 | |
Darin Petkov | 50308cd | 2011-06-01 18:25:07 -0700 | [diff] [blame] | 109 | } // namespace shill |