blob: 6d8314b2700316c79c7e61378778694dddc5b37c [file] [log] [blame]
SunnySrivastava1984b59fd092020-02-03 09:58:56 -06001#pragma once
2
SunnySrivastava1984f6d541e2020-02-04 12:50:40 -06003#include "editor_impl.hpp"
SunnySrivastava1984b59fd092020-02-03 09:58:56 -06004#include "types.hpp"
5
6#include <com/ibm/VPD/Manager/server.hpp>
SunnySrivastava1984de3c60d2020-02-03 10:34:33 -06007#include <map>
8#include <nlohmann/json.hpp>
SunnySrivastava1984b59fd092020-02-03 09:58:56 -06009
10namespace sdbusplus
11{
12namespace bus
13{
14class bus;
15}
16} // namespace sdbusplus
17
18namespace openpower
19{
20namespace vpd
21{
22namespace manager
23{
24
25template <typename T>
26using ServerObject = T;
27
28using ManagerIface = sdbusplus::com::ibm::VPD::server::Manager;
29
30/** @class Manager
31 * @brief OpenBMC VPD Manager implementation.
32 *
33 * A concrete implementation for the
34 * com.ibm.vpd.Manager
35 */
36class Manager : public ServerObject<ManagerIface>
37{
38 public:
39 /* Define all of the basic class operations:
40 * Not allowed:
41 * - Default constructor to avoid nullptrs.
42 * - Copy operations due to internal unique_ptr.
43 * - Move operations due to 'this' being registered as the
44 * 'context' with sdbus.
45 * Allowed:
46 * - Destructor.
47 */
48 Manager() = delete;
49 Manager(const Manager&) = delete;
50 Manager& operator=(const Manager&) = delete;
51 Manager(Manager&&) = delete;
52 ~Manager() = default;
53
54 /** @brief Constructor to put object onto bus at a dbus path.
55 * @param[in] bus - Bus connection.
56 * @param[in] busName - Name to be requested on Bus
57 * @param[in] objPath - Path to attach at.
58 * @param[in] iFace - interface to implement
59 */
Patrick Williams2eb01762022-07-22 19:26:56 -050060 Manager(sdbusplus::bus_t&& bus, const char* busName, const char* objPath,
SunnySrivastava1984b59fd092020-02-03 09:58:56 -060061 const char* iFace);
62
63 /** @brief Implementation for WriteKeyword
64 * Api to update the keyword value for a given inventory.
65 *
66 * @param[in] path - Path to the D-Bus object that represents the FRU.
67 * @param[in] recordName - name of the record for which the keyword value
68 * has to be modified
69 * @param[in] keyword - keyword whose value needs to be updated
70 * @param[in] value - value that needs to be updated
71 */
72 void writeKeyword(const sdbusplus::message::object_path path,
73 const std::string recordName, const std::string keyword,
74 const Binary value);
75
76 /** @brief Implementation for GetFRUsByUnexpandedLocationCode
77 * A method to get list of FRU D-BUS object paths for a given unexpanded
78 * location code. Returns empty vector if no FRU found for that location
79 * code.
80 *
81 * @param[in] locationCode - An un-expanded Location code.
82 * @param[in] nodeNumber - Denotes the node in case of a multi-node
83 * configuration, ignored on a single node system.
84 *
85 * @return inventoryList[std::vector<sdbusplus::message::object_path>] -
86 * List of all the FRUs D-Bus object paths for the given location code.
87 */
SunnySrivastava19841356d7e2020-04-24 04:29:35 -050088 inventory::ListOfPaths
SunnySrivastava1984b59fd092020-02-03 09:58:56 -060089 getFRUsByUnexpandedLocationCode(const std::string locationCode,
90 const uint16_t nodeNumber);
91
92 /** @brief Implementation for GetFRUsByExpandedLocationCode
93 * A method to get list of FRU D-BUS object paths for a given expanded
94 * location code. Returns empty vector if no FRU found for that location
95 * code.
96 *
97 * @param[in] locationCode - Location code in expanded format.
98 *
99 * @return inventoryList[std::vector<sdbusplus::message::object_path>] -
100 * List of all the FRUs D-Bus object path for the given location code.
101 */
SunnySrivastava19841356d7e2020-04-24 04:29:35 -0500102 inventory::ListOfPaths
SunnySrivastava1984b59fd092020-02-03 09:58:56 -0600103 getFRUsByExpandedLocationCode(const std::string locationCode);
104
105 /** @brief Implementation for GetExpandedLocationCode
SunnySrivastava1984bca5aaa2020-04-21 05:31:04 -0500106 * An API to get expanded location code corresponding to a given
SunnySrivastava1984b59fd092020-02-03 09:58:56 -0600107 * un-expanded location code.
108 *
109 * @param[in] locationCode - Location code in un-expaned format.
110 * @param[in] nodeNumber - Denotes the node in case of multi-node
111 * configuration. Ignored in case of single node configuration.
112 *
113 * @return locationCode[std::string] - Location code in expanded format.
114 */
115 std::string getExpandedLocationCode(const std::string locationCode,
116 const uint16_t nodeNumber);
117
118 /** @brief Start processing DBus messages. */
119 void run();
120
SunnySrivastava19849a195542020-09-07 06:04:50 -0500121 /** @brief Api to perform VPD recollection.
122 * This api will trigger parser to perform VPD recollection for FRUs that
123 * can be replaced at standby.
124 */
125 void performVPDRecollection();
126
SunnySrivastava1984b59fd092020-02-03 09:58:56 -0600127 private:
SunnySrivastava1984de3c60d2020-02-03 10:34:33 -0600128 /** @brief process the given JSON file
129 */
130 void processJSON();
131
Sunny Srivastavaecb5c7d2021-09-02 07:20:24 -0500132 /** @brief Api to register host state callback.
133 * This api will register callback to listen for host state property change.
134 */
135 void listenHostState();
136
137 /** @brief Callback to listen for Host state change
138 * @param[in] msg - callback message.
139 */
Patrick Williams2eb01762022-07-22 19:26:56 -0500140 void hostStateCallBack(sdbusplus::message_t& msg);
Sunny Srivastavaecb5c7d2021-09-02 07:20:24 -0500141
Santosh Puranikb62f6052022-04-06 18:37:54 +0530142 /** @brief Api to register AssetTag property change.
143 * This api will register callback to listen for asset tag property change.
144 */
145 void listenAssetTag();
146
147 /** @brief Callback to listen for Asset tag change
148 * @param[in] msg - callback message.
149 */
Patrick Williams2eb01762022-07-22 19:26:56 -0500150 void assetTagCallback(sdbusplus::message_t& msg);
Santosh Puranikb62f6052022-04-06 18:37:54 +0530151
Santosh Puranik6b2b5372022-06-02 20:49:02 +0530152 /**
153 * @brief Restores and defaulted VPD on the system VPD EEPROM.
154 *
155 * This function will read the system VPD EEPROM and check if any of the
156 * keywords that need to be preserved across FRU replacements are defaulted
157 * in the EEPROM. If they are, this function will restore them from the
158 * value that is in the D-Bus cache.
159 */
160 void restoreSystemVpd();
161
SunnySrivastava1984b59fd092020-02-03 09:58:56 -0600162 /** @brief Persistent sdbusplus DBus bus connection. */
Patrick Williams2eb01762022-07-22 19:26:56 -0500163 sdbusplus::bus_t _bus;
SunnySrivastava1984b59fd092020-02-03 09:58:56 -0600164
165 /** @brief sdbusplus org.freedesktop.DBus.ObjectManager reference. */
Patrick Williams2eb01762022-07-22 19:26:56 -0500166 sdbusplus::server::manager_t _manager;
SunnySrivastava1984de3c60d2020-02-03 10:34:33 -0600167
168 // file to store parsed json
169 nlohmann::json jsonFile;
170
171 // map to hold mapping to inventory path to vpd file path
172 // we need as map here as it is in reverse order to that of json
173 inventory::FrusMap frus;
SunnySrivastava1984bca5aaa2020-04-21 05:31:04 -0500174
175 // map to hold the mapping of location code and inventory path
176 inventory::LocationCodeMap fruLocationCode;
SunnySrivastava19849a195542020-09-07 06:04:50 -0500177
178 // map to hold FRUs which can be replaced at standby
179 inventory::ReplaceableFrus replaceableFrus;
SunnySrivastava1984b59fd092020-02-03 09:58:56 -0600180};
181
182} // namespace manager
183} // namespace vpd
184} // namespace openpower