blob: 62e272c83baf1a330eb59731175e74ac6cad0f17 [file] [log] [blame]
Matthew Barth81748b12018-05-02 16:03:48 -05001#include "conditions.hpp"
Matthew Barth177fe982020-05-26 11:05:19 -05002
Matthew Barth81748b12018-05-02 16:03:48 -05003#include "sdbusplus.hpp"
Matthew Barth3ad14342020-06-08 16:17:42 -05004#include "types.hpp"
5
6#include <nlohmann/json.hpp>
7#include <phosphor-logging/log.hpp>
Matthew Barth81748b12018-05-02 16:03:48 -05008
Matthew Barth177fe982020-05-26 11:05:19 -05009#include <algorithm>
10
Matthew Barth81748b12018-05-02 16:03:48 -050011namespace phosphor
12{
13namespace fan
14{
15namespace monitor
16{
17namespace condition
18{
19
Matthew Barth3ad14342020-06-08 16:17:42 -050020using json = nlohmann::json;
21using namespace phosphor::logging;
22
Matthew Barth81748b12018-05-02 16:03:48 -050023Condition propertiesMatch(std::vector<PropertyState>&& propStates)
24{
Patrick Williamscb356d42022-07-22 19:26:53 -050025 return [pStates = std::move(propStates)](sdbusplus::bus_t& bus) {
Patrick Williamsdfddd642024-08-16 15:21:51 -040026 return std::all_of(
27 pStates.begin(), pStates.end(), [&bus](const auto& p) {
28 return util::SDBusPlus::getPropertyVariant<PropertyValue>(
29 bus, std::get<propObj>(p.first),
30 std::get<propIface>(p.first),
31 std::get<propName>(p.first)) == p.second;
32 });
Matthew Barth81748b12018-05-02 16:03:48 -050033 };
34}
35
Matthew Barth3ad14342020-06-08 16:17:42 -050036Condition getPropertiesMatch(const json& condParams)
37{
38 if (!condParams.contains("properties"))
39 {
40 // Log error on missing required parameter
41 log<level::ERR>(
42 "Missing fan monitor condition properties",
43 entry("NAME=%s", condParams["name"].get<std::string>().c_str()));
44 throw std::runtime_error("Missing fan monitor condition properties");
45 }
46 std::vector<PropertyState> propStates;
47 for (auto& param : condParams["properties"])
48 {
49 if (!param.contains("object") || !param.contains("interface") ||
50 !param.contains("property"))
51 {
52 // Log error on missing required parameters
53 log<level::ERR>("Missing propertiesMatch condition parameters",
54 entry("REQUIRED_PARAMETERS=%s",
55 "{object, interface, property}"));
56 throw std::runtime_error(
57 "Missing propertiesMatch condition parameters");
58 }
59
60 auto propAttrs = param["property"];
61 if (!propAttrs.contains("name") || !propAttrs.contains("value"))
62 {
63 // Log error on missing required parameters
64 log<level::ERR>(
65 "Missing propertiesMatch condition property attributes",
66 entry("REQUIRED_ATTRIBUTES=%s", "{name, value}"));
67 throw std::runtime_error(
68 "Missing propertiesMatch condition property attributes");
69 }
70
71 std::string type = "";
72 if (propAttrs.contains("type"))
73 {
74 type = propAttrs["type"].get<std::string>();
75 }
76
77 // Add property for propertiesMatch condition
78 propStates.emplace_back(PropertyState(
79 {param["object"].get<std::string>(),
80 param["interface"].get<std::string>(),
81 propAttrs["name"].get<std::string>()},
82 JsonTypeHandler::getPropValue(propAttrs["value"], type)));
83 }
84
85 return make_condition(condition::propertiesMatch(std::move(propStates)));
86}
87
Matthew Barth81748b12018-05-02 16:03:48 -050088} // namespace condition
89} // namespace monitor
90} // namespace fan
91} // namespace phosphor