| |
| #include "getConfig.hpp" |
| |
| #include <boost/asio/steady_timer.hpp> |
| #include <phosphor-logging/lg2.hpp> |
| #include <sdbusplus/asio/connection.hpp> |
| |
| #include <chrono> |
| #include <cstdlib> |
| #include <memory> |
| #include <string> |
| #include <utility> |
| #include <variant> |
| #include <vector> |
| |
| namespace estoraged |
| { |
| |
| namespace mapper |
| { |
| constexpr const char* busName = "xyz.openbmc_project.ObjectMapper"; |
| constexpr const char* path = "/xyz/openbmc_project/object_mapper"; |
| constexpr const char* interface = "xyz.openbmc_project.ObjectMapper"; |
| constexpr const char* subtree = "GetSubTree"; |
| } // namespace mapper |
| |
| using GetSubTreeType = std::vector< |
| std::pair<std::string, |
| std::vector<std::pair<std::string, std::vector<std::string>>>>>; |
| |
| void GetStorageConfiguration::getStorageInfo(const std::string& path, |
| const std::string& owner, |
| size_t retries) |
| { |
| std::shared_ptr<GetStorageConfiguration> self = shared_from_this(); |
| self->dbusConnection->async_method_call( |
| [self, path, owner, retries]( |
| const boost::system::error_code ec, |
| boost::container::flat_map<std::string, BasicVariantType>& data) { |
| if (ec) |
| { |
| lg2::error( |
| "Error getting properties for {PATH}: {RETRIES} retries left", |
| "PATH", path, "RETRIES", retries - 1, "REDFISH_MESSAGE_ID", |
| std::string("OpenBMC.0.1.GetStorageInfoFail")); |
| if (retries == 0U) |
| { |
| return; |
| } |
| |
| auto timer = std::make_shared<boost::asio::steady_timer>( |
| self->dbusConnection->get_io_context()); |
| timer->expires_after(std::chrono::seconds(10)); |
| timer->async_wait([self, timer, path, owner, |
| retries](boost::system::error_code ec) { |
| if (ec) |
| { |
| lg2::error("Timer error!"); |
| return; |
| } |
| self->getStorageInfo(path, owner, retries - 1); |
| }); |
| |
| return; |
| } |
| |
| self->respData[path] = std::move(data); |
| }, |
| owner, path, "org.freedesktop.DBus.Properties", "GetAll", |
| emmcConfigInterface); |
| } |
| |
| void GetStorageConfiguration::getConfiguration() |
| { |
| std::shared_ptr<GetStorageConfiguration> self = shared_from_this(); |
| dbusConnection->async_method_call( |
| [self](const boost::system::error_code ec, const GetSubTreeType& ret) { |
| if (ec) |
| { |
| lg2::error("Error calling mapper"); |
| return; |
| } |
| for (const auto& [objPath, objDict] : ret) |
| { |
| if (objDict.empty()) |
| { |
| return; |
| } |
| const std::string& objOwner = objDict.begin()->first; |
| /* Look for the config interface exposed by this object. */ |
| for (const std::string& interface : objDict.begin()->second) |
| { |
| if (interface.compare(emmcConfigInterface) == 0) |
| { |
| /* Get the properties exposed by this interface. */ |
| self->getStorageInfo(objPath, objOwner); |
| } |
| } |
| } |
| }, |
| mapper::busName, mapper::path, mapper::interface, mapper::subtree, "/", |
| 0, std::vector<const char*>(1, emmcConfigInterface)); |
| } |
| |
| GetStorageConfiguration::~GetStorageConfiguration() |
| { |
| callback(respData); |
| } |
| |
| } // namespace estoraged |