blob: 6d813afe7f6c2e54972455bbcd435dab9362f945 [file] [log] [blame]
#pragma once
#include "external_storer_interface.hpp"
#include "nlohmann/json.hpp"
#include "notifier_dbus_handler.hpp"
#include <boost/uuid/uuid_generators.hpp>
#include <filesystem>
#include <string>
namespace bios_bmc_smm_error_logger
{
namespace rde
{
/**
* @brief Simple Base class for writing JSON data to files.
*
* This class allows us to unit test the ExternalStorerFileInterface
* functionality.
*/
class FileHandlerInterface
{
public:
virtual ~FileHandlerInterface() = default;
/**
* @brief Create a folder at the provided path.
*
* @param[in] folderPath - folder path.
* @return true if successful.
*/
virtual bool createFolder(const std::string& folderPath) const = 0;
/**
* @brief Create an index.json and write the JSON content to it.
*
* If the file already exists, this will overwrite it.
*
* @param[in] folderPath - path of the file without including the file name.
* @param[in] jsonPdr - PDR in nlohmann::json format.
* @return true if successful.
*/
virtual bool createFile(const std::string& folderPath,
const nlohmann::json& jsonPdr) const = 0;
};
/**
* @brief Class for handling folder and file creation for ExternalStorer.
*/
class ExternalStorerFileWriter : public FileHandlerInterface
{
public:
bool createFolder(const std::string& folderPath) const override;
bool createFile(const std::string& folderPath,
const nlohmann::json& jsonPdr) const override;
};
/**
* @brief Categories for different redfish JSON strings.
*/
enum class JsonPdrType
{
logEntry,
logService,
other
};
/**
* @brief Class for handling ExternalStorer file operations.
*/
class ExternalStorerFileInterface : public ExternalStorerInterface
{
public:
/**
* @brief Constructor for the ExternalStorerFileInterface.
*
* @param[in] conn - sdbusplus asio connection.
* @param[in] rootPath - root path for creating redfish folders.
* Eg: "/run/bmcweb"
* @param[in] fileHandler - an ExternalStorerFileWriter object. This class
* will take the ownership of this object.
*/
ExternalStorerFileInterface(
const std::shared_ptr<sdbusplus::asio::connection>& conn,
std::string_view rootPath,
std::unique_ptr<FileHandlerInterface> fileHandler);
bool publishJson(std::string_view jsonStr) override;
private:
std::string rootPath;
std::unique_ptr<FileHandlerInterface> fileHandler;
std::string logServiceId;
std::unique_ptr<CperFileNotifierHandler> cperNotifier;
boost::uuids::random_generator randomGen;
/**
* @brief Get the type of the received PDR.
*
* @param[in] jsonSchema - PDR in nlohmann::json format.
* @return JsonPdrType of the PDR.
*/
JsonPdrType getSchemaType(const nlohmann::json& jsonSchema) const;
/**
* @brief Process a LogEntry type PDR.
*
* @param[in] logEntry - PDR in nlohmann::json format.
* @return true if successful.
*/
bool processLogEntry(nlohmann::json& logEntry);
/**
* @brief Process a LogService type PDR.
*
* @param[in] logService - PDR in nlohmann::json format.
* @return true if successful.
*/
bool processLogService(const nlohmann::json& logService);
/**
* @brief Process PDRs that doesn't have a specific category.
*
* @param[in] jsonPdr - PDR in nlohmann::json format.
* @return true if successful.
*/
bool processOtherTypes(const nlohmann::json& jsonPdr) const;
/**
* @brief Create the needed folders and the index.json.
*
* @param subPath - path within the root folder.
* @param jsonPdr - PDR in nlohmann::json format.
* @return true if successful.
*/
bool createFile(const std::string& subPath,
const nlohmann::json& jsonPdr) const;
};
} // namespace rde
} // namespace bios_bmc_smm_error_logger