Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 1 | #pragma once |
| 2 | |
Patrick Williams | e7e741e | 2024-11-21 16:21:56 -0500 | [diff] [blame] | 3 | #include "util.hpp" |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 4 | #include "xyz/openbmc_project/Logging/Entry/server.hpp" |
Deepak Kodihalli | 36db46c | 2017-03-31 06:28:44 -0500 | [diff] [blame] | 5 | #include "xyz/openbmc_project/Object/Delete/server.hpp" |
Matt Spinler | 375ac9b | 2018-05-01 15:20:55 -0500 | [diff] [blame] | 6 | #include "xyz/openbmc_project/Software/Version/server.hpp" |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 7 | |
| 8 | #include <sdbusplus/bus.hpp> |
| 9 | #include <sdbusplus/server/object.hpp> |
Adriana Kobylak | eb5d3f2 | 2021-02-04 14:03:28 -0600 | [diff] [blame] | 10 | #include <sdeventplus/event.hpp> |
| 11 | #include <sdeventplus/source/event.hpp> |
John Wang | 27d8281 | 2019-09-11 16:39:36 +0800 | [diff] [blame] | 12 | #include <xyz/openbmc_project/Association/Definitions/server.hpp> |
Adriana Kobylak | 1ff95ef | 2020-12-03 13:52:19 -0600 | [diff] [blame] | 13 | #include <xyz/openbmc_project/Common/FilePath/server.hpp> |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 14 | |
| 15 | namespace phosphor |
| 16 | { |
| 17 | namespace logging |
| 18 | { |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 19 | |
Patrick Williams | 45e8352 | 2022-07-22 19:26:52 -0500 | [diff] [blame] | 20 | using EntryIfaces = sdbusplus::server::object_t< |
Willy Tu | 6ddbf69 | 2023-09-05 10:54:16 -0700 | [diff] [blame] | 21 | sdbusplus::server::xyz::openbmc_project::logging::Entry, |
| 22 | sdbusplus::server::xyz::openbmc_project::object::Delete, |
| 23 | sdbusplus::server::xyz::openbmc_project::association::Definitions, |
| 24 | sdbusplus::server::xyz::openbmc_project::software::Version, |
| 25 | sdbusplus::server::xyz::openbmc_project::common::FilePath>; |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 26 | |
Deepak Kodihalli | 35b4637 | 2017-02-27 04:58:18 -0600 | [diff] [blame] | 27 | using AssociationList = |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 28 | std::vector<std::tuple<std::string, std::string, std::string>>; |
Deepak Kodihalli | 35b4637 | 2017-02-27 04:58:18 -0600 | [diff] [blame] | 29 | |
Nagaraju Goruganti | 05aae8b | 2017-08-30 07:56:12 -0500 | [diff] [blame] | 30 | namespace internal |
| 31 | { |
Deepak Kodihalli | 8110ca6 | 2017-04-10 02:11:54 -0500 | [diff] [blame] | 32 | class Manager; |
Nagaraju Goruganti | 05aae8b | 2017-08-30 07:56:12 -0500 | [diff] [blame] | 33 | } |
Deepak Kodihalli | 8110ca6 | 2017-04-10 02:11:54 -0500 | [diff] [blame] | 34 | |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 35 | /** @class Entry |
| 36 | * @brief OpenBMC logging entry implementation. |
| 37 | * @details A concrete implementation for the |
Deepak Kodihalli | b388da6 | 2017-02-27 00:47:12 -0600 | [diff] [blame] | 38 | * xyz.openbmc_project.Logging.Entry and |
John Wang | 27d8281 | 2019-09-11 16:39:36 +0800 | [diff] [blame] | 39 | * xyz.openbmc_project.Associations.Definitions DBus APIs. |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 40 | */ |
Deepak Kodihalli | b388da6 | 2017-02-27 00:47:12 -0600 | [diff] [blame] | 41 | class Entry : public EntryIfaces |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 42 | { |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 43 | public: |
| 44 | Entry() = delete; |
| 45 | Entry(const Entry&) = delete; |
| 46 | Entry& operator=(const Entry&) = delete; |
| 47 | Entry(Entry&&) = delete; |
| 48 | Entry& operator=(Entry&&) = delete; |
| 49 | virtual ~Entry() = default; |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 50 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 51 | /** @brief Constructor to put object onto bus at a dbus path. |
| 52 | * Defer signal registration (pass true for deferSignal to the |
| 53 | * base class) until after the properties are set. |
| 54 | * @param[in] bus - Bus to attach to. |
Matt Spinler | fb978da | 2022-01-21 08:42:24 -0600 | [diff] [blame] | 55 | * @param[in] objectPath - Path to attach at. |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 56 | * @param[in] idErr - The error entry id. |
| 57 | * @param[in] timestampErr - The commit timestamp. |
| 58 | * @param[in] severityErr - The severity of the error. |
| 59 | * @param[in] msgErr - The message of the error. |
| 60 | * @param[in] additionalDataErr - The error metadata. |
| 61 | * @param[in] objects - The list of associations. |
| 62 | * @param[in] fwVersion - The BMC code version. |
Matt Spinler | fb978da | 2022-01-21 08:42:24 -0600 | [diff] [blame] | 63 | * @param[in] filePath - Serialization path |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 64 | * @param[in] parent - The error's parent. |
| 65 | */ |
Patrick Williams | 45e8352 | 2022-07-22 19:26:52 -0500 | [diff] [blame] | 66 | Entry(sdbusplus::bus_t& bus, const std::string& objectPath, uint32_t idErr, |
| 67 | uint64_t timestampErr, Level severityErr, std::string&& msgErr, |
| 68 | std::vector<std::string>&& additionalDataErr, |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 69 | AssociationList&& objects, const std::string& fwVersion, |
Matt Spinler | fb978da | 2022-01-21 08:42:24 -0600 | [diff] [blame] | 70 | const std::string& filePath, internal::Manager& parent) : |
Patrick Williams | 6ef6b25 | 2022-03-30 14:28:27 -0500 | [diff] [blame] | 71 | EntryIfaces(bus, objectPath.c_str(), EntryIfaces::action::defer_emit), |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 72 | parent(parent) |
| 73 | { |
Matt Spinler | ef952af | 2021-08-19 10:23:05 -0500 | [diff] [blame] | 74 | id(idErr, true); |
| 75 | severity(severityErr, true); |
| 76 | timestamp(timestampErr, true); |
| 77 | updateTimestamp(timestampErr, true); |
| 78 | message(std::move(msgErr), true); |
| 79 | additionalData(std::move(additionalDataErr), true); |
Patrick Williams | e7e741e | 2024-11-21 16:21:56 -0500 | [diff] [blame] | 80 | additionalData2(util::additional_data::parse(additionalData()), true); |
Matt Spinler | ef952af | 2021-08-19 10:23:05 -0500 | [diff] [blame] | 81 | associations(std::move(objects), true); |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 82 | // Store a copy of associations in case we need to recreate |
| 83 | assocs = associations(); |
Patrick Williams | 075c792 | 2024-08-16 15:19:49 -0400 | [diff] [blame] | 84 | sdbusplus::server::xyz::openbmc_project::logging::Entry::resolved( |
| 85 | false, true); |
Adriana Kobylak | 4ea7f31 | 2017-01-10 12:52:34 -0600 | [diff] [blame] | 86 | |
Matt Spinler | ef952af | 2021-08-19 10:23:05 -0500 | [diff] [blame] | 87 | version(fwVersion, true); |
| 88 | purpose(VersionPurpose::BMC, true); |
Matt Spinler | fb978da | 2022-01-21 08:42:24 -0600 | [diff] [blame] | 89 | path(filePath, true); |
Matt Spinler | 375ac9b | 2018-05-01 15:20:55 -0500 | [diff] [blame] | 90 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 91 | // Emit deferred signal. |
| 92 | this->emit_object_added(); |
| 93 | }; |
Adriana Kobylak | 4ea7f31 | 2017-01-10 12:52:34 -0600 | [diff] [blame] | 94 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 95 | /** @brief Constructor that puts an "empty" error object on the bus, |
| 96 | * with only the id property populated. Rest of the properties |
| 97 | * to be set by the caller. Caller should emit the added signal. |
| 98 | * @param[in] bus - Bus to attach to. |
| 99 | * @param[in] path - Path to attach at. |
| 100 | * @param[in] id - The error entry id. |
| 101 | * @param[in] parent - The error's parent. |
| 102 | */ |
Patrick Williams | 45e8352 | 2022-07-22 19:26:52 -0500 | [diff] [blame] | 103 | Entry(sdbusplus::bus_t& bus, const std::string& path, uint32_t entryId, |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 104 | internal::Manager& parent) : |
Patrick Williams | 6ef6b25 | 2022-03-30 14:28:27 -0500 | [diff] [blame] | 105 | EntryIfaces(bus, path.c_str(), EntryIfaces::action::defer_emit), |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 106 | parent(parent) |
| 107 | { |
Matt Spinler | ef952af | 2021-08-19 10:23:05 -0500 | [diff] [blame] | 108 | id(entryId, true); |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 109 | }; |
Deepak Kodihalli | 72654f1 | 2017-06-12 04:33:29 -0500 | [diff] [blame] | 110 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 111 | /** @brief Set resolution status of the error. |
| 112 | * @param[in] value - boolean indicating resolution |
| 113 | * status (true = resolved) |
| 114 | * @returns value of 'Resolved' property |
| 115 | */ |
| 116 | bool resolved(bool value) override; |
Deepak Kodihalli | 90abed6 | 2017-03-27 03:56:44 -0500 | [diff] [blame] | 117 | |
Willy Tu | 6ddbf69 | 2023-09-05 10:54:16 -0700 | [diff] [blame] | 118 | using sdbusplus::server::xyz::openbmc_project::logging::Entry::resolved; |
Deepak Kodihalli | 90abed6 | 2017-03-27 03:56:44 -0500 | [diff] [blame] | 119 | |
Vijay Lobo | d354a39 | 2021-06-01 16:21:02 -0500 | [diff] [blame] | 120 | /** @brief Update eventId string of the error. |
| 121 | * @param[in] value - The eventID |
| 122 | * @returns New property value |
| 123 | */ |
| 124 | std::string eventId(std::string value) override; |
| 125 | |
Willy Tu | 6ddbf69 | 2023-09-05 10:54:16 -0700 | [diff] [blame] | 126 | using sdbusplus::server::xyz::openbmc_project::logging::Entry::eventId; |
Vijay Lobo | d354a39 | 2021-06-01 16:21:02 -0500 | [diff] [blame] | 127 | |
Vijay Lobo | 593a4c6 | 2021-06-16 14:25:26 -0500 | [diff] [blame] | 128 | /** @brief Update resolution string of the error. |
| 129 | * @param[in] value - The resolution |
| 130 | * @returns New property value |
| 131 | */ |
| 132 | std::string resolution(std::string value) override; |
| 133 | |
Willy Tu | 6ddbf69 | 2023-09-05 10:54:16 -0700 | [diff] [blame] | 134 | using sdbusplus::server::xyz::openbmc_project::logging::Entry::resolution; |
Vijay Lobo | 593a4c6 | 2021-06-16 14:25:26 -0500 | [diff] [blame] | 135 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 136 | /** @brief Delete this d-bus object. |
| 137 | */ |
| 138 | void delete_() override; |
Deepak Kodihalli | 36db46c | 2017-03-31 06:28:44 -0500 | [diff] [blame] | 139 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 140 | /** @brief Severity level to check in cap. |
| 141 | * @details Errors with severity lesser than this will be |
| 142 | * considered as low priority and maximum ERROR_INFO_CAP |
| 143 | * number errors of this category will be captured. |
| 144 | */ |
| 145 | static constexpr auto sevLowerLimit = Entry::Level::Informational; |
Nagaraju Goruganti | f8a5a79 | 2017-10-13 08:09:52 -0500 | [diff] [blame] | 146 | |
Adriana Kobylak | eb5d3f2 | 2021-02-04 14:03:28 -0600 | [diff] [blame] | 147 | /** |
| 148 | * @brief Returns the file descriptor to the Entry file. |
| 149 | * @return unix_fd - File descriptor to the Entry file. |
| 150 | */ |
| 151 | sdbusplus::message::unix_fd getEntry() override; |
| 152 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 153 | private: |
| 154 | /** @brief This entry's associations */ |
| 155 | AssociationList assocs = {}; |
Deepak Kodihalli | 8110ca6 | 2017-04-10 02:11:54 -0500 | [diff] [blame] | 156 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 157 | /** @brief This entry's parent */ |
| 158 | internal::Manager& parent; |
Adriana Kobylak | eb5d3f2 | 2021-02-04 14:03:28 -0600 | [diff] [blame] | 159 | |
| 160 | /** |
| 161 | * @brief The event source for closing the Entry file descriptor after it |
| 162 | * has been returned from the getEntry D-Bus method. |
| 163 | */ |
| 164 | std::unique_ptr<sdeventplus::source::Defer> fdCloseEventSource; |
| 165 | |
| 166 | /** |
| 167 | * @brief Closes the file descriptor passed in. |
| 168 | * @details This is called from the event loop to close FDs returned from |
| 169 | * getEntry(). |
| 170 | * @param[in] fd - The file descriptor to close |
| 171 | * @param[in] source - The event source object used |
| 172 | */ |
| 173 | void closeFD(int fd, sdeventplus::source::EventBase& source); |
Adriana Kobylak | 88d7cf8 | 2017-01-24 12:30:15 -0600 | [diff] [blame] | 174 | }; |
| 175 | |
| 176 | } // namespace logging |
| 177 | } // namespace phosphor |