blob: 24dbcedf8989b9b72bf2c6c86c0c8685c8d7a3aa [file] [log] [blame]
#pragma once
#include "config.h"
#include "dump_manager_bmc.hpp"
#include <cereal/access.hpp>
#include <sdbusplus/bus.hpp>
#include <sdbusplus/server.hpp>
#include <xyz/openbmc_project/Dump/Create/server.hpp>
#include <filesystem>
#include <set>
namespace phosphor
{
namespace dump
{
namespace elog
{
using Mgr = phosphor::dump::bmc::Manager;
using EId = uint32_t;
using ElogList = std::set<EId>;
/** @class Watch
* @brief Adds d-bus signal based watch for elog add and delete.
* @details This implements methods for watching for InternalFailure
* type error message and call appropriate function to initiate dump
*/
class Watch
{
public:
Watch() = delete;
~Watch() = default;
Watch(const Watch&) = delete;
Watch& operator=(const Watch&) = delete;
Watch(Watch&&) = delete;
Watch& operator=(Watch&&) = delete;
/** @brief constructs watch for elog add and delete signals.
* @param[in] bus - The Dbus bus object
* @param[in] mgr - Dump Manager object
*/
Watch(sdbusplus::bus_t& bus, Mgr& mgr);
private:
friend class cereal::access;
/** @brief Function required by Cereal to perform serialization.
* @tparam Archive - Cereal archive type (binary in our case).
* @param[in] a - reference to Cereal archive.
* @param[in] version - Class version that enables handling
* a serialized data across code levels
*/
template <class Archive>
void serialize(Archive& a, const std::uint32_t version)
{
(void)version; // Mark version as unused to avoid warning
a(elogList);
// TODO: openbmc/phosphor-debug-collector#1
// Split into load/save so that it enables
// version compare during serialization
}
/** @brief Callback function for error log add.
* @details InternalError type error message initiates
* Internal error type dump request.
* @param[in] msg - Data associated with subscribed signal
*/
void addCallback(sdbusplus::message_t& msg);
/** @brief Callback function for error log delete.
* @param[in] msg - Data associated with subscribed signal
*/
void delCallback(sdbusplus::message_t& msg);
/** @brief get elog ID from elog entry object string.
* @param[in] objectPath - elog entry object path.
* @return - elog id.
*/
inline EId getEid(const std::string& objectPath)
{
std::filesystem::path path(objectPath);
return std::stoul(path.filename());
}
/** @brief BMC Dump Manager object. */
Mgr& mgr;
/** @brief sdbusplus signal match for elog add */
sdbusplus::bus::match_t addMatch;
/** @brief sdbusplus signal match for elog delete */
sdbusplus::bus::match_t delMatch;
/** @brief List of elog ids, which have associated dumps created */
ElogList elogList;
};
} // namespace elog
} // namespace dump
} // namespace phosphor