101539e7eSLei YU #pragma once 201539e7eSLei YU 301539e7eSLei YU #include "config.h" 401539e7eSLei YU 501539e7eSLei YU #include "activation.hpp" 67f2a2152SLei YU #include "association_interface.hpp" 791029448SLei YU #include "types.hpp" 85e0dcb39SLei YU #include "utils.hpp" 901539e7eSLei YU #include "version.hpp" 1001539e7eSLei YU 1158c26e3fSLei YU #include <filesystem> 125e0dcb39SLei YU #include <phosphor-logging/log.hpp> 1301539e7eSLei YU #include <sdbusplus/server.hpp> 1491029448SLei YU #include <xyz/openbmc_project/Association/Definitions/server.hpp> 1501539e7eSLei YU #include <xyz/openbmc_project/Collection/DeleteAll/server.hpp> 1601539e7eSLei YU 17f77189f7SLei YU class TestItemUpdater; 18f77189f7SLei YU 1901539e7eSLei YU namespace phosphor 2001539e7eSLei YU { 2101539e7eSLei YU namespace software 2201539e7eSLei YU { 2301539e7eSLei YU namespace updater 2401539e7eSLei YU { 2501539e7eSLei YU 2601539e7eSLei YU class Version; 2701539e7eSLei YU 2801539e7eSLei YU using ItemUpdaterInherit = sdbusplus::server::object::object< 29a5c47bb3SLei YU sdbusplus::xyz::openbmc_project::Association::server::Definitions>; 30a5c47bb3SLei YU 3101539e7eSLei YU namespace MatchRules = sdbusplus::bus::match::rules; 3201539e7eSLei YU 3358c26e3fSLei YU namespace fs = std::filesystem; 3458c26e3fSLei YU 3501539e7eSLei YU /** @class ItemUpdater 3601539e7eSLei YU * @brief Manages the activation of the PSU version items. 3701539e7eSLei YU */ 387f2a2152SLei YU class ItemUpdater : public ItemUpdaterInherit, public AssociationInterface 3901539e7eSLei YU { 40f77189f7SLei YU friend class ::TestItemUpdater; 41f77189f7SLei YU 4201539e7eSLei YU public: 4301539e7eSLei YU /** @brief Constructs ItemUpdater 4401539e7eSLei YU * 4501539e7eSLei YU * @param[in] bus - The D-Bus bus object 4601539e7eSLei YU * @param[in] path - The D-Bus path 4701539e7eSLei YU */ 4801539e7eSLei YU ItemUpdater(sdbusplus::bus::bus& bus, const std::string& path) : 4901539e7eSLei YU ItemUpdaterInherit(bus, path.c_str()), bus(bus), 5001539e7eSLei YU versionMatch(bus, 5101539e7eSLei YU MatchRules::interfacesAdded() + 5201539e7eSLei YU MatchRules::path(SOFTWARE_OBJPATH), 5301539e7eSLei YU std::bind(std::mem_fn(&ItemUpdater::createActivation), 5401539e7eSLei YU this, std::placeholders::_1)) 5501539e7eSLei YU { 56ad90ad51SLei YU processPSUImage(); 5758c26e3fSLei YU processStoredImage(); 58*63f9e712SLei YU syncToLatestImage(); 5901539e7eSLei YU } 6001539e7eSLei YU 6101539e7eSLei YU /** @brief Deletes version 6201539e7eSLei YU * 6301539e7eSLei YU * @param[in] versionId - Id of the version to delete 6401539e7eSLei YU */ 65a5c47bb3SLei YU void erase(const std::string& versionId); 6601539e7eSLei YU 6791029448SLei YU /** @brief Creates an active association to the 6891029448SLei YU * newly active software image 6991029448SLei YU * 7091029448SLei YU * @param[in] path - The path to create the association to. 7191029448SLei YU */ 727f2a2152SLei YU void createActiveAssociation(const std::string& path) override; 7391029448SLei YU 74ad90ad51SLei YU /** @brief Add the functional association to the 7591029448SLei YU * new "running" PSU images 7691029448SLei YU * 77ad90ad51SLei YU * @param[in] path - The path to add the association to. 7891029448SLei YU */ 797f2a2152SLei YU void addFunctionalAssociation(const std::string& path) override; 8091029448SLei YU 8191029448SLei YU /** @brief Removes the associations from the provided software image path 8291029448SLei YU * 8391029448SLei YU * @param[in] path - The path to remove the association from. 8491029448SLei YU */ 857f2a2152SLei YU void removeAssociation(const std::string& path) override; 8691029448SLei YU 877f2a2152SLei YU private: 8801539e7eSLei YU /** @brief Callback function for Software.Version match. 8901539e7eSLei YU * @details Creates an Activation D-Bus object. 9001539e7eSLei YU * 9101539e7eSLei YU * @param[in] msg - Data associated with subscribed signal 9201539e7eSLei YU */ 9301539e7eSLei YU void createActivation(sdbusplus::message::message& msg); 9401539e7eSLei YU 95a2c2cd72SLei YU using Properties = 96a2c2cd72SLei YU std::map<std::string, utils::UtilsInterface::PropertyType>; 97a2c2cd72SLei YU 98ad90ad51SLei YU /** @brief Callback function for PSU inventory match. 99ad90ad51SLei YU * @details Update an Activation D-Bus object for PSU inventory. 100ad90ad51SLei YU * 101ad90ad51SLei YU * @param[in] msg - Data associated with subscribed signal 102ad90ad51SLei YU */ 103a2c2cd72SLei YU void onPsuInventoryChangedMsg(sdbusplus::message::message& msg); 104a2c2cd72SLei YU 105a2c2cd72SLei YU /** @brief Callback function for PSU inventory match. 106a2c2cd72SLei YU * @details Update an Activation D-Bus object for PSU inventory. 107a2c2cd72SLei YU * 108a2c2cd72SLei YU * @param[in] psuPath - The PSU inventory path 109a2c2cd72SLei YU * @param[in] properties - The updated properties 110a2c2cd72SLei YU */ 111a2c2cd72SLei YU void onPsuInventoryChanged(const std::string& psuPath, 112a2c2cd72SLei YU const Properties& properties); 113ad90ad51SLei YU 11401539e7eSLei YU /** @brief Create Activation object */ 11501539e7eSLei YU std::unique_ptr<Activation> createActivationObject( 11601539e7eSLei YU const std::string& path, const std::string& versionId, 11758c26e3fSLei YU const std::string& extVersion, Activation::Status activationStatus, 1189930137bSLei YU const AssociationList& assocs, const std::string& filePath); 11901539e7eSLei YU 12001539e7eSLei YU /** @brief Create Version object */ 12101539e7eSLei YU std::unique_ptr<Version> 12201539e7eSLei YU createVersionObject(const std::string& objPath, 12301539e7eSLei YU const std::string& versionId, 12401539e7eSLei YU const std::string& versionString, 12501539e7eSLei YU sdbusplus::xyz::openbmc_project::Software::server:: 1269930137bSLei YU Version::VersionPurpose versionPurpose); 12701539e7eSLei YU 128bd3b0076SLei YU /** @brief Create Activation and Version object for PSU inventory 129bd3b0076SLei YU * @details If the same version exists for multiple PSUs, just add 130bd3b0076SLei YU * related association, instead of creating new objects. 131bd3b0076SLei YU * */ 132ad90ad51SLei YU void createPsuObject(const std::string& psuInventoryPath, 133ad90ad51SLei YU const std::string& psuVersion); 134ad90ad51SLei YU 135bd3b0076SLei YU /** @brief Remove Activation and Version object for PSU inventory 136bd3b0076SLei YU * @details If the same version exists for mutliple PSUs, just remove 137bd3b0076SLei YU * related association. 138bd3b0076SLei YU * If the version has no association, the Activation and 139bd3b0076SLei YU * Version object will be removed 140bd3b0076SLei YU */ 141bd3b0076SLei YU void removePsuObject(const std::string& psuInventoryPath); 142bd3b0076SLei YU 143ad90ad51SLei YU /** 144ad90ad51SLei YU * @brief Create and populate the active PSU Version. 145ad90ad51SLei YU */ 146ad90ad51SLei YU void processPSUImage(); 147ad90ad51SLei YU 14858c26e3fSLei YU /** @brief Create PSU Version from stored images */ 14958c26e3fSLei YU void processStoredImage(); 15058c26e3fSLei YU 15158c26e3fSLei YU /** @brief Scan a directory and create PSU Version from stored images */ 15258c26e3fSLei YU void scanDirectory(const fs::path& p); 15358c26e3fSLei YU 1546520748dSLei YU /** @brief Get the versionId of the latest PSU version */ 1556520748dSLei YU std::optional<std::string> getLatestVersionId(); 1566520748dSLei YU 157*63f9e712SLei YU /** @brief Update PSUs to the latest version */ 158*63f9e712SLei YU void syncToLatestImage(); 159*63f9e712SLei YU 160*63f9e712SLei YU /** @brief Invoke the activation via DBus */ 161*63f9e712SLei YU void invokeActivation(const std::unique_ptr<Activation>& activation); 162*63f9e712SLei YU 16301539e7eSLei YU /** @brief Persistent sdbusplus D-Bus bus connection. */ 16401539e7eSLei YU sdbusplus::bus::bus& bus; 16501539e7eSLei YU 16601539e7eSLei YU /** @brief Persistent map of Activation D-Bus objects and their 16701539e7eSLei YU * version id */ 16801539e7eSLei YU std::map<std::string, std::unique_ptr<Activation>> activations; 16901539e7eSLei YU 17001539e7eSLei YU /** @brief Persistent map of Version D-Bus objects and their 17101539e7eSLei YU * version id */ 17201539e7eSLei YU std::map<std::string, std::unique_ptr<Version>> versions; 17301539e7eSLei YU 174bd3b0076SLei YU /** @brief The reference map of PSU Inventory objects and the 175bd3b0076SLei YU * Activation*/ 176bd3b0076SLei YU std::map<std::string, const std::unique_ptr<Activation>&> 177bd3b0076SLei YU psuPathActivationMap; 178bd3b0076SLei YU 179ad90ad51SLei YU /** @brief sdbusplus signal match for PSU Software*/ 18001539e7eSLei YU sdbusplus::bus::match_t versionMatch; 18191029448SLei YU 182ad90ad51SLei YU /** @brief sdbusplus signal matches for PSU Inventory */ 183ad90ad51SLei YU std::vector<sdbusplus::bus::match_t> psuMatches; 184ad90ad51SLei YU 18591029448SLei YU /** @brief This entry's associations */ 18691029448SLei YU AssociationList assocs; 1876520748dSLei YU 1886520748dSLei YU /** @brief A collection of the version strings */ 1896520748dSLei YU std::set<std::string> versionStrings; 19001539e7eSLei YU }; 19101539e7eSLei YU 19201539e7eSLei YU } // namespace updater 19301539e7eSLei YU } // namespace software 19401539e7eSLei YU } // namespace phosphor 195