| #pragma once |
| |
| #include "xyz/openbmc_project/Logging/Entry/server.hpp" |
| #include "xyz/openbmc_project/Object/Delete/server.hpp" |
| #include "xyz/openbmc_project/Software/Version/server.hpp" |
| |
| #include <sdbusplus/bus.hpp> |
| #include <sdbusplus/server/object.hpp> |
| #include <sdeventplus/event.hpp> |
| #include <sdeventplus/source/event.hpp> |
| #include <xyz/openbmc_project/Association/Definitions/server.hpp> |
| #include <xyz/openbmc_project/Common/FilePath/server.hpp> |
| |
| namespace phosphor |
| { |
| namespace logging |
| { |
| |
| using EntryIfaces = sdbusplus::server::object::object< |
| sdbusplus::xyz::openbmc_project::Logging::server::Entry, |
| sdbusplus::xyz::openbmc_project::Object::server::Delete, |
| sdbusplus::xyz::openbmc_project::Association::server::Definitions, |
| sdbusplus::xyz::openbmc_project::Software::server::Version, |
| sdbusplus::xyz::openbmc_project::Common::server::FilePath>; |
| |
| using AssociationList = |
| std::vector<std::tuple<std::string, std::string, std::string>>; |
| |
| namespace internal |
| { |
| class Manager; |
| } |
| |
| /** @class Entry |
| * @brief OpenBMC logging entry implementation. |
| * @details A concrete implementation for the |
| * xyz.openbmc_project.Logging.Entry and |
| * xyz.openbmc_project.Associations.Definitions DBus APIs. |
| */ |
| class Entry : public EntryIfaces |
| { |
| public: |
| Entry() = delete; |
| Entry(const Entry&) = delete; |
| Entry& operator=(const Entry&) = delete; |
| Entry(Entry&&) = delete; |
| Entry& operator=(Entry&&) = delete; |
| virtual ~Entry() = default; |
| |
| /** @brief Constructor to put object onto bus at a dbus path. |
| * Defer signal registration (pass true for deferSignal to the |
| * base class) until after the properties are set. |
| * @param[in] bus - Bus to attach to. |
| * @param[in] path - Path to attach at. |
| * @param[in] idErr - The error entry id. |
| * @param[in] timestampErr - The commit timestamp. |
| * @param[in] severityErr - The severity of the error. |
| * @param[in] msgErr - The message of the error. |
| * @param[in] additionalDataErr - The error metadata. |
| * @param[in] objects - The list of associations. |
| * @param[in] fwVersion - The BMC code version. |
| * @param[in] parent - The error's parent. |
| */ |
| Entry(sdbusplus::bus::bus& bus, const std::string& path, uint32_t idErr, |
| uint64_t timestampErr, Level severityErr, std::string&& msgErr, |
| std::vector<std::string>&& additionalDataErr, |
| AssociationList&& objects, const std::string& fwVersion, |
| internal::Manager& parent) : |
| EntryIfaces(bus, path.c_str(), true), |
| parent(parent) |
| { |
| id(idErr); |
| severity(severityErr); |
| timestamp(timestampErr); |
| updateTimestamp(timestampErr); |
| message(std::move(msgErr)); |
| additionalData(std::move(additionalDataErr)); |
| associations(std::move(objects)); |
| // Store a copy of associations in case we need to recreate |
| assocs = associations(); |
| sdbusplus::xyz::openbmc_project::Logging::server::Entry::resolved( |
| false); |
| |
| version(fwVersion); |
| purpose(VersionPurpose::BMC); |
| |
| // Emit deferred signal. |
| this->emit_object_added(); |
| }; |
| |
| /** @brief Constructor that puts an "empty" error object on the bus, |
| * with only the id property populated. Rest of the properties |
| * to be set by the caller. Caller should emit the added signal. |
| * @param[in] bus - Bus to attach to. |
| * @param[in] path - Path to attach at. |
| * @param[in] id - The error entry id. |
| * @param[in] parent - The error's parent. |
| */ |
| Entry(sdbusplus::bus::bus& bus, const std::string& path, uint32_t entryId, |
| internal::Manager& parent) : |
| EntryIfaces(bus, path.c_str(), true), |
| parent(parent) |
| { |
| id(entryId); |
| }; |
| |
| /** @brief Set resolution status of the error. |
| * @param[in] value - boolean indicating resolution |
| * status (true = resolved) |
| * @returns value of 'Resolved' property |
| */ |
| bool resolved(bool value) override; |
| |
| using sdbusplus::xyz::openbmc_project::Logging::server::Entry::resolved; |
| |
| /** @brief Delete this d-bus object. |
| */ |
| void delete_() override; |
| |
| /** @brief Severity level to check in cap. |
| * @details Errors with severity lesser than this will be |
| * considered as low priority and maximum ERROR_INFO_CAP |
| * number errors of this category will be captured. |
| */ |
| static constexpr auto sevLowerLimit = Entry::Level::Informational; |
| |
| /** |
| * @brief Returns the file descriptor to the Entry file. |
| * @return unix_fd - File descriptor to the Entry file. |
| */ |
| sdbusplus::message::unix_fd getEntry() override; |
| |
| private: |
| /** @brief This entry's associations */ |
| AssociationList assocs = {}; |
| |
| /** @brief This entry's parent */ |
| internal::Manager& parent; |
| |
| /** |
| * @brief The event source for closing the Entry file descriptor after it |
| * has been returned from the getEntry D-Bus method. |
| */ |
| std::unique_ptr<sdeventplus::source::Defer> fdCloseEventSource; |
| |
| /** |
| * @brief Closes the file descriptor passed in. |
| * @details This is called from the event loop to close FDs returned from |
| * getEntry(). |
| * @param[in] fd - The file descriptor to close |
| * @param[in] source - The event source object used |
| */ |
| void closeFD(int fd, sdeventplus::source::EventBase& source); |
| }; |
| |
| } // namespace logging |
| } // namespace phosphor |