Refactor GetSubTree method
Since the GetSubTree method has been implemented in dbus_utility and
this commit is to integrate all the places where the GetSubTree
method is called, and use the method in dbus_utility uniformly.
Tested: Redfish Validator Passed
Signed-off-by: George Liu <liuxiwei@inspur.com>
Change-Id: If3852b487d74e7cd8f123e0efffbd4affe92743c
diff --git a/redfish-core/lib/redfish_util.hpp b/redfish-core/lib/redfish_util.hpp
index 2bf66ba..d7a7f8c 100644
--- a/redfish-core/lib/redfish_util.hpp
+++ b/redfish-core/lib/redfish_util.hpp
@@ -20,9 +20,12 @@
#include "dbus_utility.hpp"
#include "error_messages.hpp"
+#include <boost/system/error_code.hpp>
#include <sdbusplus/asio/property.hpp>
+#include <array>
#include <charconv>
+#include <string_view>
namespace redfish
{
@@ -60,9 +63,13 @@
CallbackFunc&& callback)
{
// Find managed chassis
- crow::connections::systemBus->async_method_call(
+ constexpr std::array<std::string_view, 2> interfaces = {
+ "xyz.openbmc_project.Inventory.Item.Board",
+ "xyz.openbmc_project.Inventory.Item.Chassis"};
+ dbus::utility::getSubTree(
+ "/xyz/openbmc_project/inventory", 0, interfaces,
[callback,
- asyncResp](const boost::system::error_code ec,
+ asyncResp](const boost::system::error_code& ec,
const dbus::utility::MapperGetSubTreeResponse& subtree) {
if (ec)
{
@@ -86,14 +93,7 @@
std::string chassisId = subtree[0].first.substr(idPos + 1);
BMCWEB_LOG_DEBUG << "chassisId = " << chassisId;
callback(chassisId, asyncResp);
- },
- "xyz.openbmc_project.ObjectMapper",
- "/xyz/openbmc_project/object_mapper",
- "xyz.openbmc_project.ObjectMapper", "GetSubTree",
- "/xyz/openbmc_project/inventory", 0,
- std::array<const char*, 2>{
- "xyz.openbmc_project.Inventory.Item.Board",
- "xyz.openbmc_project.Inventory.Item.Chassis"});
+ });
}
template <typename CallbackFunc>