Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 1 | #include "power_status_monitor.hpp" |
| 2 | |
Alexander Hansen | 0a4bb2a | 2025-07-25 11:34:48 +0200 | [diff] [blame] | 3 | #include "phosphor-logging/lg2.hpp" |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 4 | #include "utils.hpp" |
| 5 | |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 6 | #include <sdbusplus/bus/match.hpp> |
| 7 | |
Alexander Hansen | 0a4bb2a | 2025-07-25 11:34:48 +0200 | [diff] [blame] | 8 | #include <flat_map> |
| 9 | |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 10 | namespace power |
| 11 | { |
| 12 | |
| 13 | const static constexpr char* busname = "xyz.openbmc_project.State.Host"; |
| 14 | const static constexpr char* interface = "xyz.openbmc_project.State.Host"; |
| 15 | const static constexpr char* path = "/xyz/openbmc_project/state/host0"; |
| 16 | const static constexpr char* property = "CurrentHostState"; |
| 17 | |
Alexander Hansen | e164627 | 2025-07-25 11:47:17 +0200 | [diff] [blame] | 18 | PowerStatusMonitor::PowerStatusMonitor(sdbusplus::asio::connection& conn) : |
| 19 | |
| 20 | powerMatch(static_cast<sdbusplus::bus_t&>(conn), |
| 21 | "type='signal',interface='" + |
| 22 | std::string(em_utils::properties::interface) + "',path='" + |
| 23 | std::string(power::path) + "',arg0='" + |
| 24 | std::string(power::interface) + "'", |
| 25 | std::bind_front(&PowerStatusMonitor::handlePowerMatch, this)) |
| 26 | |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 27 | { |
Alexander Hansen | e164627 | 2025-07-25 11:47:17 +0200 | [diff] [blame] | 28 | getInitialPowerStatus(conn); |
| 29 | } |
| 30 | |
| 31 | bool PowerStatusMonitor::isPowerOn() const |
| 32 | { |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 33 | return powerStatusOn; |
| 34 | } |
| 35 | |
Alexander Hansen | 0a4bb2a | 2025-07-25 11:34:48 +0200 | [diff] [blame] | 36 | void PowerStatusMonitor::handlePowerMatch(sdbusplus::message_t& message) |
| 37 | { |
| 38 | lg2::debug("power match triggered"); |
| 39 | |
| 40 | std::string objectName; |
| 41 | std::flat_map<std::string, std::variant<std::string>> values; |
| 42 | message.read(objectName, values); |
| 43 | auto findState = values.find(power::property); |
| 44 | if (findState != values.end()) |
| 45 | { |
| 46 | powerStatusOn = |
| 47 | std::get<std::string>(findState->second).ends_with("Running"); |
| 48 | } |
| 49 | } |
| 50 | |
Alexander Hansen | e164627 | 2025-07-25 11:47:17 +0200 | [diff] [blame] | 51 | void PowerStatusMonitor::getInitialPowerStatus( |
| 52 | sdbusplus::asio::connection& conn) |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 53 | { |
Alexander Hansen | e164627 | 2025-07-25 11:47:17 +0200 | [diff] [blame] | 54 | conn.async_method_call( |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 55 | [this](boost::system::error_code ec, |
| 56 | const std::variant<std::string>& state) { |
| 57 | if (ec) |
| 58 | { |
| 59 | return; |
| 60 | } |
Alexander Hansen | 0a4bb2a | 2025-07-25 11:34:48 +0200 | [diff] [blame] | 61 | powerStatusOn = std::get<std::string>(state).ends_with("Running"); |
Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 62 | }, |
| 63 | power::busname, power::path, em_utils::properties::interface, |
| 64 | em_utils::properties::get, power::interface, power::property); |
| 65 | } |
| 66 | |
| 67 | } // namespace power |