blob: 51863a770c8bc6449c3dad5030c9c523691c9e9c [file] [log] [blame]
Ratan Gupta6811f822017-04-14 16:34:56 +05301#include "network_manager.hpp"
Patrick Venture189d44e2018-07-09 12:30:59 -07002
William A. Kennington III09f3a4a2022-10-25 02:59:16 -07003#include "config_parser.hpp"
Ratan Gupta5978dd12017-07-25 13:47:13 +05304#include "ipaddress.hpp"
William A. Kennington III2e09d272022-10-14 17:15:00 -07005#include "system_queries.hpp"
William A. Kennington III3a70fa22018-09-20 18:48:20 -07006#include "types.hpp"
William A. Kennington IIIb8006122022-11-13 18:15:15 -08007#include "util.hpp"
8
William A. Kennington III57ca9612022-11-14 15:26:47 -08009#include <linux/if_addr.h>
William A. Kennington III7310ac72022-11-14 15:44:00 -080010#include <linux/neighbour.h>
William A. Kennington IIIb8006122022-11-13 18:15:15 -080011#include <net/if.h>
Ratan Gupta738a67f2017-04-21 10:38:05 +053012
Manojkiran Edacc099a82020-05-11 14:25:16 +053013#include <filesystem>
Patrick Venture189d44e2018-07-09 12:30:59 -070014#include <phosphor-logging/elog-errors.hpp>
15#include <phosphor-logging/log.hpp>
William A. Kennington III80d29012022-11-12 02:31:40 -080016#include <sdbusplus/message.hpp>
Patrick Venture189d44e2018-07-09 12:30:59 -070017#include <xyz/openbmc_project/Common/error.hpp>
Ratan Gupta6811f822017-04-14 16:34:56 +053018
William A. Kennington IIIf1aa51c2019-02-12 19:58:11 -080019constexpr char SYSTEMD_BUSNAME[] = "org.freedesktop.systemd1";
20constexpr char SYSTEMD_PATH[] = "/org/freedesktop/systemd1";
21constexpr char SYSTEMD_INTERFACE[] = "org.freedesktop.systemd1.Manager";
22
William A. Kennington III56ecc782021-10-07 18:44:50 -070023constexpr char NETWORKD_BUSNAME[] = "org.freedesktop.network1";
24constexpr char NETWORKD_PATH[] = "/org/freedesktop/network1";
25constexpr char NETWORKD_INTERFACE[] = "org.freedesktop.network1.Manager";
26
Ratan Gupta6811f822017-04-14 16:34:56 +053027namespace phosphor
28{
29namespace network
30{
Ratan Gupta82549cc2017-04-21 08:45:23 +053031
William A. Kennington IIIc7cf25f2021-11-09 16:16:59 -080032extern std::unique_ptr<Timer> reloadTimer;
Ratan Gupta6811f822017-04-14 16:34:56 +053033using namespace phosphor::logging;
Ratan Guptaef85eb92017-06-15 08:57:54 +053034using namespace sdbusplus::xyz::openbmc_project::Common::Error;
Jiaqing Zhaob685cb62022-04-12 22:57:34 +080035using Argument = xyz::openbmc_project::Common::InvalidArgument;
Ratan Gupta6811f822017-04-14 16:34:56 +053036
William A. Kennington III80d29012022-11-12 02:31:40 -080037static constexpr const char enabledMatch[] =
38 "type='signal',sender='org.freedesktop.network1',path_namespace='/org/"
39 "freedesktop/network1/"
40 "link',interface='org.freedesktop.DBus.Properties',member='"
41 "PropertiesChanged',arg0='org.freedesktop.network1.Link',";
42
Patrick Williamsc38b0712022-07-22 19:26:54 -050043Manager::Manager(sdbusplus::bus_t& bus, const char* objPath,
William A. Kennington III5b179382022-11-15 15:23:26 -080044 const std::filesystem::path& confDir) :
45 ManagerIface(bus, objPath, ManagerIface::action::defer_emit),
46 bus(bus), objPath(std::string(objPath)), confDir(confDir),
William A. Kennington III80d29012022-11-12 02:31:40 -080047 systemdNetworkdEnabledMatch(
48 bus, enabledMatch, [&](sdbusplus::message_t& m) {
49 std::string intf;
50 std::unordered_map<std::string, std::variant<std::string>> values;
51 try
52 {
53 m.read(intf, values);
54 auto it = values.find("AdministrativeState");
55 if (it == values.end())
56 {
57 return;
58 }
59 const std::string_view obj = m.get_path();
60 auto sep = obj.rfind('/');
61 if (sep == obj.npos || sep + 3 > obj.size())
62 {
63 throw std::invalid_argument("Invalid obj path");
64 }
65 auto ifidx = DecodeInt<unsigned, 10>{}(obj.substr(sep + 3));
66 const auto& state = std::get<std::string>(it->second);
67 handleAdminState(state, ifidx);
68 }
69 catch (const std::exception& e)
70 {
71 log<level::ERR>(
72 fmt::format("AdministrativeState match parsing failed: {}",
73 e.what())
74 .c_str(),
75 entry("ERROR=%s", e.what()));
76 }
77 })
Ratan Gupta6811f822017-04-14 16:34:56 +053078{
William A. Kennington III80d29012022-11-12 02:31:40 -080079 std::vector<
80 std::tuple<int32_t, std::string, sdbusplus::message::object_path>>
81 links;
82 try
83 {
84 auto rsp =
85 bus.new_method_call("org.freedesktop.network1",
86 "/org/freedesktop/network1",
87 "org.freedesktop.network1.Manager", "ListLinks")
88 .call();
89 rsp.read(links);
90 }
91 catch (const sdbusplus::exception::SdBusError& e)
92 {
93 // Any failures are systemd-network not being ready
94 }
95 for (const auto& link : links)
96 {
97 unsigned ifidx = std::get<0>(link);
98 auto obj = fmt::format("/org/freedesktop/network1/link/_3{}", ifidx);
99 auto req =
100 bus.new_method_call("org.freedesktop.network1", obj.c_str(),
101 "org.freedesktop.DBus.Properties", "Get");
102 req.append("org.freedesktop.network1.Link", "AdministrativeState");
103 auto rsp = req.call();
104 std::variant<std::string> val;
105 rsp.read(val);
106 handleAdminState(std::get<std::string>(val), ifidx);
107 }
Ratan Guptaef85eb92017-06-15 08:57:54 +0530108
William A. Kennington III5b179382022-11-15 15:23:26 -0800109 std::filesystem::create_directories(confDir);
110 systemConf = std::make_unique<phosphor::network::SystemConfiguration>(
111 bus, (this->objPath / "config").str);
112 dhcpConf = std::make_unique<phosphor::network::dhcp::Configuration>(
113 bus, (this->objPath / "dhcp").str, *this);
Ratan Gupta29b0e432017-05-25 12:51:40 +0530114}
115
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800116void Manager::createInterface(const AllIntfInfo& info, bool enabled)
William A. Kennington III80d29012022-11-12 02:31:40 -0800117{
William A. Kennington III93f5c6d2022-11-17 16:23:44 -0800118 if (ignoredIntf.find(info.intf.idx) != ignoredIntf.end())
119 {
120 return;
121 }
William A. Kennington III5b179382022-11-15 15:23:26 -0800122 if (auto it = interfacesByIdx.find(info.intf.idx);
123 it != interfacesByIdx.end())
124 {
William A. Kennington III5b179382022-11-15 15:23:26 -0800125 if (info.intf.name && *info.intf.name != it->second->interfaceName())
126 {
William A. Kennington IIIbf290462022-11-15 19:44:25 -0800127 interfaces.erase(it->second->interfaceName());
128 interfacesByIdx.erase(it);
William A. Kennington III5b179382022-11-15 15:23:26 -0800129 }
William A. Kennington IIIbf290462022-11-15 19:44:25 -0800130 else
131 {
132 it->second->updateInfo(info.intf);
133 return;
134 }
William A. Kennington III5b179382022-11-15 15:23:26 -0800135 }
William A. Kennington III876927c2022-11-17 16:20:15 -0800136 else if (info.intf.name)
137 {
138 auto it = interfaces.find(*info.intf.name);
139 if (it != interfaces.end())
140 {
141 it->second->updateInfo(info.intf);
142 return;
143 }
144 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800145 if (!info.intf.name)
146 {
147 auto msg = fmt::format("Can't create interface without name: {}",
148 info.intf.idx);
149 log<level::ERR>(msg.c_str(), entry("IFIDX=%u", info.intf.idx));
150 return;
151 }
William A. Kennington IIIf30d5602022-11-13 17:09:55 -0800152 config::Parser config(config::pathForIntfConf(confDir, *info.intf.name));
William A. Kennington III80d29012022-11-12 02:31:40 -0800153 auto intf = std::make_unique<EthernetInterface>(
William A. Kennington III13d665c2022-11-15 20:34:40 -0800154 bus, *this, info, objPath.str, config, enabled);
William A. Kennington III80d29012022-11-12 02:31:40 -0800155 intf->loadNameServers(config);
156 intf->loadNTPServers(config);
157 auto ptr = intf.get();
William A. Kennington IIIf30d5602022-11-13 17:09:55 -0800158 interfaces.insert_or_assign(*info.intf.name, std::move(intf));
159 interfacesByIdx.insert_or_assign(info.intf.idx, ptr);
William A. Kennington III80d29012022-11-12 02:31:40 -0800160}
161
William A. Kennington III0813a242022-11-12 18:07:11 -0800162void Manager::addInterface(const InterfaceInfo& info)
163{
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800164 if (info.flags & IFF_LOOPBACK)
165 {
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800166 ignoredIntf.emplace(info.idx);
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800167 return;
168 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800169 if (info.name)
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800170 {
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800171 const auto& ignored = internal::getIgnoredInterfaces();
172 if (ignored.find(*info.name) != ignored.end())
173 {
174 static std::unordered_set<std::string> ignored;
175 if (!ignored.contains(*info.name))
176 {
177 ignored.emplace(*info.name);
178 auto msg = fmt::format("Ignoring interface {}\n", *info.name);
179 log<level::INFO>(msg.c_str());
180 }
181 ignoredIntf.emplace(info.idx);
182 return;
183 }
William A. Kennington IIIb8006122022-11-13 18:15:15 -0800184 }
185
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800186 auto infoIt = intfInfo.find(info.idx);
187 if (infoIt != intfInfo.end())
William A. Kennington III0813a242022-11-12 18:07:11 -0800188 {
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800189 infoIt->second.intf = info;
William A. Kennington III0813a242022-11-12 18:07:11 -0800190 }
191 else
192 {
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800193 infoIt = std::get<0>(intfInfo.emplace(info.idx, AllIntfInfo{info}));
194 }
195
196 if (auto it = systemdNetworkdEnabled.find(info.idx);
197 it != systemdNetworkdEnabled.end())
198 {
199 createInterface(infoIt->second, it->second);
William A. Kennington III0813a242022-11-12 18:07:11 -0800200 }
201}
202
203void Manager::removeInterface(const InterfaceInfo& info)
204{
205 auto iit = interfacesByIdx.find(info.idx);
206 auto nit = interfaces.end();
207 if (info.name)
208 {
209 nit = interfaces.find(*info.name);
210 if (nit != interfaces.end() && iit != interfacesByIdx.end() &&
211 nit->second.get() != iit->second)
212 {
213 fmt::print(stderr, "Removed interface desync detected\n");
214 fflush(stderr);
215 std::abort();
216 }
217 }
218 else if (iit != interfacesByIdx.end())
219 {
220 for (nit = interfaces.begin(); nit != interfaces.end(); ++nit)
221 {
222 if (nit->second.get() == iit->second)
223 {
224 break;
225 }
226 }
227 }
228
229 if (iit != interfacesByIdx.end())
230 {
231 interfacesByIdx.erase(iit);
232 }
233 else
234 {
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800235 ignoredIntf.erase(info.idx);
William A. Kennington III0813a242022-11-12 18:07:11 -0800236 }
237 if (nit != interfaces.end())
238 {
239 interfaces.erase(nit);
240 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800241 intfInfo.erase(info.idx);
William A. Kennington III0813a242022-11-12 18:07:11 -0800242}
243
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800244void Manager::addAddress(const AddressInfo& info)
245{
William A. Kennington III57ca9612022-11-14 15:26:47 -0800246 if (info.flags & IFA_F_DEPRECATED)
247 {
248 return;
249 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800250 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
William A. Kennington III57ca9612022-11-14 15:26:47 -0800251 {
252 it->second.addrs.insert_or_assign(info.ifaddr, info);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800253 if (auto it = interfacesByIdx.find(info.ifidx);
254 it != interfacesByIdx.end())
255 {
256 it->second->addAddr(info);
257 }
William A. Kennington III57ca9612022-11-14 15:26:47 -0800258 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800259 else if (!ignoredIntf.contains(info.ifidx))
William A. Kennington III57ca9612022-11-14 15:26:47 -0800260 {
261 throw std::runtime_error(
262 fmt::format("Interface `{}` not found for addr", info.ifidx));
263 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800264}
265
266void Manager::removeAddress(const AddressInfo& info)
267{
William A. Kennington III57ca9612022-11-14 15:26:47 -0800268 if (auto it = interfacesByIdx.find(info.ifidx); it != interfacesByIdx.end())
269 {
270 it->second->addrs.erase(info.ifaddr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800271 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
272 {
273 it->second.addrs.erase(info.ifaddr);
274 }
William A. Kennington III57ca9612022-11-14 15:26:47 -0800275 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800276}
277
278void Manager::addNeighbor(const NeighborInfo& info)
279{
William A. Kennington III7310ac72022-11-14 15:44:00 -0800280 if (!(info.state & NUD_PERMANENT) || !info.addr)
281 {
282 return;
283 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800284 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
William A. Kennington III7310ac72022-11-14 15:44:00 -0800285 {
286 it->second.staticNeighs.insert_or_assign(*info.addr, info);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800287 if (auto it = interfacesByIdx.find(info.ifidx);
288 it != interfacesByIdx.end())
289 {
290 it->second->addStaticNeigh(info);
291 }
William A. Kennington III7310ac72022-11-14 15:44:00 -0800292 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800293 else if (!ignoredIntf.contains(info.ifidx))
William A. Kennington III7310ac72022-11-14 15:44:00 -0800294 {
295 throw std::runtime_error(
296 fmt::format("Interface `{}` not found for neigh", info.ifidx));
297 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800298}
299
300void Manager::removeNeighbor(const NeighborInfo& info)
301{
William A. Kennington III7310ac72022-11-14 15:44:00 -0800302 if (!info.addr)
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800303 {
William A. Kennington III7310ac72022-11-14 15:44:00 -0800304 return;
305 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800306 if (auto it = intfInfo.find(info.ifidx); it != intfInfo.end())
William A. Kennington III7310ac72022-11-14 15:44:00 -0800307 {
308 it->second.staticNeighs.erase(*info.addr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800309 if (auto it = interfacesByIdx.find(info.ifidx);
310 it != interfacesByIdx.end())
311 {
312 it->second->staticNeighbors.erase(*info.addr);
313 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800314 }
315}
316
317void Manager::addDefGw(unsigned ifidx, InAddrAny addr)
318{
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800319 if (auto it = intfInfo.find(ifidx); it != intfInfo.end())
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800320 {
321 std::visit(
322 [&](auto addr) {
323 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
324 {
325 it->second.defgw4.emplace(addr);
326 }
327 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
328 {
329 it->second.defgw6.emplace(addr);
330 }
331 else
332 {
333 static_assert(!std::is_same_v<void, decltype(addr)>);
334 }
335 },
336 addr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800337 if (auto it = interfacesByIdx.find(ifidx); it != interfacesByIdx.end())
338 {
339 std::visit(
340 [&](auto addr) {
341 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
342 {
343 it->second->EthernetInterfaceIntf::defaultGateway(
344 std::to_string(addr));
345 }
346 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
347 {
348 it->second->EthernetInterfaceIntf::defaultGateway6(
349 std::to_string(addr));
350 }
351 else
352 {
353 static_assert(!std::is_same_v<void, decltype(addr)>);
354 }
355 },
356 addr);
357 }
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800358 }
William A. Kennington III3ee5b7e2022-11-15 15:04:37 -0800359 else if (!ignoredIntf.contains(ifidx))
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800360 {
361 auto msg = fmt::format("Interface `{}` not found for gw", ifidx);
362 log<level::ERR>(msg.c_str(), entry("IFIDX=%u", ifidx));
363 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800364}
365
366void Manager::removeDefGw(unsigned ifidx, InAddrAny addr)
367{
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800368 if (auto it = intfInfo.find(ifidx); it != intfInfo.end())
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800369 {
370 std::visit(
371 [&](auto addr) {
372 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
373 {
374 if (it->second.defgw4 == addr)
375 {
376 it->second.defgw4.reset();
377 }
378 }
379 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
380 {
381 if (it->second.defgw6 == addr)
382 {
383 it->second.defgw6.reset();
384 }
385 }
386 else
387 {
388 static_assert(!std::is_same_v<void, decltype(addr)>);
389 }
390 },
391 addr);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800392 if (auto it = interfacesByIdx.find(ifidx); it != interfacesByIdx.end())
393 {
394 std::visit(
395 [&](auto addr) {
396 if constexpr (std::is_same_v<in_addr, decltype(addr)>)
397 {
398 if (it->second->defaultGateway() ==
399 std::to_string(addr))
400 {
401 it->second->EthernetInterfaceIntf::defaultGateway(
402 "");
403 }
404 }
405 else if constexpr (std::is_same_v<in6_addr, decltype(addr)>)
406 {
407 if (it->second->defaultGateway6() ==
408 std::to_string(addr))
409 {
410 it->second->EthernetInterfaceIntf::defaultGateway6(
411 "");
412 }
413 }
414 else
415 {
416 static_assert(!std::is_same_v<void, decltype(addr)>);
417 }
418 },
419 addr);
420 }
William A. Kennington IIIbb9e9092022-11-14 15:58:02 -0800421 }
William A. Kennington IIIed5ff472022-11-12 16:24:02 -0800422}
423
William A. Kennington III085bbdc2022-10-05 02:45:37 -0700424ObjectPath Manager::vlan(std::string interfaceName, uint32_t id)
Ratan Gupta6811f822017-04-14 16:34:56 +0530425{
Jiaqing Zhaob685cb62022-04-12 22:57:34 +0800426 if (id == 0 || id >= 4095)
427 {
428 log<level::ERR>("VLAN ID is not valid", entry("VLANID=%u", id));
429 elog<InvalidArgument>(
430 Argument::ARGUMENT_NAME("VLANId"),
431 Argument::ARGUMENT_VALUE(std::to_string(id).c_str()));
432 }
433
William A. Kennington III96444792022-10-05 15:16:22 -0700434 auto it = interfaces.find(interfaceName);
435 if (it == interfaces.end())
436 {
437 using ResourceErr =
438 phosphor::logging::xyz::openbmc_project::Common::ResourceNotFound;
439 elog<ResourceNotFound>(ResourceErr::RESOURCE(interfaceName.c_str()));
440 }
441 return it->second->createVLAN(id);
Ratan Gupta6811f822017-04-14 16:34:56 +0530442}
443
Michael Tritz29f2fd62017-05-22 15:27:26 -0500444void Manager::reset()
445{
William A. Kennington III5b179382022-11-15 15:23:26 -0800446 for (const auto& dirent : std::filesystem::directory_iterator(confDir))
Michael Tritz29f2fd62017-05-22 15:27:26 -0500447 {
William A. Kennington III5b179382022-11-15 15:23:26 -0800448 std::error_code ec;
449 std::filesystem::remove(dirent.path(), ec);
Michael Tritz29f2fd62017-05-22 15:27:26 -0500450 }
William A. Kennington III5b179382022-11-15 15:23:26 -0800451 log<level::INFO>("Network data purged.");
Michael Tritz29f2fd62017-05-22 15:27:26 -0500452}
453
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530454// Need to merge the below function with the code which writes the
455// config file during factory reset.
Gunnar Mills57d9c502018-09-14 14:42:34 -0500456// TODO openbmc/openbmc#1751
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530457void Manager::writeToConfigurationFile()
458{
459 // write all the static ip address in the systemd-network conf file
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530460 for (const auto& intf : interfaces)
461 {
Ratan Gupta2b106532017-07-25 16:05:02 +0530462 intf.second->writeConfigurationFile();
Ratan Gupta4f1c18b2017-05-25 12:59:35 +0530463 }
Ratan Guptae05083a2017-09-16 07:12:11 +0530464}
465
William A. Kennington III85dc57a2022-11-07 16:53:24 -0800466void Manager::reloadConfigs()
467{
William A. Kennington III5b179382022-11-15 15:23:26 -0800468 reloadTimer->restartOnce(reloadTimeout);
William A. Kennington IIIc7cf25f2021-11-09 16:16:59 -0800469}
470
471void Manager::doReloadConfigs()
472{
William A. Kennington III6ff633a2021-11-09 17:09:12 -0800473 for (auto& hook : reloadPreHooks)
474 {
475 try
476 {
477 hook();
478 }
479 catch (const std::exception& ex)
480 {
481 log<level::ERR>("Failed executing reload hook, ignoring",
482 entry("ERR=%s", ex.what()));
483 }
484 }
485 reloadPreHooks.clear();
William A. Kennington III56ecc782021-10-07 18:44:50 -0700486 try
487 {
488 auto method = bus.new_method_call(NETWORKD_BUSNAME, NETWORKD_PATH,
489 NETWORKD_INTERFACE, "Reload");
490 bus.call_noreply(method);
491 }
Patrick Williamsc38b0712022-07-22 19:26:54 -0500492 catch (const sdbusplus::exception_t& ex)
William A. Kennington III56ecc782021-10-07 18:44:50 -0700493 {
494 log<level::ERR>("Failed to reload configuration",
495 entry("ERR=%s", ex.what()));
William A. Kennington IIIde4668a2022-11-17 16:02:30 -0800496 reloadPostHooks.clear();
William A. Kennington III56ecc782021-10-07 18:44:50 -0700497 }
William A. Kennington IIIde4668a2022-11-17 16:02:30 -0800498 for (auto& hook : reloadPostHooks)
499 {
500 try
501 {
502 hook();
503 }
504 catch (const std::exception& ex)
505 {
506 log<level::ERR>("Failed executing reload hook, ignoring",
507 entry("ERR=%s", ex.what()));
508 }
509 }
510 reloadPostHooks.clear();
William A. Kennington III56ecc782021-10-07 18:44:50 -0700511}
512
William A. Kennington III80d29012022-11-12 02:31:40 -0800513void Manager::handleAdminState(std::string_view state, unsigned ifidx)
514{
515 if (state == "initialized" || state == "linger")
516 {
517 systemdNetworkdEnabled.erase(ifidx);
518 }
519 else
520 {
521 bool managed = state != "unmanaged";
522 systemdNetworkdEnabled.insert_or_assign(ifidx, managed);
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800523 if (auto it = interfacesByIdx.find(ifidx); it != interfacesByIdx.end())
William A. Kennington III80d29012022-11-12 02:31:40 -0800524 {
525 it->second->EthernetInterfaceIntf::nicEnabled(managed);
526 }
William A. Kennington III2fb0c872022-11-15 19:35:39 -0800527 else if (auto it = intfInfo.find(ifidx); it != intfInfo.end())
528 {
529 createInterface(it->second, managed);
530 }
William A. Kennington III80d29012022-11-12 02:31:40 -0800531 }
532}
533
Gunnar Mills57d9c502018-09-14 14:42:34 -0500534} // namespace network
535} // namespace phosphor