| Alexander Hansen | 8c99fcf | 2025-07-24 12:27:05 +0200 | [diff] [blame] | 1 | #include "power_status_monitor.hpp" | 
|  | 2 |  | 
|  | 3 | #include "utils.hpp" | 
|  | 4 |  | 
| Ed Tanous | dd5732d | 2025-10-13 10:50:26 -0700 | [diff] [blame^] | 5 | #include <phosphor-logging/lg2.hpp> | 
| 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 |