blob: 30af9a672804d3808b6c2e2eaa1c978386034658 [file] [log] [blame]
Gunnar Mills57d9c502018-09-14 14:42:34 -05001#include "config.h"
2
Ratan Gupta6811f822017-04-14 16:34:56 +05303#include "network_manager.hpp"
Patrick Venture189d44e2018-07-09 12:30:59 -07004
William A. Kennington III09f3a4a2022-10-25 02:59:16 -07005#include "config_parser.hpp"
Ratan Gupta5978dd12017-07-25 13:47:13 +05306#include "ipaddress.hpp"
William A. Kennington III2e09d272022-10-14 17:15:00 -07007#include "system_queries.hpp"
William A. Kennington III3a70fa22018-09-20 18:48:20 -07008#include "types.hpp"
William A. Kennington IIIb8006122022-11-13 18:15:15 -08009#include "util.hpp"
10
William A. Kennington III57ca9612022-11-14 15:26:47 -080011#include <linux/if_addr.h>
William A. Kennington III7310ac72022-11-14 15:44:00 -080012#include <linux/neighbour.h>
William A. Kennington IIIb8006122022-11-13 18:15:15 -080013#include <net/if.h>
Ratan Gupta738a67f2017-04-21 10:38:05 +053014
Manojkiran Edacc099a82020-05-11 14:25:16 +053015#include <filesystem>
Patrick Venture189d44e2018-07-09 12:30:59 -070016#include <fstream>
Patrick Venture189d44e2018-07-09 12:30:59 -070017#include <phosphor-logging/elog-errors.hpp>
18#include <phosphor-logging/log.hpp>
William A. Kennington III80d29012022-11-12 02:31:40 -080019#include <sdbusplus/message.hpp>
Patrick Venture189d44e2018-07-09 12:30:59 -070020#include <xyz/openbmc_project/Common/error.hpp>
Ratan Gupta6811f822017-04-14 16:34:56 +053021
William A. Kennington IIIf1aa51c2019-02-12 19:58:11 -080022constexpr char SYSTEMD_BUSNAME[] = "org.freedesktop.systemd1";
23constexpr char SYSTEMD_PATH[] = "/org/freedesktop/systemd1";
24constexpr char SYSTEMD_INTERFACE[] = "org.freedesktop.systemd1.Manager";
Manojkiran Edacc099a82020-05-11 14:25:16 +053025constexpr auto FirstBootFile = "/var/lib/network/firstBoot_";
William A. Kennington IIIf1aa51c2019-02-12 19:58:11 -080026
William A. Kennington III56ecc782021-10-07 18:44:50 -070027constexpr char NETWORKD_BUSNAME[] = "org.freedesktop.network1";
28constexpr char NETWORKD_PATH[] = "/org/freedesktop/network1";
29constexpr char NETWORKD_INTERFACE[] = "org.freedesktop.network1.Manager";
30
Ratan Gupta6811f822017-04-14 16:34:56 +053031namespace phosphor
32{
33namespace network
34{
Ratan Gupta82549cc2017-04-21 08:45:23 +053035
William A. Kennington IIIc7cf25f2021-11-09 16:16:59 -080036extern std::unique_ptr<Timer> reloadTimer;
Ratan Gupta6811f822017-04-14 16:34:56 +053037using namespace phosphor::logging;
Ratan Guptaef85eb92017-06-15 08:57:54 +053038using namespace sdbusplus::xyz::openbmc_project::Common::Error;
Jiaqing Zhaob685cb62022-04-12 22:57:34 +080039using Argument = xyz::openbmc_project::Common::InvalidArgument;
Ratan Gupta6811f822017-04-14 16:34:56 +053040
William A. Kennington III80d29012022-11-12 02:31:40 -080041static constexpr const char enabledMatch[] =
42 "type='signal',sender='org.freedesktop.network1',path_namespace='/org/"
43 "freedesktop/network1/"
44 "link',interface='org.freedesktop.DBus.Properties',member='"
45 "PropertiesChanged',arg0='org.freedesktop.network1.Link',";
46
Patrick Williamsc38b0712022-07-22 19:26:54 -050047Manager::Manager(sdbusplus::bus_t& bus, const char* objPath,
William A. Kennington III5b179382022-11-15 15:23:26 -080048 const std::filesystem::path& confDir) :
49 ManagerIface(bus, objPath, ManagerIface::action::defer_emit),
50 bus(bus), objPath(std::string(objPath)), confDir(confDir),
William A. Kennington III80d29012022-11-12 02:31:40 -080051 systemdNetworkdEnabledMatch(
52 bus, enabledMatch, [&](sdbusplus::message_t& m) {
53 std::string intf;
54 std::unordered_map<std::string, std::variant<std::string>> values;
55 try
56 {
57 m.read(intf, values);
58 auto it = values.find("AdministrativeState");
59 if (it == values.end())
60 {
61 return;
62 }
63 const std::string_view obj = m.get_path();
64 auto sep = obj.rfind('/');
65 if (sep == obj.npos || sep + 3 > obj.size())
66 {
67 throw std::invalid_argument("Invalid obj path");
68 }
69 auto ifidx = DecodeInt<unsigned, 10>{}(obj.substr(sep + 3));
70 const auto& state = std::get<std::string>(it->second);
71 handleAdminState(state, ifidx);
72 }
73 catch (const std::exception& e)
74 {
75 log<level::ERR>(
76 fmt::format("AdministrativeState match parsing failed: {}",
77 e.what())
78 .c_str(),
79 entry("ERROR=%s", e.what()));
80 }
81 })
Ratan Gupta6811f822017-04-14 16:34:56 +053082{
William A. Kennington III80d29012022-11-12 02:31:40 -080083 std::vector<
84 std::tuple<int32_t, std::string, sdbusplus::message::object_path>>
85 links;
86 try
87 {
88 auto rsp =
89 bus.new_method_call("org.freedesktop.network1",
90 "/org/freedesktop/network1",
91 "org.freedesktop.network1.Manager", "ListLinks")
92 .call();
93 rsp.read(links);
94 }
95 catch (const sdbusplus::exception::SdBusError& e)
96 {
97 // Any failures are systemd-network not being ready
98 }
99 for (const auto& link : links)
100 {
101 unsigned ifidx = std::get<0>(link);
102 auto obj = fmt::format("/org/freedesktop/network1/link/_3{}", ifidx);
103 auto req =
104 bus.new_method_call("org.freedesktop.network1", obj.c_str(),
105 "org.freedesktop.DBus.Properties", "Get");
106 req.append("org.freedesktop.network1.Link", "AdministrativeState");
107 auto rsp = req.call();
108 std::variant<std::string> val;
109 rsp.read(val);
110 handleAdminState(std::get<std::string>(val), ifidx);
111 }
Ratan Guptaef85eb92017-06-15 08:57:54 +0530112
William A. Kennington III5b179382022-11-15 15:23:26 -0800113 std::filesystem::create_directories(confDir);
114 systemConf = std::make_unique<phosphor::network::SystemConfiguration>(
115 bus, (this->objPath / "config").str);
116 dhcpConf = std::make_unique<phosphor::network::dhcp::Configuration>(
117 bus, (this->objPath / "dhcp").str, *this);
Ratan Gupta29b0e432017-05-25 12:51:40 +0530118}
119
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800120void Manager::createInterface(const AllIntfInfo& info, bool enabled)
William A. Kennington III80d29012022-11-12 02:31:40 -0800121{
William A. Kennington III93f5c6d2022-11-17 16:23:44 -0800122 if (ignoredIntf.find(info.intf.idx) != ignoredIntf.end())
123 {
124 return;
125 }
William A. Kennington III5b179382022-11-15 15:23:26 -0800126 if (auto it = interfacesByIdx.find(info.intf.idx);
127 it != interfacesByIdx.end())
128 {
William A. Kennington III5b179382022-11-15 15:23:26 -0800129 if (info.intf.name && *info.intf.name != it->second->interfaceName())
130 {
William A. Kennington IIIbf290462022-11-15 19:44:25 -0800131 interfaces.erase(it->second->interfaceName());
132 interfacesByIdx.erase(it);
William A. Kennington III5b179382022-11-15 15:23:26 -0800133 }
William A. Kennington IIIbf290462022-11-15 19:44:25 -0800134 else
135 {
136 it->second->updateInfo(info.intf);
137 return;
138 }
William A. Kennington III5b179382022-11-15 15:23:26 -0800139 }
William A. Kennington III876927c2022-11-17 16:20:15 -0800140 else if (info.intf.name)
141 {
142 auto it = interfaces.find(*info.intf.name);
143 if (it != interfaces.end())
144 {
145 it->second->updateInfo(info.intf);
146 return;
147 }
148 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800149 if (!info.intf.name)
150 {
151 auto msg = fmt::format("Can't create interface without name: {}",
152 info.intf.idx);
153 log<level::ERR>(msg.c_str(), entry("IFIDX=%u", info.intf.idx));
154 return;
155 }
William A. Kennington IIIf30d5602022-11-13 17:09:55 -0800156 config::Parser config(config::pathForIntfConf(confDir, *info.intf.name));
William A. Kennington III80d29012022-11-12 02:31:40 -0800157 auto intf = std::make_unique<EthernetInterface>(
William A. Kennington III13d665c2022-11-15 20:34:40 -0800158 bus, *this, info, objPath.str, config, enabled);
William A. Kennington III80d29012022-11-12 02:31:40 -0800159 intf->loadNameServers(config);
160 intf->loadNTPServers(config);
161 auto ptr = intf.get();
William A. Kennington IIIf30d5602022-11-13 17:09:55 -0800162 interfaces.insert_or_assign(*info.intf.name, std::move(intf));
163 interfacesByIdx.insert_or_assign(info.intf.idx, ptr);
William A. Kennington III80d29012022-11-12 02:31:40 -0800164}
165
William A. Kennington III0813a242022-11-12 18:07:11 -0800166void Manager::addInterface(const InterfaceInfo& info)
167{
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800168 if (info.flags & IFF_LOOPBACK)
169 {
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800170 ignoredIntf.emplace(info.idx);
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800171 return;
172 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800173 if (info.name)
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800174 {
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800175 const auto& ignored = internal::getIgnoredInterfaces();
176 if (ignored.find(*info.name) != ignored.end())
177 {
178 static std::unordered_set<std::string> ignored;
179 if (!ignored.contains(*info.name))
180 {
181 ignored.emplace(*info.name);
182 auto msg = fmt::format("Ignoring interface {}\n", *info.name);
183 log<level::INFO>(msg.c_str());
184 }
185 ignoredIntf.emplace(info.idx);
186 return;
187 }
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800188 }
189
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800190 auto infoIt = intfInfo.find(info.idx);
191 if (infoIt != intfInfo.end())
William A. Kennington III0813a242022-11-12 18:07:11 -0800192 {
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800193 infoIt->second.intf = info;
William A. Kennington III0813a242022-11-12 18:07:11 -0800194 }
195 else
196 {
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800197 infoIt = std::get<0>(intfInfo.emplace(info.idx, AllIntfInfo{info}));
198 }
199
200 if (auto it = systemdNetworkdEnabled.find(info.idx);
201 it != systemdNetworkdEnabled.end())
202 {
203 createInterface(infoIt->second, it->second);
William A. Kennington III0813a242022-11-12 18:07:11 -0800204 }
205}
206
207void Manager::removeInterface(const InterfaceInfo& info)
208{
209 auto iit = interfacesByIdx.find(info.idx);
210 auto nit = interfaces.end();
211 if (info.name)
212 {
213 nit = interfaces.find(*info.name);
214 if (nit != interfaces.end() && iit != interfacesByIdx.end() &&
215 nit->second.get() != iit->second)
216 {
217 fmt::print(stderr, "Removed interface desync detected\n");
218 fflush(stderr);
219 std::abort();
220 }
221 }
222 else if (iit != interfacesByIdx.end())
223 {
224 for (nit = interfaces.begin(); nit != interfaces.end(); ++nit)
225 {
226 if (nit->second.get() == iit->second)
227 {
228 break;
229 }
230 }
231 }
232
233 if (iit != interfacesByIdx.end())
234 {
235 interfacesByIdx.erase(iit);
236 }
237 else
238 {
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800239 ignoredIntf.erase(info.idx);
William A. Kennington III0813a242022-11-12 18:07:11 -0800240 }
241 if (nit != interfaces.end())
242 {
243 interfaces.erase(nit);
244 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800245 intfInfo.erase(info.idx);
William A. Kennington III0813a242022-11-12 18:07:11 -0800246}
247
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800248void Manager::addAddress(const AddressInfo& info)
249{
William A. Kennington III57ca9612022-11-14 15:26:47 -0800250 if (info.flags & IFA_F_DEPRECATED)
251 {
252 return;
253 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800254 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
William A. Kennington III57ca9612022-11-14 15:26:47 -0800255 {
256 it->second.addrs.insert_or_assign(info.ifaddr, info);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800257 if (auto it = interfacesByIdx.find(info.ifidx);
258 it != interfacesByIdx.end())
259 {
260 it->second->addAddr(info);
261 }
William A. Kennington III57ca9612022-11-14 15:26:47 -0800262 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800263 else if (!ignoredIntf.contains(info.ifidx))
William A. Kennington III57ca9612022-11-14 15:26:47 -0800264 {
265 throw std::runtime_error(
266 fmt::format("Interface `{}` not found for addr", info.ifidx));
267 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800268}
269
270void Manager::removeAddress(const AddressInfo& info)
271{
William A. Kennington III57ca9612022-11-14 15:26:47 -0800272 if (auto it = interfacesByIdx.find(info.ifidx); it != interfacesByIdx.end())
273 {
274 it->second->addrs.erase(info.ifaddr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800275 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
276 {
277 it->second.addrs.erase(info.ifaddr);
278 }
William A. Kennington III57ca9612022-11-14 15:26:47 -0800279 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800280}
281
282void Manager::addNeighbor(const NeighborInfo& info)
283{
William A. Kennington III7310ac72022-11-14 15:44:00 -0800284 if (!(info.state & NUD_PERMANENT) || !info.addr)
285 {
286 return;
287 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800288 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
William A. Kennington III7310ac72022-11-14 15:44:00 -0800289 {
290 it->second.staticNeighs.insert_or_assign(*info.addr, info);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800291 if (auto it = interfacesByIdx.find(info.ifidx);
292 it != interfacesByIdx.end())
293 {
294 it->second->addStaticNeigh(info);
295 }
William A. Kennington III7310ac72022-11-14 15:44:00 -0800296 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800297 else if (!ignoredIntf.contains(info.ifidx))
William A. Kennington III7310ac72022-11-14 15:44:00 -0800298 {
299 throw std::runtime_error(
300 fmt::format("Interface `{}` not found for neigh", info.ifidx));
301 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800302}
303
304void Manager::removeNeighbor(const NeighborInfo& info)
305{
William A. Kennington III7310ac72022-11-14 15:44:00 -0800306 if (!info.addr)
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800307 {
William A. Kennington III7310ac72022-11-14 15:44:00 -0800308 return;
309 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800310 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
William A. Kennington III7310ac72022-11-14 15:44:00 -0800311 {
312 it->second.staticNeighs.erase(*info.addr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800313 if (auto it = interfacesByIdx.find(info.ifidx);
314 it != interfacesByIdx.end())
315 {
316 it->second->staticNeighbors.erase(*info.addr);
317 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800318 }
319}
320
321void Manager::addDefGw(unsigned ifidx, InAddrAny addr)
322{
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800323 if (auto it = intfInfo.find(ifidx); it != intfInfo.end())
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800324 {
325 std::visit(
326 [&](auto addr) {
327 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
328 {
329 it->second.defgw4.emplace(addr);
330 }
331 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
332 {
333 it->second.defgw6.emplace(addr);
334 }
335 else
336 {
337 static_assert(!std::is_same_v<void, decltype(addr)>);
338 }
339 },
340 addr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800341 if (auto it = interfacesByIdx.find(ifidx); it != interfacesByIdx.end())
342 {
343 std::visit(
344 [&](auto addr) {
345 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
346 {
347 it->second->EthernetInterfaceIntf::defaultGateway(
348 std::to_string(addr));
349 }
350 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
351 {
352 it->second->EthernetInterfaceIntf::defaultGateway6(
353 std::to_string(addr));
354 }
355 else
356 {
357 static_assert(!std::is_same_v<void, decltype(addr)>);
358 }
359 },
360 addr);
361 }
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800362 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800363 else if (!ignoredIntf.contains(ifidx))
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800364 {
365 auto msg = fmt::format("Interface `{}` not found for gw", ifidx);
366 log<level::ERR>(msg.c_str(), entry("IFIDX=%u", ifidx));
367 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800368}
369
370void Manager::removeDefGw(unsigned ifidx, InAddrAny addr)
371{
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800372 if (auto it = intfInfo.find(ifidx); it != intfInfo.end())
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800373 {
374 std::visit(
375 [&](auto addr) {
376 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
377 {
378 if (it->second.defgw4 == addr)
379 {
380 it->second.defgw4.reset();
381 }
382 }
383 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
384 {
385 if (it->second.defgw6 == addr)
386 {
387 it->second.defgw6.reset();
388 }
389 }
390 else
391 {
392 static_assert(!std::is_same_v<void, decltype(addr)>);
393 }
394 },
395 addr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800396 if (auto it = interfacesByIdx.find(ifidx); it != interfacesByIdx.end())
397 {
398 std::visit(
399 [&](auto addr) {
400 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
401 {
402 if (it->second->defaultGateway() ==
403 std::to_string(addr))
404 {
405 it->second->EthernetInterfaceIntf::defaultGateway(
406 "");
407 }
408 }
409 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
410 {
411 if (it->second->defaultGateway6() ==
412 std::to_string(addr))
413 {
414 it->second->EthernetInterfaceIntf::defaultGateway6(
415 "");
416 }
417 }
418 else
419 {
420 static_assert(!std::is_same_v<void, decltype(addr)>);
421 }
422 },
423 addr);
424 }
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800425 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800426}
427
William A. Kennington III085bbdc2022-10-05 02:45:37 -0700428ObjectPath Manager::vlan(std::string interfaceName, uint32_t id)
Ratan Gupta6811f822017-04-14 16:34:56 +0530429{
Jiaqing Zhaob685cb62022-04-12 22:57:34 +0800430 if (id == 0 || id >= 4095)
431 {
432 log<level::ERR>("VLAN ID is not valid", entry("VLANID=%u", id));
433 elog<InvalidArgument>(
434 Argument::ARGUMENT_NAME("VLANId"),
435 Argument::ARGUMENT_VALUE(std::to_string(id).c_str()));
436 }
437
William A. Kennington III96444792022-10-05 15:16:22 -0700438 auto it = interfaces.find(interfaceName);
439 if (it == interfaces.end())
440 {
441 using ResourceErr =
442 phosphor::logging::xyz::openbmc_project::Common::ResourceNotFound;
443 elog<ResourceNotFound>(ResourceErr::RESOURCE(interfaceName.c_str()));
444 }
445 return it->second->createVLAN(id);
Ratan Gupta6811f822017-04-14 16:34:56 +0530446}
447
Michael Tritz29f2fd62017-05-22 15:27:26 -0500448void Manager::reset()
449{
William A. Kennington III5b179382022-11-15 15:23:26 -0800450 for (const auto& dirent : std::filesystem::directory_iterator(confDir))
Michael Tritz29f2fd62017-05-22 15:27:26 -0500451 {
William A. Kennington III5b179382022-11-15 15:23:26 -0800452 std::error_code ec;
453 std::filesystem::remove(dirent.path(), ec);
Michael Tritz29f2fd62017-05-22 15:27:26 -0500454 }
William A. Kennington III5b179382022-11-15 15:23:26 -0800455 log<level::INFO>("Network data purged.");
Michael Tritz29f2fd62017-05-22 15:27:26 -0500456}
457
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530458// Need to merge the below function with the code which writes the
459// config file during factory reset.
Gunnar Mills57d9c502018-09-14 14:42:34 -0500460// TODO openbmc/openbmc#1751
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530461void Manager::writeToConfigurationFile()
462{
463 // write all the static ip address in the systemd-network conf file
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530464 for (const auto& intf : interfaces)
465 {
Ratan Gupta2b106532017-07-25 16:05:02 +0530466 intf.second->writeConfigurationFile();
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530467 }
Ratan Guptae05083a2017-09-16 07:12:11 +0530468}
469
William A. Kennington III6f39c5e2021-05-13 18:39:23 -0700470#ifdef SYNC_MAC_FROM_INVENTORY
Manojkiran Edacc099a82020-05-11 14:25:16 +0530471void Manager::setFistBootMACOnInterface(
472 const std::pair<std::string, std::string>& inventoryEthPair)
473{
474 for (const auto& interface : interfaces)
475 {
476 if (interface.first == inventoryEthPair.first)
477 {
478 auto returnMAC =
Patrick Williams6aef7692021-05-01 06:39:41 -0500479 interface.second->macAddress(inventoryEthPair.second);
Manojkiran Edacc099a82020-05-11 14:25:16 +0530480 if (returnMAC == inventoryEthPair.second)
481 {
482 log<level::INFO>("Set the MAC on "),
483 entry("interface : ", interface.first.c_str()),
484 entry("MAC : ", inventoryEthPair.second.c_str());
485 std::error_code ec;
486 if (std::filesystem::is_directory("/var/lib/network", ec))
487 {
488 std::ofstream persistentFile(FirstBootFile +
489 interface.first);
490 }
491 break;
492 }
493 else
494 {
495 log<level::INFO>("MAC is Not Set on ethernet Interface");
496 }
497 }
498 }
499}
500
501#endif
502
William A. Kennington III85dc57a2022-11-07 16:53:24 -0800503void Manager::reloadConfigs()
504{
William A. Kennington III5b179382022-11-15 15:23:26 -0800505 reloadTimer->restartOnce(reloadTimeout);
William A. Kennington IIIc7cf25f2021-11-09 16:16:59 -0800506}
507
508void Manager::doReloadConfigs()
509{
William A. Kennington III6ff633a2021-11-09 17:09:12 -0800510 for (auto& hook : reloadPreHooks)
511 {
512 try
513 {
514 hook();
515 }
516 catch (const std::exception& ex)
517 {
518 log<level::ERR>("Failed executing reload hook, ignoring",
519 entry("ERR=%s", ex.what()));
520 }
521 }
522 reloadPreHooks.clear();
William A. Kennington III56ecc782021-10-07 18:44:50 -0700523 try
524 {
525 auto method = bus.new_method_call(NETWORKD_BUSNAME, NETWORKD_PATH,
526 NETWORKD_INTERFACE, "Reload");
527 bus.call_noreply(method);
528 }
Patrick Williamsc38b0712022-07-22 19:26:54 -0500529 catch (const sdbusplus::exception_t& ex)
William A. Kennington III56ecc782021-10-07 18:44:50 -0700530 {
531 log<level::ERR>("Failed to reload configuration",
532 entry("ERR=%s", ex.what()));
William A. Kennington IIIde4668a2022-11-17 16:02:30 -0800533 reloadPostHooks.clear();
William A. Kennington III56ecc782021-10-07 18:44:50 -0700534 }
William A. Kennington IIIde4668a2022-11-17 16:02:30 -0800535 for (auto& hook : reloadPostHooks)
536 {
537 try
538 {
539 hook();
540 }
541 catch (const std::exception& ex)
542 {
543 log<level::ERR>("Failed executing reload hook, ignoring",
544 entry("ERR=%s", ex.what()));
545 }
546 }
547 reloadPostHooks.clear();
William A. Kennington III56ecc782021-10-07 18:44:50 -0700548}
549
William A. Kennington III80d29012022-11-12 02:31:40 -0800550void Manager::handleAdminState(std::string_view state, unsigned ifidx)
551{
552 if (state == "initialized" || state == "linger")
553 {
554 systemdNetworkdEnabled.erase(ifidx);
555 }
556 else
557 {
558 bool managed = state != "unmanaged";
559 systemdNetworkdEnabled.insert_or_assign(ifidx, managed);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800560 if (auto it = interfacesByIdx.find(ifidx); it != interfacesByIdx.end())
William A. Kennington III80d29012022-11-12 02:31:40 -0800561 {
562 it->second->EthernetInterfaceIntf::nicEnabled(managed);
563 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800564 else if (auto it = intfInfo.find(ifidx); it != intfInfo.end())
565 {
566 createInterface(it->second, managed);
567 }
William A. Kennington III80d29012022-11-12 02:31:40 -0800568 }
569}
570
Gunnar Mills57d9c502018-09-14 14:42:34 -0500571} // namespace network
572} // namespace phosphor