blob: 095495346588d66b9474c3c8d5318ce29132e8bf [file] [log] [blame]
Brad Bishop49aefb32016-10-19 11:54:14 -04001#pragma once
2
3#include <map>
4#include <memory>
5#include <string>
6#include <vector>
7#include <sdbusplus/server.hpp>
Brad Bishope30dd772016-11-12 21:39:28 -05008#include "xyz/openbmc_project/Inventory/Manager/server.hpp"
Brad Bishop67b788d2016-11-29 13:09:01 -05009#include "events.hpp"
Brad Bishopc038e012016-10-19 13:02:24 -040010#include "actions.hpp"
Brad Bishop49aefb32016-10-19 11:54:14 -040011
12namespace phosphor
13{
14namespace inventory
15{
16namespace manager
17{
18namespace details
19{
Brad Bishop451f8d92016-11-21 14:15:19 -050020
21template <typename T>
22using ServerObject = typename sdbusplus::server::object::object<T>;
23
24using ManagerIface =
25 sdbusplus::server::xyz::openbmc_project::Inventory::Manager;
26
Brad Bishop65ffffa2016-11-29 12:31:31 -050027/** @struct MakeInterface
28 * @brief Adapt an sdbusplus interface proxy.
29 *
30 * Template instances are builder functions that create
31 * adapted sdbusplus interface proxy interface objects.
32 *
33 * @tparam T - The type of the interface being adapted.
34 */
35template <typename T>
36struct MakeInterface
37{
38 static decltype(auto) make(sdbusplus::bus::bus &bus, const char *path)
39 {
40 using HolderType = holder::Holder<std::unique_ptr<T>>;
41 return static_cast<std::unique_ptr<holder::Base>>(
42 HolderType::template make_unique<HolderType>(
43 std::forward<std::unique_ptr<T>>(
44 std::make_unique<T>(
45 std::forward<decltype(bus)>(bus),
46 std::forward<decltype(path)>(path)))));
47 }
48};
Brad Bishop49aefb32016-10-19 11:54:14 -040049} // namespace details
50
51/** @class Manager
52 * @brief OpenBMC inventory manager implementation.
53 *
54 * A concrete implementation for the xyz.openbmc_project.Inventory.Manager
55 * DBus API.
56 */
57class Manager final :
Brad Bishop451f8d92016-11-21 14:15:19 -050058 public details::ServerObject<details::ManagerIface>
Brad Bishop49aefb32016-10-19 11:54:14 -040059{
60 public:
61 Manager() = delete;
62 Manager(const Manager&) = delete;
63 Manager& operator=(const Manager&) = delete;
64 Manager(Manager&&) = default;
65 Manager& operator=(Manager&&) = default;
66 ~Manager() = default;
67
68 /** @brief Construct an inventory manager.
69 *
70 * @param[in] bus - An sdbusplus bus connection.
71 * @param[in] busname - The DBus busname to own.
72 * @param[in] root - The DBus path on which to implement
73 * an inventory manager.
74 * @param[in] iface - The DBus inventory interface to implement.
75 */
76 Manager(sdbusplus::bus::bus &&, const char *, const char*, const char*);
77
78 using Object = std::map<
79 std::string, std::map<
80 std::string, sdbusplus::message::variant<std::string>>>;
Brad Bishop68c80832016-11-29 16:41:32 -050081 using EventInfo = std::tuple<
82 std::vector<details::EventBasePtr>,
83 std::vector<details::ActionBasePtr>>;
Brad Bishop49aefb32016-10-19 11:54:14 -040084
85 /** @brief Start processing DBus messages. */
86 void run() noexcept;
87
88 /** @brief Provided for testing only. */
89 void shutdown() noexcept;
90
91 /** @brief sd_bus Notify method implementation callback. */
92 void notify(std::string path, Object) override;
93
94 /** @brief sd_bus signal callback. */
Brad Bishop68c80832016-11-29 16:41:32 -050095 void signal(sdbusplus::message::message&,
96 const details::DbusSignal &event,
97 const EventInfo &info);
Brad Bishop49aefb32016-10-19 11:54:14 -040098
Brad Bishop656a7d02016-10-19 22:20:02 -040099 /** @brief Drop an object from DBus. */
100 void destroyObject(const char *);
101
Brad Bishopda649b12016-11-30 14:35:02 -0500102 /** @brief Invoke an sdbusplus server binding method.
103 *
104 * Invoke the requested method with a reference to the requested
105 * sdbusplus server binding interface as a parameter.
106 *
107 * @tparam T - The sdbusplus server binding interface type.
108 * @tparam U - The type of the sdbusplus server binding member.
109 * @tparam Args - Argument types of the binding member.
110 *
111 * @param[in] path - The DBus path on which the method should
112 * be invoked.
113 * @param[in] interface - The DBus interface hosting the method.
114 * @param[in] member - Pointer to sdbusplus server binding member.
115 * @param[in] args - Arguments to forward to the binding member.
116 *
117 * @returns - The return/value type of the binding method being
118 * called.
119 */
120 template<typename T, typename U, typename ...Args>
121 decltype(auto) invokeMethod(const char *path, const char *interface,
122 U&& member, Args&&...args)
123 {
124 auto &holder = getInterface<std::unique_ptr<T>>(path, interface);
125 auto &iface = *holder.get();
126 return (iface.*member)(std::forward<Args>(args)...);
127 }
128
Brad Bishop49aefb32016-10-19 11:54:14 -0400129 using SigArgs = std::vector<
130 std::unique_ptr<
131 std::tuple<
132 Manager *,
Brad Bishop68c80832016-11-29 16:41:32 -0500133 const details::DbusSignal *,
Brad Bishop4f20a3e2016-11-29 15:21:46 -0500134 const EventInfo *>>>;
Brad Bishop49aefb32016-10-19 11:54:14 -0400135 using SigArg = SigArgs::value_type::element_type;
136
137 private:
Brad Bishop65ffffa2016-11-29 12:31:31 -0500138 using HolderPtr = std::unique_ptr<details::holder::Base>;
Brad Bishop49aefb32016-10-19 11:54:14 -0400139 using InterfaceComposite = std::map<std::string, HolderPtr>;
140 using ObjectReferences = std::map<std::string, InterfaceComposite>;
Brad Bishop4f20a3e2016-11-29 15:21:46 -0500141 using Events = std::vector<EventInfo>;
Brad Bishop5fbaa7f2016-10-31 10:42:41 -0500142 using MakerType = HolderPtr(*)(
143 sdbusplus::bus::bus &, const char *);
144 using Makers = std::map<std::string, MakerType>;
Brad Bishop49aefb32016-10-19 11:54:14 -0400145
Brad Bishopb83a21e2016-11-30 13:43:37 -0500146 /** @brief Provides weak references to interface holders.
147 *
148 * Common code for all types for the templated getInterface
149 * methods.
150 *
151 * @param[in] path - The DBus path for which the interface
152 * holder instance should be provided.
153 * @param[in] interface - The DBus interface for which the
154 * holder instance should be provided.
155 *
156 * @returns A weak reference to the holder instance.
157 */
158 details::holder::Base& getInterfaceHolder(
159 const char *, const char *) const;
160 details::holder::Base& getInterfaceHolder(
161 const char *, const char *);
162
163 /** @brief Provides weak references to interface holders.
164 *
165 * @tparam T - The sdbusplus server binding interface type.
166 *
167 * @param[in] path - The DBus path for which the interface
168 * should be provided.
169 * @param[in] interface - The DBus interface to obtain.
170 *
171 * @returns A weak reference to the interface holder.
172 */
173 template<typename T>
174 auto& getInterface(const char *path, const char *interface)
175 {
176 auto &holder = getInterfaceHolder(path, interface);
177 return static_cast<
178 details::holder::Holder<T> &>(holder);
179 }
180 template<typename T>
181 auto& getInterface(const char *path, const char *interface) const
182 {
183 auto &holder = getInterfaceHolder(path, interface);
184 return static_cast<
185 const details::holder::Holder<T> &>(holder);
186 }
187
Brad Bishop49aefb32016-10-19 11:54:14 -0400188 /** @brief Provided for testing only. */
189 bool _shutdown;
190
191 /** @brief Path prefix applied to any relative paths. */
192 const char * _root;
193
194 /** @brief A container of sdbusplus server interface references. */
195 ObjectReferences _refs;
196
197 /** @brief A container contexts for signal callbacks. */
198 SigArgs _sigargs;
199
200 /** @brief A container of sdbusplus signal matches. */
201 std::vector<sdbusplus::server::match::match> _matches;
202
203 /** @brief Persistent sdbusplus DBus bus connection. */
204 sdbusplus::bus::bus _bus;
205
206 /** @brief sdbusplus org.freedesktop.DBus.ObjectManager reference. */
207 sdbusplus::server::manager::manager _manager;
208
209 /** @brief A container of pimgen generated events and responses. */
210 static const Events _events;
Brad Bishop5fbaa7f2016-10-31 10:42:41 -0500211
212 /** @brief A container of pimgen generated factory methods. */
213 static const Makers _makers;
Brad Bishop49aefb32016-10-19 11:54:14 -0400214};
215
216} // namespace manager
217} // namespace inventory
218} // namespace phosphor
219
220// vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4