1 #pragma once
2 
3 #include "error_reporter.hpp"
4 #include "fan.hpp"
5 #include "psensor.hpp"
6 #include "rpolicy.hpp"
7 
8 #include <nlohmann/json.hpp>
9 #include <sdbusplus/bus.hpp>
10 #include <sdeventplus/source/signal.hpp>
11 
12 #include <filesystem>
13 #include <memory>
14 #include <string>
15 #include <vector>
16 
17 namespace phosphor
18 {
19 namespace fan
20 {
21 namespace presence
22 {
23 
24 namespace fs = std::filesystem;
25 using json = nlohmann::json;
26 
27 constexpr auto confFileName = "config.json";
28 constexpr auto confAppName = "presence";
29 
30 using policies = std::vector<std::unique_ptr<RedundancyPolicy>>;
31 
32 constexpr auto fanPolicyFanPos = 0;
33 constexpr auto fanPolicySensorListPos = 1;
34 using fanPolicy = std::tuple<Fan, std::vector<std::unique_ptr<PresenceSensor>>>;
35 
36 // Presence method handler function
37 using methodHandler =
38     std::function<std::unique_ptr<PresenceSensor>(size_t, const json&)>;
39 // Presence redundancy policy handler function
40 using rpolicyHandler =
41     std::function<std::unique_ptr<RedundancyPolicy>(const fanPolicy&)>;
42 
43 class JsonConfig
44 {
45   public:
46     JsonConfig() = delete;
47     JsonConfig(const JsonConfig&) = delete;
48     JsonConfig(JsonConfig&&) = delete;
49     JsonConfig& operator=(const JsonConfig&) = delete;
50     JsonConfig& operator=(JsonConfig&&) = delete;
51     ~JsonConfig() = default;
52 
53     /**
54      * Constructor
55      *
56      * @param[in] bus - sdbusplus bus object
57      */
58     explicit JsonConfig(sdbusplus::bus::bus& bus);
59 
60     /**
61      * @brief Get the json config based fan presence policies
62      *
63      * @return - The fan presence policies
64      */
65     static const policies& get();
66 
67     /**
68      * @brief Callback function to handle receiving a HUP signal to
69      * reload the json configuration.
70      *
71      * @param[in] sigSrc - sd_event_source signal wrapper
72      * @param[in] sigInfo - signal info on signal fd
73      */
74     void sighupHandler(sdeventplus::source::Signal& sigSrc,
75                        const struct signalfd_siginfo* sigInfo);
76 
77     /**
78      * @brief Parses and populates the fan presence policies from
79      *        the json file and then starts the actual presence
80      *        detecting.
81      */
82     void start();
83 
84   private:
85     /* Fan presence policies */
86     static policies _policies;
87 
88     /* The sdbusplus bus object */
89     sdbusplus::bus::bus& _bus;
90 
91     /* List of Fan objects to have presence policies */
92     std::vector<fanPolicy> _fans;
93 
94     /* Presence methods mapping to their associated handler function */
95     static const std::map<std::string, methodHandler> _methods;
96 
97     /**
98      * Presence redundancy policy mapping to their associated handler
99      * function
100      */
101     static const std::map<std::string, rpolicyHandler> _rpolicies;
102 
103     /**
104      * Class that handles reporting errors for missing fans.
105      */
106     std::unique_ptr<ErrorReporter> _reporter;
107 
108     /**
109      * @brief Process the json config to extract the defined fan presence
110      * policies.
111      *
112      * @param[in] jsonConf - parsed json configuration data
113      */
114     void process(const json& jsonConf);
115 
116     /**
117      * @brief Get the redundancy policy of presence detection for a fan
118      *
119      * @param[in] rpolicy - policy type to construct
120      * @param[in] fpolicy - fan policy object
121      *
122      * @return - The constructed redundancy policy type for the fan
123      */
124     std::unique_ptr<RedundancyPolicy> getPolicy(const json& rpolicy,
125                                                 const fanPolicy& fpolicy);
126 };
127 
128 /**
129  * Methods of fan presence detection function declarations
130  */
131 namespace method
132 {
133 /**
134  * @brief Fan presence detection method by tach feedback
135  *
136  * @param[in] fanIndex - fan object index to add tach method
137  * @param[in] method - json properties for a tach method
138  *
139  * @return - A presence sensor to detect fan presence by tach feedback
140  */
141 std::unique_ptr<PresenceSensor> getTach(size_t fanIndex, const json& method);
142 
143 /**
144  * @brief Fan presence detection method by gpio
145  *
146  * @param[in] fanIndex - fan object index to add gpio method
147  * @param[in] method - json properties for a gpio method
148  *
149  * @return - A presence sensor to detect fan presence by gpio
150  */
151 std::unique_ptr<PresenceSensor> getGpio(size_t fanIndex, const json& method);
152 
153 } // namespace method
154 
155 /**
156  * Redundancy policies for fan presence detection function declarations
157  */
158 namespace rpolicy
159 {
160 /**
161  * @brief Create an `Anyof` redundancy policy on the created presence
162  * sensors for a fan
163  *
164  * @param[in] fan - fan policy object with the presence sensors for the fan
165  *
166  * @return - An `Anyof` redundancy policy
167  */
168 std::unique_ptr<RedundancyPolicy> getAnyof(const fanPolicy& fan);
169 
170 /**
171  * @brief Create a `Fallback` redundancy policy on the created presence
172  * sensors for a fan
173  *
174  * @param[in] fan - fan policy object with the presence sensors for the fan
175  *
176  * @return - A `Fallback` redundancy policy
177  */
178 std::unique_ptr<RedundancyPolicy> getFallback(const fanPolicy& fan);
179 
180 } // namespace rpolicy
181 
182 } // namespace presence
183 } // namespace fan
184 } // namespace phosphor
185