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