blob: b008dba17a3d93ce785b9aafec583c648f3a4e48 [file] [log] [blame]
Ratan Gupta82e1ef92017-06-15 08:39:15 +05301#include "system_configuration.hpp"
Patrick Venture189d44e2018-07-09 12:30:59 -07002
Ratan Gupta82e1ef92017-06-15 08:39:15 +05303#include <phosphor-logging/elog-errors.hpp>
Jagpal Singh Gilla2947b42023-04-17 21:10:14 -07004#include <phosphor-logging/lg2.hpp>
William A. Kennington III9ede1b72022-11-21 01:59:28 -08005#include <stdplus/pinned.hpp>
Patrick Venture189d44e2018-07-09 12:30:59 -07006#include <xyz/openbmc_project/Common/error.hpp>
Ratan Gupta82e1ef92017-06-15 08:39:15 +05307
8namespace phosphor
9{
10namespace network
11{
12
William A. Kennington III40c29b52022-11-16 17:48:10 -080013static constexpr char HOSTNAMED_SVC[] = "org.freedesktop.hostname1";
14static constexpr char HOSTNAMED_OBJ[] = "/org/freedesktop/hostname1";
15static constexpr char HOSTNAMED_INTF[] = "org.freedesktop.hostname1";
Ratan Gupta82e1ef92017-06-15 08:39:15 +053016
Ravi Teja46dda592024-01-12 04:54:35 -060017using namespace phosphor::logging;
Ratan Gupta82e1ef92017-06-15 08:39:15 +053018using namespace sdbusplus::xyz::openbmc_project::Common::Error;
Ravi Teja46dda592024-01-12 04:54:35 -060019using Argument = xyz::openbmc_project::Common::InvalidArgument;
Ratan Gupta82e1ef92017-06-15 08:39:15 +053020
William A. Kennington III40c29b52022-11-16 17:48:10 -080021static constexpr char propMatch[] =
22 "type='signal',sender='org.freedesktop.hostname1',"
23 "path='/org/freedesktop/hostname1',"
24 "interface='org.freedesktop.DBus.Properties',member='PropertiesChanged',"
25 "arg0='org.freedesktop.hostname1'";
Ratan Gupta82e1ef92017-06-15 08:39:15 +053026
William A. Kennington III9ede1b72022-11-21 01:59:28 -080027SystemConfiguration::SystemConfiguration(
28 stdplus::PinnedRef<sdbusplus::bus_t> bus, stdplus::const_zstring objPath) :
Patrick Williams166b9592022-03-30 16:09:16 -050029 Iface(bus, objPath.c_str(), Iface::action::defer_emit),
Patrick Williams89d734b2023-05-10 07:50:25 -050030 bus(bus), hostnamePropMatch(
31 bus, propMatch,
32 [sc = stdplus::PinnedRef(*this)](sdbusplus::message_t& m) {
33 std::string intf;
34 std::unordered_map<std::string, std::variant<std::string>> values;
35 try
36 {
37 m.read(intf, values);
38 auto it = values.find("Hostname");
39 if (it == values.end())
40 {
41 return;
42 }
43 sc.get().Iface::hostName(std::get<std::string>(it->second));
44 }
45 catch (const std::exception& e)
46 {
47 lg2::error("Hostname match parsing failed: {ERROR}", "ERROR", e);
48 }
Patrick Williams6f256bc2023-10-20 11:18:34 -050049})
Ratan Gupta82e1ef92017-06-15 08:39:15 +053050{
William A. Kennington III40c29b52022-11-16 17:48:10 -080051 try
52 {
53 std::variant<std::string> name;
Patrick Williams89d734b2023-05-10 07:50:25 -050054 auto req = bus.get().new_method_call(HOSTNAMED_SVC, HOSTNAMED_OBJ,
55 "org.freedesktop.DBus.Properties",
56 "Get");
William A. Kennington III40c29b52022-11-16 17:48:10 -080057
58 req.append(HOSTNAMED_INTF, "Hostname");
William A. Kennington III9ede1b72022-11-21 01:59:28 -080059 auto reply = req.call();
William A. Kennington III40c29b52022-11-16 17:48:10 -080060 reply.read(name);
61 SystemConfigIntf::hostName(std::get<std::string>(name), true);
62 }
63 catch (const std::exception& e)
64 {
Jagpal Singh Gilla2947b42023-04-17 21:10:14 -070065 lg2::error("Failed to get hostname: {ERROR}", "ERROR", e);
William A. Kennington III40c29b52022-11-16 17:48:10 -080066 }
Ratan Gupta82e1ef92017-06-15 08:39:15 +053067
William A. Kennington IIId99e6db2022-11-15 20:39:45 -080068 emit_object_added();
Ratan Gupta82e1ef92017-06-15 08:39:15 +053069}
70
71std::string SystemConfiguration::hostName(std::string name)
72{
73 if (SystemConfigIntf::hostName() == name)
74 {
75 return name;
76 }
Ratan Guptad30adf82020-06-12 09:47:32 +053077 try
Ratan Gupta82e1ef92017-06-15 08:39:15 +053078 {
William A. Kennington III9ede1b72022-11-21 01:59:28 -080079 auto method = bus.get().new_method_call(
80 HOSTNAMED_SVC, HOSTNAMED_OBJ, HOSTNAMED_INTF, "SetStaticHostname");
William A. Kennington III40c29b52022-11-16 17:48:10 -080081 method.append(name, /*interactive=*/false);
Ravi Teja46dda592024-01-12 04:54:35 -060082 method.call();
William A. Kennington III40c29b52022-11-16 17:48:10 -080083 return SystemConfigIntf::hostName(std::move(name));
Ratan Gupta82e1ef92017-06-15 08:39:15 +053084 }
Ravi Teja46dda592024-01-12 04:54:35 -060085 catch (const sdbusplus::exception::SdBusError& e)
Ratan Gupta82e1ef92017-06-15 08:39:15 +053086 {
Ravi Teja46dda592024-01-12 04:54:35 -060087 lg2::error("Failed to set hostname {HOSTNAME}: {ERROR} ", "HOSTNAME",
88 name, "ERROR", e);
89 auto dbusError = e.get_error();
90 if ((dbusError != nullptr) &&
91 (strcmp(dbusError->name,
92 "org.freedesktop.DBus.Error.InvalidArgs") == 0))
93 {
94 elog<InvalidArgument>(Argument::ARGUMENT_NAME("Hostname"),
95 Argument::ARGUMENT_VALUE(name.c_str()));
96 }
Ratan Gupta82e1ef92017-06-15 08:39:15 +053097 }
William A. Kennington III40c29b52022-11-16 17:48:10 -080098 return SystemConfigIntf::hostName();
Ratan Gupta82e1ef92017-06-15 08:39:15 +053099}
100
Gunnar Mills57d9c502018-09-14 14:42:34 -0500101} // namespace network
102} // namespace phosphor