#include "settings.hpp" #include "xyz/openbmc_project/Common/error.hpp" #include #include namespace settings { using namespace phosphor::logging; using namespace sdbusplus::xyz::openbmc_project::Common::Error; constexpr auto mapperService = "xyz.openbmc_project.ObjectMapper"; constexpr auto mapperPath = "/xyz/openbmc_project/object_mapper"; constexpr auto mapperIntf = "xyz.openbmc_project.ObjectMapper"; Objects::Objects(sdbusplus::bus::bus& bus) : bus(bus) { std::vector settingsIntfs = {timeOwnerIntf, timeSyncIntf, hostStateIntf}; auto depth = 0; auto mapperCall = bus.new_method_call(mapperService, mapperPath, mapperIntf, "GetSubTree"); mapperCall.append(root); mapperCall.append(depth); mapperCall.append(settingsIntfs); auto response = bus.call(mapperCall); if (response.is_method_error()) { log("Error in mapper GetSubTree"); elog(); } using Interfaces = std::vector; using MapperResponse = std::vector< std::pair>>>; MapperResponse result; response.read(result); if (result.empty()) { log("Invalid response from mapper"); elog(); } for (const auto& iter : result) { const Path& path = iter.first; for (const auto& service_iter : iter.second) { for (const Interface& interface : service_iter.second) { if (timeOwnerIntf == interface) { timeOwner = path; } else if (timeSyncIntf == interface) { timeSyncMethod = path; } else if (hostStateIntf == interface) { hostState = path; } } } } } Service Objects::service(const Path& path, const Interface& interface) const { using Interfaces = std::vector; auto mapperCall = bus.new_method_call(mapperService, mapperPath, mapperIntf, "GetObject"); mapperCall.append(path); mapperCall.append(Interfaces({interface})); auto response = bus.call(mapperCall); if (response.is_method_error()) { log("Error in mapper GetObject"); elog(); } std::map result; response.read(result); if (result.empty()) { log("Invalid response from mapper"); elog(); } return result.begin()->first; } } // namespace settings