summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/data_types.hpp4
-rw-r--r--src/propertywatchimpl.hpp5
-rw-r--r--src/sdbusplus.hpp24
3 files changed, 28 insertions, 5 deletions
diff --git a/src/data_types.hpp b/src/data_types.hpp
index 5eab4b2..21f2ecf 100644
--- a/src/data_types.hpp
+++ b/src/data_types.hpp
@@ -13,6 +13,10 @@ namespace dbus
namespace monitoring
{
+constexpr auto MAPPER_BUSNAME = "xyz.openbmc_project.ObjectMapper";
+constexpr auto MAPPER_PATH = "/xyz/openbmc_project/object_mapper";
+constexpr auto MAPPER_INTERFACE = "xyz.openbmc_project.ObjectMapper";
+
/** @brief A map with references as keys. */
template <typename Key, typename Value>
using RefKeyMap = std::map<std::reference_wrapper<Key>, Value, std::less<Key>>;
diff --git a/src/propertywatchimpl.hpp b/src/propertywatchimpl.hpp
index 67bbaff..3ef5de5 100644
--- a/src/propertywatchimpl.hpp
+++ b/src/propertywatchimpl.hpp
@@ -14,11 +14,6 @@ namespace dbus
namespace monitoring
{
-static constexpr auto MAPPER_BUSNAME = "xyz.openbmc_project.ObjectMapper";
-static constexpr auto MAPPER_PATH = "/xyz/openbmc_project/object_mapper";
-static constexpr auto MAPPER_INTERFACE =
- "xyz.openbmc_project.ObjectMapper";
-
using MappedPropertyIndex =
RefKeyMap<const std::string,
RefKeyMap<const std::string,
diff --git a/src/sdbusplus.hpp b/src/sdbusplus.hpp
index aba5a36..d62a5d4 100644
--- a/src/sdbusplus.hpp
+++ b/src/sdbusplus.hpp
@@ -3,6 +3,7 @@
#include <sdbusplus/bus.hpp>
#include <sdbusplus/message.hpp>
#include <sdbusplus/bus/match.hpp>
+#include "data_types.hpp"
struct Loop;
@@ -104,6 +105,29 @@ class SDBusPlus
callback);
}
+ /** @brief Look up the bus name for a path and interface */
+ static auto getBusName(
+ const std::string& path,
+ const std::string& interface)
+ {
+ std::vector<std::string> interfaces{interface};
+
+ auto object = callMethodAndRead<GetObject>(
+ MAPPER_BUSNAME,
+ MAPPER_PATH,
+ MAPPER_INTERFACE,
+ "GetObject",
+ path,
+ interfaces);
+
+ std::string name;
+ if (!object.empty())
+ {
+ name = object.begin()->first;
+ }
+ return name;
+ }
+
friend Loop;
};
OpenPOWER on IntegriCloud