blob: e2bf985b1d7127ddbb962d2ff9fe0d0cd1fe0268 [file] [log] [blame]
Matthew Barthfcfa0522020-08-24 16:40:24 -05001/**
2 * Copyright © 2020 IBM Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#pragma once
17
18#include "config_base.hpp"
19
20#include <nlohmann/json.hpp>
21#include <sdbusplus/bus.hpp>
22
Matthew Bartha3a8cc52021-01-15 12:40:25 -060023#include <map>
24
Matthew Barthfcfa0522020-08-24 16:40:24 -050025namespace phosphor::fan::control::json
26{
27
28using json = nlohmann::json;
29
30/**
31 * @class Fan - Represents a configured fan control fan object
32 *
33 * A fan object contains the configured attributes for a fan within the system
34 * that will be controlled by the fan control application. These configuration
35 * attributes include, but are not limited to, the cooling zone in which the
36 * fan is included, what sensors make up the fan, the target interface to be
Matthew Barthe47c9582021-03-09 14:24:02 -060037 * used in setting a target, and any profiles(OPTIONAL) the fan should be
Matthew Barthfcfa0522020-08-24 16:40:24 -050038 * included in.
39 *
40 * (When no profile for a fan is given, the fan defaults to always be included)
41 *
42 */
43class Fan : public ConfigBase
44{
45 public:
46 /* JSON file name for fans */
47 static constexpr auto confFileName = "fans.json";
48
49 Fan() = delete;
50 Fan(const Fan&) = delete;
51 Fan(Fan&&) = delete;
52 Fan& operator=(const Fan&) = delete;
53 Fan& operator=(Fan&&) = delete;
54 ~Fan() = default;
55
56 /**
57 * Constructor
58 * Parses and populates a zone fan from JSON object data
59 *
Matthew Barthfcfa0522020-08-24 16:40:24 -050060 * @param[in] jsonObj - JSON object
Matthew Barth603ef162021-03-24 15:34:53 -050061 * @param[in] bus - sdbusplus bus object
Matthew Barthfcfa0522020-08-24 16:40:24 -050062 */
Matthew Barth603ef162021-03-24 15:34:53 -050063 Fan(const json& jsonObj, sdbusplus::bus::bus& bus);
Matthew Barthfcfa0522020-08-24 16:40:24 -050064
65 /**
Matthew Barthfcfa0522020-08-24 16:40:24 -050066 * @brief Get the zone
67 *
68 * @return Zone this fan belongs in
69 */
70 inline const auto& getZone() const
71 {
72 return _zone;
73 }
74
75 /**
76 * @brief Get the list of sensors
77 *
78 * @return List of sensors with `Target` property
79 */
80 inline const auto& getSensors() const
81 {
82 return _sensors;
83 }
84
85 /**
86 * @brief Get the sensors' interface
87 *
88 * @return Interface containing `Target` to use on sensors
89 */
90 inline const auto& getInterface() const
91 {
92 return _interface;
93 }
94
Matthew Bartha3a8cc52021-01-15 12:40:25 -060095 /**
96 * @brief Get the current fan target
97 *
98 * @return - The current target of the fan
99 */
100 inline auto getTarget() const
101 {
102 return _target;
103 }
Matthew Barthfcfa0522020-08-24 16:40:24 -0500104
105 /**
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600106 * Sets the target value on all contained sensors
107 *
108 * @param[in] target - The value to set
Matthew Barthfcfa0522020-08-24 16:40:24 -0500109 */
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600110 void setTarget(uint64_t target);
111
112 private:
113 /* The sdbusplus bus object */
114 sdbusplus::bus::bus& _bus;
Matthew Barthfcfa0522020-08-24 16:40:24 -0500115
116 /**
117 * Interface containing the `Target` property
Matthew Barthe47c9582021-03-09 14:24:02 -0600118 * to use in controlling the fan's target
Matthew Barthfcfa0522020-08-24 16:40:24 -0500119 */
120 std::string _interface;
Matthew Barthbff10802020-08-25 10:07:57 -0500121
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600122 /* Target for this fan */
123 uint64_t _target;
124
Matthew Barthbff10802020-08-25 10:07:57 -0500125 /**
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600126 * Map of sensors containing the `Target` property on
127 * dbus to the service providing them that make up the fan
128 */
129 std::map<std::string, std::string> _sensors;
130
131 /* The zone this fan belongs to */
132 std::string _zone;
133
134 /**
135 * @brief Parse and set the fan's sensor interface
Matthew Barthbff10802020-08-25 10:07:57 -0500136 *
137 * @param[in] jsonObj - JSON object for the fan
138 *
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600139 * Sets the sensor interface to use when setting the `Target` property
Matthew Barthbff10802020-08-25 10:07:57 -0500140 */
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600141 void setInterface(const json& jsonObj);
Matthew Barthbff10802020-08-25 10:07:57 -0500142
143 /**
144 * @brief Parse and set the fan's sensor list
145 *
146 * @param[in] jsonObj - JSON object for the fan
147 *
148 * Sets the list of sensors that contain a `Target` property on dbus
149 * that make up this fan.
150 */
151 void setSensors(const json& jsonObj);
152
153 /**
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600154 * @brief Parse and set the fan's zone
Matthew Barthbff10802020-08-25 10:07:57 -0500155 *
156 * @param[in] jsonObj - JSON object for the fan
157 *
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600158 * Sets the zone this fan is included in.
Matthew Barthbff10802020-08-25 10:07:57 -0500159 */
Matthew Bartha3a8cc52021-01-15 12:40:25 -0600160 void setZone(const json& jsonObj);
Matthew Barthfcfa0522020-08-24 16:40:24 -0500161};
162
163} // namespace phosphor::fan::control::json