blob: 99c64c98e6b9c0c31a956faa6aa4b9f1b1a7b665 [file] [log] [blame]
#pragma once
#include <sdbusplus/bus.hpp>
#include "xyz/openbmc_project/Software/Version/server.hpp"
#include "xyz/openbmc_project/Common/FilePath/server.hpp"
#include <functional>
namespace phosphor
{
namespace software
{
namespace manager
{
typedef std::function<void(std::string)> eraseFunc;
using VersionInherit = sdbusplus::server::object::object<
sdbusplus::xyz::openbmc_project::Software::server::Version,
sdbusplus::xyz::openbmc_project::Common::server::FilePath>;
/** @class Version
* @brief OpenBMC version software management implementation.
* @details A concrete implementation for xyz.openbmc_project.Software.Version
* D-Bus API.
*/
class Version : public VersionInherit
{
public:
/** @brief Constructs Version Software Manager
*
* @param[in] bus - The D-Bus bus object
* @param[in] objPath - The D-Bus object path
* @param[in] versionString - The version string
* @param[in] versionPurpose - The version purpose
* @param[in] filePath - The image filesystem path
*/
Version(sdbusplus::bus::bus& bus,
const std::string& objPath,
const std::string& versionString,
VersionPurpose versionPurpose,
const std::string& filePath) : VersionInherit(
bus, (objPath).c_str(), true),
versionStr(versionString)
{
// Set properties.
purpose(versionPurpose);
version(versionString);
path(filePath);
// Emit deferred signal.
emit_object_added();
}
/**
* @brief Read the manifest file to get the value of the key.
*
* @return The value of the key.
**/
static std::string getValue(const std::string& manifestFilePath,
std::string key);
/**
* @brief Calculate the version id from the version string.
*
* @details The version id is a unique 8 hexadecimal digit id
* calculated from the version string.
*
* @param[in] version - The image's version string (e.g. v1.99.10-19).
*
* @return The id.
*/
static std::string getId(const std::string& version);
/**
* @brief Get the active BMC version string.
*
* @param[in] releaseFilePath - The path to the file which contains
* the release version string.
*
* @return The version string (e.g. v1.99.10-19).
*/
static std::string getBMCVersion(const std::string& releaseFilePath);
/* @brief Check if this version matches the currently running version
*
* @return - Returns true if this version matches the currently running
* version.
*/
bool isFunctional();
private:
/** @brief This Version's version string */
const std::string versionStr;
};
} // namespace manager
} // namespace software
} // namespace phosphor