blob: 3d2cc5accd2f3f5b75e27e0ee51b8ccb98795fb4 [file] [log] [blame]
#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