blob: 984ac5f72343714721b18b49a8598210252fd4cd [file] [log] [blame]
#include <phosphor-logging/elog-errors.hpp>
#include <phosphor-logging/lg2.hpp>
#include <xyz/openbmc_project/Common/error.hpp>
const constexpr char* entityManagerBusName =
"xyz.openbmc_project.EntityManager";
const char* propIntf = "org.freedesktop.DBus.Properties";
const char* mapperBusName = "xyz.openbmc_project.ObjectMapper";
const char* mapperPath = "/xyz/openbmc_project/object_mapper";
const char* mapperIntf = "xyz.openbmc_project.ObjectMapper";
const char* methodGetObject = "GetObject";
const char* methodGet = "Get";
const char* methodSet = "Set";
using namespace sdbusplus::xyz::openbmc_project::Common::Error;
using Value = std::variant<int64_t, double, std::string, bool>;
std::string getService(sdbusplus::bus_t& bus, const std::string& path,
const char* intf)
{
/* Get mapper object for sensor path */
auto mapper = bus.new_method_call(mapperBusName, mapperPath, mapperIntf,
methodGetObject);
mapper.append(path.c_str());
mapper.append(std::vector<std::string>({intf}));
std::unordered_map<std::string, std::vector<std::string>> resp;
try
{
auto msg = bus.call(mapper);
msg.read(resp);
}
catch (const sdbusplus::exception_t& ex)
{
if (ex.name() == std::string(sdbusplus::xyz::openbmc_project::Common::
Error::ResourceNotFound::errName))
{
// The service isn't on D-Bus yet.
return std::string{};
}
else if (ex.name() == std::string("org.freedesktop.DBus.Error.Timeout"))
{
lg2::info("Mapper timeout while looking up {PATH}", "PATH", path);
return std::string{};
}
throw;
}
if (resp.begin() == resp.end())
{
// Shouldn't happen, if the mapper can't find it it is handled above.
throw std::runtime_error("Unable to find Object: " + path);
}
return resp.begin()->first;
}
template <typename T>
T getDbusProperty(sdbusplus::bus_t& bus, const std::string& service,
const std::string& path, const std::string& intf,
const std::string& property)
{
Value value;
auto method = bus.new_method_call(service.c_str(), path.c_str(), propIntf,
methodGet);
method.append(intf, property);
try
{
auto msg = bus.call(method);
msg.read(value);
}
catch (const sdbusplus::exception_t& ex)
{
return std::numeric_limits<T>::quiet_NaN();
}
return std::get<T>(value);
}
int setDbusProperty(sdbusplus::bus_t& bus, const std::string& service,
const std::string& path, const std::string& intf,
const std::string& property, const Value& value)
{
try
{
auto method = bus.new_method_call(service.c_str(), path.c_str(),
propIntf, methodSet);
method.append(intf, property, value);
auto msg = bus.call(method);
}
catch (const sdbusplus::exception_t& e)
{
lg2::error(
"Faild to set dbus property. service:{SERVICE} path:{PATH} intf:{INTF} Property:{PROP},{ERRMSG}",
"SERVICE", service, "PATH", path, "INTF", intf, "PROP", property,
"ERRMSG", e);
return -1;
}
return 0;
}