xref: /openbmc/bmcweb/features/redfish/lib/systems.hpp (revision 94bda602f00b181befa20a08550439b3c1d3b256)
1c5b2abe0SLewanczyk, Dawid /*
2c5b2abe0SLewanczyk, Dawid // Copyright (c) 2018 Intel Corporation
3c5b2abe0SLewanczyk, Dawid //
4c5b2abe0SLewanczyk, Dawid // Licensed under the Apache License, Version 2.0 (the "License");
5c5b2abe0SLewanczyk, Dawid // you may not use this file except in compliance with the License.
6c5b2abe0SLewanczyk, Dawid // You may obtain a copy of the License at
7c5b2abe0SLewanczyk, Dawid //
8c5b2abe0SLewanczyk, Dawid //      http://www.apache.org/licenses/LICENSE-2.0
9c5b2abe0SLewanczyk, Dawid //
10c5b2abe0SLewanczyk, Dawid // Unless required by applicable law or agreed to in writing, software
11c5b2abe0SLewanczyk, Dawid // distributed under the License is distributed on an "AS IS" BASIS,
12c5b2abe0SLewanczyk, Dawid // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13c5b2abe0SLewanczyk, Dawid // See the License for the specific language governing permissions and
14c5b2abe0SLewanczyk, Dawid // limitations under the License.
15c5b2abe0SLewanczyk, Dawid */
16c5b2abe0SLewanczyk, Dawid #pragma once
17c5b2abe0SLewanczyk, Dawid 
18b49ac873SJames Feist #include "health.hpp"
191c8fba97SJames Feist #include "led.hpp"
20f5c9f8bdSJason M. Bills #include "pcie.hpp"
21c5d03ff4SJennifer Lee #include "redfish_util.hpp"
22c5d03ff4SJennifer Lee 
239712f8acSEd Tanous #include <boost/container/flat_map.hpp>
249712f8acSEd Tanous #include <node.hpp>
25cb7e1e7bSAndrew Geissler #include <utils/fw_utils.hpp>
26c5b2abe0SLewanczyk, Dawid #include <utils/json_utils.hpp>
271214b7e7SGunnar Mills 
28abf2add6SEd Tanous #include <variant>
29c5b2abe0SLewanczyk, Dawid 
301abe55efSEd Tanous namespace redfish
311abe55efSEd Tanous {
32c5b2abe0SLewanczyk, Dawid 
339d3ae10eSAlpana Kumari /**
349d3ae10eSAlpana Kumari  * @brief Updates the Functional State of DIMMs
359d3ae10eSAlpana Kumari  *
369d3ae10eSAlpana Kumari  * @param[in] aResp Shared pointer for completing asynchronous calls
379d3ae10eSAlpana Kumari  * @param[in] dimmState Dimm's Functional state, true/false
389d3ae10eSAlpana Kumari  *
399d3ae10eSAlpana Kumari  * @return None.
409d3ae10eSAlpana Kumari  */
41b5a76932SEd Tanous inline void updateDimmProperties(const std::shared_ptr<AsyncResp>& aResp,
429d3ae10eSAlpana Kumari                                  const std::variant<bool>& dimmState)
439d3ae10eSAlpana Kumari {
449d3ae10eSAlpana Kumari     const bool* isDimmFunctional = std::get_if<bool>(&dimmState);
459d3ae10eSAlpana Kumari     if (isDimmFunctional == nullptr)
469d3ae10eSAlpana Kumari     {
479d3ae10eSAlpana Kumari         messages::internalError(aResp->res);
489d3ae10eSAlpana Kumari         return;
499d3ae10eSAlpana Kumari     }
509d3ae10eSAlpana Kumari     BMCWEB_LOG_DEBUG << "Dimm Functional: " << *isDimmFunctional;
519d3ae10eSAlpana Kumari 
529d3ae10eSAlpana Kumari     // Set it as Enabled if at least one DIMM is functional
539d3ae10eSAlpana Kumari     // Update STATE only if previous State was DISABLED and current Dimm is
549d3ae10eSAlpana Kumari     // ENABLED.
559d3ae10eSAlpana Kumari     nlohmann::json& prevMemSummary =
569d3ae10eSAlpana Kumari         aResp->res.jsonValue["MemorySummary"]["Status"]["State"];
579d3ae10eSAlpana Kumari     if (prevMemSummary == "Disabled")
589d3ae10eSAlpana Kumari     {
599d3ae10eSAlpana Kumari         if (*isDimmFunctional == true)
609d3ae10eSAlpana Kumari         {
619d3ae10eSAlpana Kumari             aResp->res.jsonValue["MemorySummary"]["Status"]["State"] =
629d3ae10eSAlpana Kumari                 "Enabled";
639d3ae10eSAlpana Kumari         }
649d3ae10eSAlpana Kumari     }
659d3ae10eSAlpana Kumari }
669d3ae10eSAlpana Kumari 
6757e8c9beSAlpana Kumari /*
6857e8c9beSAlpana Kumari  * @brief Update "ProcessorSummary" "Count" based on Cpu PresenceState
6957e8c9beSAlpana Kumari  *
7057e8c9beSAlpana Kumari  * @param[in] aResp Shared pointer for completing asynchronous calls
7157e8c9beSAlpana Kumari  * @param[in] cpuPresenceState CPU present or not
7257e8c9beSAlpana Kumari  *
7357e8c9beSAlpana Kumari  * @return None.
7457e8c9beSAlpana Kumari  */
75b5a76932SEd Tanous inline void modifyCpuPresenceState(const std::shared_ptr<AsyncResp>& aResp,
7657e8c9beSAlpana Kumari                                    const std::variant<bool>& cpuPresenceState)
7757e8c9beSAlpana Kumari {
7857e8c9beSAlpana Kumari     const bool* isCpuPresent = std::get_if<bool>(&cpuPresenceState);
7957e8c9beSAlpana Kumari 
8057e8c9beSAlpana Kumari     if (isCpuPresent == nullptr)
8157e8c9beSAlpana Kumari     {
8257e8c9beSAlpana Kumari         messages::internalError(aResp->res);
8357e8c9beSAlpana Kumari         return;
8457e8c9beSAlpana Kumari     }
8557e8c9beSAlpana Kumari     BMCWEB_LOG_DEBUG << "Cpu Present: " << *isCpuPresent;
8657e8c9beSAlpana Kumari 
8757e8c9beSAlpana Kumari     if (*isCpuPresent == true)
8857e8c9beSAlpana Kumari     {
89b4b9595aSJames Feist         nlohmann::json& procCount =
90b4b9595aSJames Feist             aResp->res.jsonValue["ProcessorSummary"]["Count"];
91b4b9595aSJames Feist         auto procCountPtr =
92b4b9595aSJames Feist             procCount.get_ptr<nlohmann::json::number_integer_t*>();
93b4b9595aSJames Feist         if (procCountPtr != nullptr)
94b4b9595aSJames Feist         {
95b4b9595aSJames Feist             // shouldn't be possible to be nullptr
96b4b9595aSJames Feist             *procCountPtr += 1;
9757e8c9beSAlpana Kumari         }
98b4b9595aSJames Feist     }
9957e8c9beSAlpana Kumari }
10057e8c9beSAlpana Kumari 
10157e8c9beSAlpana Kumari /*
10257e8c9beSAlpana Kumari  * @brief Update "ProcessorSummary" "Status" "State" based on
10357e8c9beSAlpana Kumari  *        CPU Functional State
10457e8c9beSAlpana Kumari  *
10557e8c9beSAlpana Kumari  * @param[in] aResp Shared pointer for completing asynchronous calls
10657e8c9beSAlpana Kumari  * @param[in] cpuFunctionalState is CPU functional true/false
10757e8c9beSAlpana Kumari  *
10857e8c9beSAlpana Kumari  * @return None.
10957e8c9beSAlpana Kumari  */
11023a21a1cSEd Tanous inline void
111b5a76932SEd Tanous     modifyCpuFunctionalState(const std::shared_ptr<AsyncResp>& aResp,
11257e8c9beSAlpana Kumari                              const std::variant<bool>& cpuFunctionalState)
11357e8c9beSAlpana Kumari {
11457e8c9beSAlpana Kumari     const bool* isCpuFunctional = std::get_if<bool>(&cpuFunctionalState);
11557e8c9beSAlpana Kumari 
11657e8c9beSAlpana Kumari     if (isCpuFunctional == nullptr)
11757e8c9beSAlpana Kumari     {
11857e8c9beSAlpana Kumari         messages::internalError(aResp->res);
11957e8c9beSAlpana Kumari         return;
12057e8c9beSAlpana Kumari     }
12157e8c9beSAlpana Kumari     BMCWEB_LOG_DEBUG << "Cpu Functional: " << *isCpuFunctional;
12257e8c9beSAlpana Kumari 
12357e8c9beSAlpana Kumari     nlohmann::json& prevProcState =
12457e8c9beSAlpana Kumari         aResp->res.jsonValue["ProcessorSummary"]["Status"]["State"];
12557e8c9beSAlpana Kumari 
12657e8c9beSAlpana Kumari     // Set it as Enabled if at least one CPU is functional
12757e8c9beSAlpana Kumari     // Update STATE only if previous State was Non_Functional and current CPU is
12857e8c9beSAlpana Kumari     // Functional.
12957e8c9beSAlpana Kumari     if (prevProcState == "Disabled")
13057e8c9beSAlpana Kumari     {
13157e8c9beSAlpana Kumari         if (*isCpuFunctional == true)
13257e8c9beSAlpana Kumari         {
13357e8c9beSAlpana Kumari             aResp->res.jsonValue["ProcessorSummary"]["Status"]["State"] =
13457e8c9beSAlpana Kumari                 "Enabled";
13557e8c9beSAlpana Kumari         }
13657e8c9beSAlpana Kumari     }
13757e8c9beSAlpana Kumari }
13857e8c9beSAlpana Kumari 
13957e8c9beSAlpana Kumari /*
140c5b2abe0SLewanczyk, Dawid  * @brief Retrieves computer system properties over dbus
141c5b2abe0SLewanczyk, Dawid  *
142c5b2abe0SLewanczyk, Dawid  * @param[in] aResp Shared pointer for completing asynchronous calls
1438f9ee3cdSGunnar Mills  * @param[in] systemHealth  Shared HealthPopulate pointer
144c5b2abe0SLewanczyk, Dawid  *
145c5b2abe0SLewanczyk, Dawid  * @return None.
146c5b2abe0SLewanczyk, Dawid  */
147b5a76932SEd Tanous inline void
148b5a76932SEd Tanous     getComputerSystem(const std::shared_ptr<AsyncResp>& aResp,
149b5a76932SEd Tanous                       const std::shared_ptr<HealthPopulate>& systemHealth)
1501abe55efSEd Tanous {
15155c7b7a2SEd Tanous     BMCWEB_LOG_DEBUG << "Get available system components.";
1529d3ae10eSAlpana Kumari 
15355c7b7a2SEd Tanous     crow::connections::systemBus->async_method_call(
1545bc2dc8eSJames Feist         [aResp, systemHealth](
155c5b2abe0SLewanczyk, Dawid             const boost::system::error_code ec,
156c5b2abe0SLewanczyk, Dawid             const std::vector<std::pair<
1576c34de48SEd Tanous                 std::string,
1581214b7e7SGunnar Mills                 std::vector<std::pair<std::string, std::vector<std::string>>>>>&
1591214b7e7SGunnar Mills                 subtree) {
1601abe55efSEd Tanous             if (ec)
1611abe55efSEd Tanous             {
16255c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "DBUS response error";
163f12894f8SJason M. Bills                 messages::internalError(aResp->res);
164c5b2abe0SLewanczyk, Dawid                 return;
165c5b2abe0SLewanczyk, Dawid             }
166c5b2abe0SLewanczyk, Dawid             // Iterate over all retrieved ObjectPaths.
1676c34de48SEd Tanous             for (const std::pair<std::string,
1686c34de48SEd Tanous                                  std::vector<std::pair<
1691214b7e7SGunnar Mills                                      std::string, std::vector<std::string>>>>&
1701214b7e7SGunnar Mills                      object : subtree)
1711abe55efSEd Tanous             {
172c5b2abe0SLewanczyk, Dawid                 const std::string& path = object.first;
17355c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "Got path: " << path;
1741abe55efSEd Tanous                 const std::vector<
1751214b7e7SGunnar Mills                     std::pair<std::string, std::vector<std::string>>>&
1761214b7e7SGunnar Mills                     connectionNames = object.second;
1771abe55efSEd Tanous                 if (connectionNames.size() < 1)
1781abe55efSEd Tanous                 {
179c5b2abe0SLewanczyk, Dawid                     continue;
180c5b2abe0SLewanczyk, Dawid                 }
181029573d4SEd Tanous 
1825bc2dc8eSJames Feist                 auto memoryHealth = std::make_shared<HealthPopulate>(
1835bc2dc8eSJames Feist                     aResp, aResp->res.jsonValue["MemorySummary"]["Status"]);
1845bc2dc8eSJames Feist 
1855bc2dc8eSJames Feist                 auto cpuHealth = std::make_shared<HealthPopulate>(
1865bc2dc8eSJames Feist                     aResp, aResp->res.jsonValue["ProcessorSummary"]["Status"]);
1875bc2dc8eSJames Feist 
1885bc2dc8eSJames Feist                 systemHealth->children.emplace_back(memoryHealth);
1895bc2dc8eSJames Feist                 systemHealth->children.emplace_back(cpuHealth);
1905bc2dc8eSJames Feist 
1916c34de48SEd Tanous                 // This is not system, so check if it's cpu, dimm, UUID or
1926c34de48SEd Tanous                 // BiosVer
19304a258f4SEd Tanous                 for (const auto& connection : connectionNames)
1941abe55efSEd Tanous                 {
19504a258f4SEd Tanous                     for (const auto& interfaceName : connection.second)
1961abe55efSEd Tanous                     {
19704a258f4SEd Tanous                         if (interfaceName ==
19804a258f4SEd Tanous                             "xyz.openbmc_project.Inventory.Item.Dimm")
1991abe55efSEd Tanous                         {
2001abe55efSEd Tanous                             BMCWEB_LOG_DEBUG
20104a258f4SEd Tanous                                 << "Found Dimm, now get its properties.";
2029d3ae10eSAlpana Kumari 
20355c7b7a2SEd Tanous                             crow::connections::systemBus->async_method_call(
2049d3ae10eSAlpana Kumari                                 [aResp, service{connection.first},
205f23b7296SEd Tanous                                  path](const boost::system::error_code ec2,
2066c34de48SEd Tanous                                        const std::vector<
2071214b7e7SGunnar Mills                                            std::pair<std::string, VariantType>>&
2081214b7e7SGunnar Mills                                            properties) {
209cb13a392SEd Tanous                                     if (ec2)
2101abe55efSEd Tanous                                     {
2111abe55efSEd Tanous                                         BMCWEB_LOG_ERROR
212cb13a392SEd Tanous                                             << "DBUS response error " << ec2;
213f12894f8SJason M. Bills                                         messages::internalError(aResp->res);
214c5b2abe0SLewanczyk, Dawid                                         return;
215c5b2abe0SLewanczyk, Dawid                                     }
2166c34de48SEd Tanous                                     BMCWEB_LOG_DEBUG << "Got "
2176c34de48SEd Tanous                                                      << properties.size()
218c5b2abe0SLewanczyk, Dawid                                                      << " Dimm properties.";
2199d3ae10eSAlpana Kumari 
2209d3ae10eSAlpana Kumari                                     if (properties.size() > 0)
2219d3ae10eSAlpana Kumari                                     {
22204a258f4SEd Tanous                                         for (const std::pair<std::string,
2231214b7e7SGunnar Mills                                                              VariantType>&
2241214b7e7SGunnar Mills                                                  property : properties)
2251abe55efSEd Tanous                                         {
2265fd7ba65SCheng C Yang                                             if (property.first !=
2275fd7ba65SCheng C Yang                                                 "MemorySizeInKB")
2281abe55efSEd Tanous                                             {
2295fd7ba65SCheng C Yang                                                 continue;
2305fd7ba65SCheng C Yang                                             }
2315fd7ba65SCheng C Yang                                             const uint32_t* value =
2328d78b7a9SPatrick Williams                                                 std::get_if<uint32_t>(
2331b6b96c5SEd Tanous                                                     &property.second);
2345fd7ba65SCheng C Yang                                             if (value == nullptr)
2351abe55efSEd Tanous                                             {
2365fd7ba65SCheng C Yang                                                 BMCWEB_LOG_DEBUG
2375fd7ba65SCheng C Yang                                                     << "Find incorrect type of "
2385fd7ba65SCheng C Yang                                                        "MemorySize";
2395fd7ba65SCheng C Yang                                                 continue;
2405fd7ba65SCheng C Yang                                             }
2415fd7ba65SCheng C Yang                                             nlohmann::json& totalMemory =
2425fd7ba65SCheng C Yang                                                 aResp->res
2435fd7ba65SCheng C Yang                                                     .jsonValue["MemorySummar"
2445fd7ba65SCheng C Yang                                                                "y"]
2455fd7ba65SCheng C Yang                                                               ["TotalSystemMe"
2465fd7ba65SCheng C Yang                                                                "moryGiB"];
2475fd7ba65SCheng C Yang                                             uint64_t* preValue =
2485fd7ba65SCheng C Yang                                                 totalMemory
2495fd7ba65SCheng C Yang                                                     .get_ptr<uint64_t*>();
2505fd7ba65SCheng C Yang                                             if (preValue == nullptr)
2515fd7ba65SCheng C Yang                                             {
2525fd7ba65SCheng C Yang                                                 continue;
2535fd7ba65SCheng C Yang                                             }
2545fd7ba65SCheng C Yang                                             aResp->res
2555fd7ba65SCheng C Yang                                                 .jsonValue["MemorySummary"]
2566c34de48SEd Tanous                                                           ["TotalSystemMemoryGi"
2575fd7ba65SCheng C Yang                                                            "B"] =
2585fd7ba65SCheng C Yang                                                 *value / (1024 * 1024) +
2595fd7ba65SCheng C Yang                                                 *preValue;
2605fd7ba65SCheng C Yang                                             aResp->res
2615fd7ba65SCheng C Yang                                                 .jsonValue["MemorySummary"]
2629d3ae10eSAlpana Kumari                                                           ["Status"]["State"] =
2631abe55efSEd Tanous                                                 "Enabled";
264c5b2abe0SLewanczyk, Dawid                                         }
265c5b2abe0SLewanczyk, Dawid                                     }
2669d3ae10eSAlpana Kumari                                     else
2679d3ae10eSAlpana Kumari                                     {
2689d3ae10eSAlpana Kumari                                         auto getDimmProperties =
2699d3ae10eSAlpana Kumari                                             [aResp](
2709d3ae10eSAlpana Kumari                                                 const boost::system::error_code
271cb13a392SEd Tanous                                                     ec3,
2721214b7e7SGunnar Mills                                                 const std::variant<bool>&
2731214b7e7SGunnar Mills                                                     dimmState) {
274cb13a392SEd Tanous                                                 if (ec3)
2759d3ae10eSAlpana Kumari                                                 {
2769d3ae10eSAlpana Kumari                                                     BMCWEB_LOG_ERROR
2779d3ae10eSAlpana Kumari                                                         << "DBUS response "
2789d3ae10eSAlpana Kumari                                                            "error "
279cb13a392SEd Tanous                                                         << ec3;
2809d3ae10eSAlpana Kumari                                                     return;
2819d3ae10eSAlpana Kumari                                                 }
2829d3ae10eSAlpana Kumari                                                 updateDimmProperties(aResp,
2839d3ae10eSAlpana Kumari                                                                      dimmState);
2849d3ae10eSAlpana Kumari                                             };
2859d3ae10eSAlpana Kumari                                         crow::connections::systemBus
2869d3ae10eSAlpana Kumari                                             ->async_method_call(
2879d3ae10eSAlpana Kumari                                                 std::move(getDimmProperties),
2889d3ae10eSAlpana Kumari                                                 service, path,
2899d3ae10eSAlpana Kumari                                                 "org.freedesktop.DBus."
2909d3ae10eSAlpana Kumari                                                 "Properties",
2919d3ae10eSAlpana Kumari                                                 "Get",
2929d3ae10eSAlpana Kumari                                                 "xyz.openbmc_project.State."
2939d3ae10eSAlpana Kumari                                                 "Decorator.OperationalStatus",
2949d3ae10eSAlpana Kumari                                                 "Functional");
2959d3ae10eSAlpana Kumari                                     }
296c5b2abe0SLewanczyk, Dawid                                 },
29704a258f4SEd Tanous                                 connection.first, path,
2986c34de48SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
2996c34de48SEd Tanous                                 "xyz.openbmc_project.Inventory.Item.Dimm");
3005bc2dc8eSJames Feist 
3015bc2dc8eSJames Feist                             memoryHealth->inventory.emplace_back(path);
3021abe55efSEd Tanous                         }
30304a258f4SEd Tanous                         else if (interfaceName ==
30404a258f4SEd Tanous                                  "xyz.openbmc_project.Inventory.Item.Cpu")
3051abe55efSEd Tanous                         {
3061abe55efSEd Tanous                             BMCWEB_LOG_DEBUG
30704a258f4SEd Tanous                                 << "Found Cpu, now get its properties.";
30857e8c9beSAlpana Kumari 
309a0803efaSEd Tanous                             crow::connections::systemBus->async_method_call(
31057e8c9beSAlpana Kumari                                 [aResp, service{connection.first},
311f23b7296SEd Tanous                                  path](const boost::system::error_code ec2,
3126c34de48SEd Tanous                                        const std::vector<
3131214b7e7SGunnar Mills                                            std::pair<std::string, VariantType>>&
3141214b7e7SGunnar Mills                                            properties) {
315cb13a392SEd Tanous                                     if (ec2)
3161abe55efSEd Tanous                                     {
3171abe55efSEd Tanous                                         BMCWEB_LOG_ERROR
318cb13a392SEd Tanous                                             << "DBUS response error " << ec2;
319f12894f8SJason M. Bills                                         messages::internalError(aResp->res);
320c5b2abe0SLewanczyk, Dawid                                         return;
321c5b2abe0SLewanczyk, Dawid                                     }
3226c34de48SEd Tanous                                     BMCWEB_LOG_DEBUG << "Got "
3236c34de48SEd Tanous                                                      << properties.size()
324c5b2abe0SLewanczyk, Dawid                                                      << " Cpu properties.";
32557e8c9beSAlpana Kumari 
32657e8c9beSAlpana Kumari                                     if (properties.size() > 0)
32757e8c9beSAlpana Kumari                                     {
3289cf21522SZhikui Ren                                         const uint64_t* processorId = nullptr;
329029cc1f4SZhikui Ren                                         const std::string* procFamily = nullptr;
330029cc1f4SZhikui Ren                                         nlohmann::json& procSummary =
331029cc1f4SZhikui Ren                                             aResp->res.jsonValue["ProcessorSumm"
33204a258f4SEd Tanous                                                                  "ary"];
33304a258f4SEd Tanous                                         nlohmann::json& procCount =
33404a258f4SEd Tanous                                             procSummary["Count"];
335b4b9595aSJames Feist 
336029cc1f4SZhikui Ren                                         auto procCountPtr = procCount.get_ptr<
337b4b9595aSJames Feist                                             nlohmann::json::
3381214b7e7SGunnar Mills                                                 number_integer_t*>();
339029cc1f4SZhikui Ren                                         if (procCountPtr == nullptr)
340b4b9595aSJames Feist                                         {
341029cc1f4SZhikui Ren                                             messages::internalError(aResp->res);
342029cc1f4SZhikui Ren                                             return;
343029cc1f4SZhikui Ren                                         }
344029cc1f4SZhikui Ren                                         for (const auto& property : properties)
345029cc1f4SZhikui Ren                                         {
346029cc1f4SZhikui Ren 
3479cf21522SZhikui Ren                                             if (property.first == "Id")
348029cc1f4SZhikui Ren                                             {
349029cc1f4SZhikui Ren                                                 processorId =
3509cf21522SZhikui Ren                                                     std::get_if<uint64_t>(
351029cc1f4SZhikui Ren                                                         &property.second);
352029cc1f4SZhikui Ren                                                 if (nullptr != procFamily)
3533174e4dfSEd Tanous                                                 {
354029cc1f4SZhikui Ren                                                     break;
3553174e4dfSEd Tanous                                                 }
356029cc1f4SZhikui Ren                                                 continue;
357029cc1f4SZhikui Ren                                             }
358029cc1f4SZhikui Ren 
3599cf21522SZhikui Ren                                             if (property.first == "Family")
360029cc1f4SZhikui Ren                                             {
361029cc1f4SZhikui Ren                                                 procFamily =
362029cc1f4SZhikui Ren                                                     std::get_if<std::string>(
363029cc1f4SZhikui Ren                                                         &property.second);
364029cc1f4SZhikui Ren                                                 if (nullptr != processorId)
3653174e4dfSEd Tanous                                                 {
366029cc1f4SZhikui Ren                                                     break;
3673174e4dfSEd Tanous                                                 }
368029cc1f4SZhikui Ren                                                 continue;
369029cc1f4SZhikui Ren                                             }
370029cc1f4SZhikui Ren                                         }
371029cc1f4SZhikui Ren 
372029cc1f4SZhikui Ren                                         if (procFamily != nullptr &&
373029cc1f4SZhikui Ren                                             processorId != nullptr)
374029cc1f4SZhikui Ren                                         {
375029cc1f4SZhikui Ren                                             if (procCountPtr != nullptr &&
376029cc1f4SZhikui Ren                                                 *processorId != 0)
377029cc1f4SZhikui Ren                                             {
378b4b9595aSJames Feist                                                 *procCountPtr += 1;
379029cc1f4SZhikui Ren                                                 procSummary["Status"]["State"] =
380c5b2abe0SLewanczyk, Dawid                                                     "Enabled";
381029cc1f4SZhikui Ren 
38257e8c9beSAlpana Kumari                                                 procSummary["Model"] =
383029cc1f4SZhikui Ren                                                     *procFamily;
384c5b2abe0SLewanczyk, Dawid                                             }
385c5b2abe0SLewanczyk, Dawid                                         }
38657e8c9beSAlpana Kumari                                     }
38757e8c9beSAlpana Kumari                                     else
38857e8c9beSAlpana Kumari                                     {
38957e8c9beSAlpana Kumari                                         auto getCpuPresenceState =
39057e8c9beSAlpana Kumari                                             [aResp](
39157e8c9beSAlpana Kumari                                                 const boost::system::error_code
392cb13a392SEd Tanous                                                     ec3,
3931214b7e7SGunnar Mills                                                 const std::variant<bool>&
3941214b7e7SGunnar Mills                                                     cpuPresenceCheck) {
395cb13a392SEd Tanous                                                 if (ec3)
39657e8c9beSAlpana Kumari                                                 {
39757e8c9beSAlpana Kumari                                                     BMCWEB_LOG_ERROR
39857e8c9beSAlpana Kumari                                                         << "DBUS response "
39957e8c9beSAlpana Kumari                                                            "error "
400cb13a392SEd Tanous                                                         << ec3;
40157e8c9beSAlpana Kumari                                                     return;
40257e8c9beSAlpana Kumari                                                 }
40357e8c9beSAlpana Kumari                                                 modifyCpuPresenceState(
40457e8c9beSAlpana Kumari                                                     aResp, cpuPresenceCheck);
40557e8c9beSAlpana Kumari                                             };
40657e8c9beSAlpana Kumari 
40757e8c9beSAlpana Kumari                                         auto getCpuFunctionalState =
40857e8c9beSAlpana Kumari                                             [aResp](
40957e8c9beSAlpana Kumari                                                 const boost::system::error_code
410cb13a392SEd Tanous                                                     ec3,
4111214b7e7SGunnar Mills                                                 const std::variant<bool>&
4121214b7e7SGunnar Mills                                                     cpuFunctionalCheck) {
413cb13a392SEd Tanous                                                 if (ec3)
41457e8c9beSAlpana Kumari                                                 {
41557e8c9beSAlpana Kumari                                                     BMCWEB_LOG_ERROR
41657e8c9beSAlpana Kumari                                                         << "DBUS response "
41757e8c9beSAlpana Kumari                                                            "error "
418cb13a392SEd Tanous                                                         << ec3;
41957e8c9beSAlpana Kumari                                                     return;
42057e8c9beSAlpana Kumari                                                 }
42157e8c9beSAlpana Kumari                                                 modifyCpuFunctionalState(
42257e8c9beSAlpana Kumari                                                     aResp, cpuFunctionalCheck);
42357e8c9beSAlpana Kumari                                             };
42457e8c9beSAlpana Kumari                                         // Get the Presence of CPU
42557e8c9beSAlpana Kumari                                         crow::connections::systemBus
42657e8c9beSAlpana Kumari                                             ->async_method_call(
42757e8c9beSAlpana Kumari                                                 std::move(getCpuPresenceState),
42857e8c9beSAlpana Kumari                                                 service, path,
42957e8c9beSAlpana Kumari                                                 "org.freedesktop.DBus."
43057e8c9beSAlpana Kumari                                                 "Properties",
43157e8c9beSAlpana Kumari                                                 "Get",
43257e8c9beSAlpana Kumari                                                 "xyz.openbmc_project.Inventory."
43357e8c9beSAlpana Kumari                                                 "Item",
43457e8c9beSAlpana Kumari                                                 "Present");
43557e8c9beSAlpana Kumari 
43657e8c9beSAlpana Kumari                                         // Get the Functional State
43757e8c9beSAlpana Kumari                                         crow::connections::systemBus
43857e8c9beSAlpana Kumari                                             ->async_method_call(
43957e8c9beSAlpana Kumari                                                 std::move(
44057e8c9beSAlpana Kumari                                                     getCpuFunctionalState),
44157e8c9beSAlpana Kumari                                                 service, path,
44257e8c9beSAlpana Kumari                                                 "org.freedesktop.DBus."
44357e8c9beSAlpana Kumari                                                 "Properties",
44457e8c9beSAlpana Kumari                                                 "Get",
44557e8c9beSAlpana Kumari                                                 "xyz.openbmc_project.State."
44657e8c9beSAlpana Kumari                                                 "Decorator."
44757e8c9beSAlpana Kumari                                                 "OperationalStatus",
44857e8c9beSAlpana Kumari                                                 "Functional");
44957e8c9beSAlpana Kumari 
45057e8c9beSAlpana Kumari                                         // Get the MODEL from
45157e8c9beSAlpana Kumari                                         // xyz.openbmc_project.Inventory.Decorator.Asset
45257e8c9beSAlpana Kumari                                         // support it later as Model  is Empty
45357e8c9beSAlpana Kumari                                         // currently.
45457e8c9beSAlpana Kumari                                     }
455c5b2abe0SLewanczyk, Dawid                                 },
45604a258f4SEd Tanous                                 connection.first, path,
4576c34de48SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
4586c34de48SEd Tanous                                 "xyz.openbmc_project.Inventory.Item.Cpu");
4595bc2dc8eSJames Feist 
4605bc2dc8eSJames Feist                             cpuHealth->inventory.emplace_back(path);
4611abe55efSEd Tanous                         }
46204a258f4SEd Tanous                         else if (interfaceName ==
46304a258f4SEd Tanous                                  "xyz.openbmc_project.Common.UUID")
4641abe55efSEd Tanous                         {
4651abe55efSEd Tanous                             BMCWEB_LOG_DEBUG
46604a258f4SEd Tanous                                 << "Found UUID, now get its properties.";
46755c7b7a2SEd Tanous                             crow::connections::systemBus->async_method_call(
4681214b7e7SGunnar Mills                                 [aResp](
469cb13a392SEd Tanous                                     const boost::system::error_code ec3,
4706c34de48SEd Tanous                                     const std::vector<
4711214b7e7SGunnar Mills                                         std::pair<std::string, VariantType>>&
4721214b7e7SGunnar Mills                                         properties) {
473cb13a392SEd Tanous                                     if (ec3)
4741abe55efSEd Tanous                                     {
4751abe55efSEd Tanous                                         BMCWEB_LOG_DEBUG
476cb13a392SEd Tanous                                             << "DBUS response error " << ec3;
477f12894f8SJason M. Bills                                         messages::internalError(aResp->res);
478c5b2abe0SLewanczyk, Dawid                                         return;
479c5b2abe0SLewanczyk, Dawid                                     }
4806c34de48SEd Tanous                                     BMCWEB_LOG_DEBUG << "Got "
4816c34de48SEd Tanous                                                      << properties.size()
482c5b2abe0SLewanczyk, Dawid                                                      << " UUID properties.";
4831abe55efSEd Tanous                                     for (const std::pair<std::string,
4841214b7e7SGunnar Mills                                                          VariantType>&
4851214b7e7SGunnar Mills                                              property : properties)
4861abe55efSEd Tanous                                     {
48704a258f4SEd Tanous                                         if (property.first == "UUID")
4881abe55efSEd Tanous                                         {
489c5b2abe0SLewanczyk, Dawid                                             const std::string* value =
4908d78b7a9SPatrick Williams                                                 std::get_if<std::string>(
4911b6b96c5SEd Tanous                                                     &property.second);
49204a258f4SEd Tanous 
4931abe55efSEd Tanous                                             if (value != nullptr)
4941abe55efSEd Tanous                                             {
495029573d4SEd Tanous                                                 std::string valueStr = *value;
49604a258f4SEd Tanous                                                 if (valueStr.size() == 32)
4971abe55efSEd Tanous                                                 {
498029573d4SEd Tanous                                                     valueStr.insert(8, 1, '-');
499029573d4SEd Tanous                                                     valueStr.insert(13, 1, '-');
500029573d4SEd Tanous                                                     valueStr.insert(18, 1, '-');
501029573d4SEd Tanous                                                     valueStr.insert(23, 1, '-');
50204a258f4SEd Tanous                                                 }
503029573d4SEd Tanous                                                 BMCWEB_LOG_DEBUG << "UUID = "
50404a258f4SEd Tanous                                                                  << valueStr;
505029573d4SEd Tanous                                                 aResp->res.jsonValue["UUID"] =
50604a258f4SEd Tanous                                                     valueStr;
507c5b2abe0SLewanczyk, Dawid                                             }
508c5b2abe0SLewanczyk, Dawid                                         }
509c5b2abe0SLewanczyk, Dawid                                     }
510c5b2abe0SLewanczyk, Dawid                                 },
51104a258f4SEd Tanous                                 connection.first, path,
5126c34de48SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
5131abe55efSEd Tanous                                 "xyz.openbmc_project.Common.UUID");
514c5b2abe0SLewanczyk, Dawid                         }
515029573d4SEd Tanous                         else if (interfaceName ==
516029573d4SEd Tanous                                  "xyz.openbmc_project.Inventory.Item.System")
5171abe55efSEd Tanous                         {
518029573d4SEd Tanous                             crow::connections::systemBus->async_method_call(
5191214b7e7SGunnar Mills                                 [aResp](
520cb13a392SEd Tanous                                     const boost::system::error_code ec2,
521029573d4SEd Tanous                                     const std::vector<
5221214b7e7SGunnar Mills                                         std::pair<std::string, VariantType>>&
5231214b7e7SGunnar Mills                                         propertiesList) {
524cb13a392SEd Tanous                                     if (ec2)
525029573d4SEd Tanous                                     {
526e4a4b9a9SJames Feist                                         // doesn't have to include this
527e4a4b9a9SJames Feist                                         // interface
528029573d4SEd Tanous                                         return;
529029573d4SEd Tanous                                     }
530698654b6SGunnar Mills                                     BMCWEB_LOG_DEBUG
531698654b6SGunnar Mills                                         << "Got " << propertiesList.size()
532029573d4SEd Tanous                                         << " properties for system";
533029573d4SEd Tanous                                     for (const std::pair<std::string,
5341214b7e7SGunnar Mills                                                          VariantType>&
5351214b7e7SGunnar Mills                                              property : propertiesList)
536029573d4SEd Tanous                                     {
537fc5afcf9Sbeccabroek                                         const std::string& propertyName =
538fc5afcf9Sbeccabroek                                             property.first;
539fc5afcf9Sbeccabroek                                         if ((propertyName == "PartNumber") ||
540fc5afcf9Sbeccabroek                                             (propertyName == "SerialNumber") ||
541fc5afcf9Sbeccabroek                                             (propertyName == "Manufacturer") ||
5425235d964SSunnySrivastava1984                                             (propertyName == "Model") ||
5435235d964SSunnySrivastava1984                                             (propertyName == "SubModel"))
544fc5afcf9Sbeccabroek                                         {
545029573d4SEd Tanous                                             const std::string* value =
546fc5afcf9Sbeccabroek                                                 std::get_if<std::string>(
547029573d4SEd Tanous                                                     &property.second);
548029573d4SEd Tanous                                             if (value != nullptr)
549029573d4SEd Tanous                                             {
550029573d4SEd Tanous                                                 aResp->res
551fc5afcf9Sbeccabroek                                                     .jsonValue[propertyName] =
552029573d4SEd Tanous                                                     *value;
553029573d4SEd Tanous                                             }
554029573d4SEd Tanous                                         }
555fc5afcf9Sbeccabroek                                     }
556c1e236a6SGunnar Mills 
557cb7e1e7bSAndrew Geissler                                     // Grab the bios version
558f97ddba7SGunnar Mills                                     fw_util::populateFirmwareInformation(
559cb7e1e7bSAndrew Geissler                                         aResp, fw_util::biosPurpose,
56072d566d9SGunnar Mills                                         "BiosVersion", false);
561029573d4SEd Tanous                                 },
562029573d4SEd Tanous                                 connection.first, path,
563029573d4SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
564029573d4SEd Tanous                                 "xyz.openbmc_project.Inventory.Decorator."
565029573d4SEd Tanous                                 "Asset");
566e4a4b9a9SJames Feist 
567e4a4b9a9SJames Feist                             crow::connections::systemBus->async_method_call(
568e4a4b9a9SJames Feist                                 [aResp](
569cb13a392SEd Tanous                                     const boost::system::error_code ec2,
570e4a4b9a9SJames Feist                                     const std::variant<std::string>& property) {
571cb13a392SEd Tanous                                     if (ec2)
572e4a4b9a9SJames Feist                                     {
573e4a4b9a9SJames Feist                                         // doesn't have to include this
574e4a4b9a9SJames Feist                                         // interface
575e4a4b9a9SJames Feist                                         return;
576e4a4b9a9SJames Feist                                     }
577e4a4b9a9SJames Feist 
578e4a4b9a9SJames Feist                                     const std::string* value =
579e4a4b9a9SJames Feist                                         std::get_if<std::string>(&property);
580e4a4b9a9SJames Feist                                     if (value != nullptr)
581e4a4b9a9SJames Feist                                     {
582e4a4b9a9SJames Feist                                         aResp->res.jsonValue["AssetTag"] =
583e4a4b9a9SJames Feist                                             *value;
584e4a4b9a9SJames Feist                                     }
585e4a4b9a9SJames Feist                                 },
586e4a4b9a9SJames Feist                                 connection.first, path,
587e4a4b9a9SJames Feist                                 "org.freedesktop.DBus.Properties", "Get",
588e4a4b9a9SJames Feist                                 "xyz.openbmc_project.Inventory.Decorator."
589e4a4b9a9SJames Feist                                 "AssetTag",
590e4a4b9a9SJames Feist                                 "AssetTag");
591029573d4SEd Tanous                         }
592029573d4SEd Tanous                     }
593029573d4SEd Tanous                 }
594c5b2abe0SLewanczyk, Dawid             }
595c5b2abe0SLewanczyk, Dawid         },
596c5b2abe0SLewanczyk, Dawid         "xyz.openbmc_project.ObjectMapper",
597c5b2abe0SLewanczyk, Dawid         "/xyz/openbmc_project/object_mapper",
598c5b2abe0SLewanczyk, Dawid         "xyz.openbmc_project.ObjectMapper", "GetSubTree",
5996617338dSEd Tanous         "/xyz/openbmc_project/inventory", int32_t(0),
6006617338dSEd Tanous         std::array<const char*, 5>{
6016617338dSEd Tanous             "xyz.openbmc_project.Inventory.Decorator.Asset",
6026617338dSEd Tanous             "xyz.openbmc_project.Inventory.Item.Cpu",
6036617338dSEd Tanous             "xyz.openbmc_project.Inventory.Item.Dimm",
6046617338dSEd Tanous             "xyz.openbmc_project.Inventory.Item.System",
6056617338dSEd Tanous             "xyz.openbmc_project.Common.UUID",
6066617338dSEd Tanous         });
607c5b2abe0SLewanczyk, Dawid }
608c5b2abe0SLewanczyk, Dawid 
609c5b2abe0SLewanczyk, Dawid /**
610c5b2abe0SLewanczyk, Dawid  * @brief Retrieves host state properties over dbus
611c5b2abe0SLewanczyk, Dawid  *
612c5b2abe0SLewanczyk, Dawid  * @param[in] aResp     Shared pointer for completing asynchronous calls.
613c5b2abe0SLewanczyk, Dawid  *
614c5b2abe0SLewanczyk, Dawid  * @return None.
615c5b2abe0SLewanczyk, Dawid  */
616b5a76932SEd Tanous inline void getHostState(const std::shared_ptr<AsyncResp>& aResp)
6171abe55efSEd Tanous {
61855c7b7a2SEd Tanous     BMCWEB_LOG_DEBUG << "Get host information.";
61955c7b7a2SEd Tanous     crow::connections::systemBus->async_method_call(
620c5d03ff4SJennifer Lee         [aResp](const boost::system::error_code ec,
621abf2add6SEd Tanous                 const std::variant<std::string>& hostState) {
6221abe55efSEd Tanous             if (ec)
6231abe55efSEd Tanous             {
62455c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
625f12894f8SJason M. Bills                 messages::internalError(aResp->res);
626c5b2abe0SLewanczyk, Dawid                 return;
627c5b2abe0SLewanczyk, Dawid             }
6286617338dSEd Tanous 
629abf2add6SEd Tanous             const std::string* s = std::get_if<std::string>(&hostState);
63055c7b7a2SEd Tanous             BMCWEB_LOG_DEBUG << "Host state: " << *s;
6316617338dSEd Tanous             if (s != nullptr)
6321abe55efSEd Tanous             {
633c5b2abe0SLewanczyk, Dawid                 // Verify Host State
63494732661SAndrew Geissler                 if (*s == "xyz.openbmc_project.State.Host.HostState.Running")
6351abe55efSEd Tanous                 {
63655c7b7a2SEd Tanous                     aResp->res.jsonValue["PowerState"] = "On";
6376617338dSEd Tanous                     aResp->res.jsonValue["Status"]["State"] = "Enabled";
6381abe55efSEd Tanous                 }
63983935af9SAndrew Geissler                 else if (*s == "xyz.openbmc_project.State.Host.HostState."
6408c888608SGunnar Mills                                "Quiesced")
6418c888608SGunnar Mills                 {
6428c888608SGunnar Mills                     aResp->res.jsonValue["PowerState"] = "On";
6438c888608SGunnar Mills                     aResp->res.jsonValue["Status"]["State"] = "Quiesced";
6448c888608SGunnar Mills                 }
6458c888608SGunnar Mills                 else if (*s == "xyz.openbmc_project.State.Host.HostState."
64683935af9SAndrew Geissler                                "DiagnosticMode")
64783935af9SAndrew Geissler                 {
64883935af9SAndrew Geissler                     aResp->res.jsonValue["PowerState"] = "On";
64983935af9SAndrew Geissler                     aResp->res.jsonValue["Status"]["State"] = "InTest";
65083935af9SAndrew Geissler                 }
6511abe55efSEd Tanous                 else
6521abe55efSEd Tanous                 {
65355c7b7a2SEd Tanous                     aResp->res.jsonValue["PowerState"] = "Off";
6546617338dSEd Tanous                     aResp->res.jsonValue["Status"]["State"] = "Disabled";
655c5b2abe0SLewanczyk, Dawid                 }
656c5b2abe0SLewanczyk, Dawid             }
657c5b2abe0SLewanczyk, Dawid         },
6586c34de48SEd Tanous         "xyz.openbmc_project.State.Host", "/xyz/openbmc_project/state/host0",
6596617338dSEd Tanous         "org.freedesktop.DBus.Properties", "Get",
6606617338dSEd Tanous         "xyz.openbmc_project.State.Host", "CurrentHostState");
661c5b2abe0SLewanczyk, Dawid }
662c5b2abe0SLewanczyk, Dawid 
663c5b2abe0SLewanczyk, Dawid /**
664786d0f60SGunnar Mills  * @brief Translates boot source DBUS property value to redfish.
665491d8ee7SSantosh Puranik  *
666491d8ee7SSantosh Puranik  * @param[in] dbusSource    The boot source in DBUS speak.
667491d8ee7SSantosh Puranik  *
668491d8ee7SSantosh Puranik  * @return Returns as a string, the boot source in Redfish terms. If translation
669491d8ee7SSantosh Puranik  * cannot be done, returns an empty string.
670491d8ee7SSantosh Puranik  */
67123a21a1cSEd Tanous inline std::string dbusToRfBootSource(const std::string& dbusSource)
672491d8ee7SSantosh Puranik {
673491d8ee7SSantosh Puranik     if (dbusSource == "xyz.openbmc_project.Control.Boot.Source.Sources.Default")
674491d8ee7SSantosh Puranik     {
675491d8ee7SSantosh Puranik         return "None";
676491d8ee7SSantosh Puranik     }
6773174e4dfSEd Tanous     if (dbusSource == "xyz.openbmc_project.Control.Boot.Source.Sources.Disk")
678491d8ee7SSantosh Puranik     {
679491d8ee7SSantosh Puranik         return "Hdd";
680491d8ee7SSantosh Puranik     }
6813174e4dfSEd Tanous     if (dbusSource ==
682a71dc0b7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Source.Sources.ExternalMedia")
683491d8ee7SSantosh Puranik     {
684491d8ee7SSantosh Puranik         return "Cd";
685491d8ee7SSantosh Puranik     }
6863174e4dfSEd Tanous     if (dbusSource == "xyz.openbmc_project.Control.Boot.Source.Sources.Network")
687491d8ee7SSantosh Puranik     {
688491d8ee7SSantosh Puranik         return "Pxe";
689491d8ee7SSantosh Puranik     }
6903174e4dfSEd Tanous     if (dbusSource ==
691944ffaf9SJohnathan Mantey         "xyz.openbmc_project.Control.Boot.Source.Sources.RemovableMedia")
6929f16b2c1SJennifer Lee     {
6939f16b2c1SJennifer Lee         return "Usb";
6949f16b2c1SJennifer Lee     }
695491d8ee7SSantosh Puranik     return "";
696491d8ee7SSantosh Puranik }
697491d8ee7SSantosh Puranik 
698491d8ee7SSantosh Puranik /**
699786d0f60SGunnar Mills  * @brief Translates boot mode DBUS property value to redfish.
700491d8ee7SSantosh Puranik  *
701491d8ee7SSantosh Puranik  * @param[in] dbusMode    The boot mode in DBUS speak.
702491d8ee7SSantosh Puranik  *
703491d8ee7SSantosh Puranik  * @return Returns as a string, the boot mode in Redfish terms. If translation
704491d8ee7SSantosh Puranik  * cannot be done, returns an empty string.
705491d8ee7SSantosh Puranik  */
70623a21a1cSEd Tanous inline std::string dbusToRfBootMode(const std::string& dbusMode)
707491d8ee7SSantosh Puranik {
708491d8ee7SSantosh Puranik     if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular")
709491d8ee7SSantosh Puranik     {
710491d8ee7SSantosh Puranik         return "None";
711491d8ee7SSantosh Puranik     }
7123174e4dfSEd Tanous     if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Safe")
713491d8ee7SSantosh Puranik     {
714491d8ee7SSantosh Puranik         return "Diags";
715491d8ee7SSantosh Puranik     }
7163174e4dfSEd Tanous     if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Setup")
717491d8ee7SSantosh Puranik     {
718491d8ee7SSantosh Puranik         return "BiosSetup";
719491d8ee7SSantosh Puranik     }
720491d8ee7SSantosh Puranik     return "";
721491d8ee7SSantosh Puranik }
722491d8ee7SSantosh Puranik 
723491d8ee7SSantosh Puranik /**
724786d0f60SGunnar Mills  * @brief Translates boot source from Redfish to the DBus boot paths.
725491d8ee7SSantosh Puranik  *
726491d8ee7SSantosh Puranik  * @param[in] rfSource    The boot source in Redfish.
727944ffaf9SJohnathan Mantey  * @param[out] bootSource The DBus source
728944ffaf9SJohnathan Mantey  * @param[out] bootMode   the DBus boot mode
729491d8ee7SSantosh Puranik  *
730944ffaf9SJohnathan Mantey  * @return Integer error code.
731491d8ee7SSantosh Puranik  */
732b5a76932SEd Tanous inline int assignBootParameters(const std::shared_ptr<AsyncResp>& aResp,
733944ffaf9SJohnathan Mantey                                 const std::string& rfSource,
734944ffaf9SJohnathan Mantey                                 std::string& bootSource, std::string& bootMode)
735491d8ee7SSantosh Puranik {
736944ffaf9SJohnathan Mantey     // The caller has initialized the bootSource and bootMode to:
737944ffaf9SJohnathan Mantey     // bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular";
738944ffaf9SJohnathan Mantey     // bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Default";
739944ffaf9SJohnathan Mantey     // Only modify the bootSource/bootMode variable needed to achieve the
740944ffaf9SJohnathan Mantey     // desired boot action.
741944ffaf9SJohnathan Mantey 
742491d8ee7SSantosh Puranik     if (rfSource == "None")
743491d8ee7SSantosh Puranik     {
744944ffaf9SJohnathan Mantey         return 0;
745491d8ee7SSantosh Puranik     }
7463174e4dfSEd Tanous     if (rfSource == "Pxe")
747491d8ee7SSantosh Puranik     {
748944ffaf9SJohnathan Mantey         bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Network";
749944ffaf9SJohnathan Mantey     }
750944ffaf9SJohnathan Mantey     else if (rfSource == "Hdd")
751944ffaf9SJohnathan Mantey     {
752944ffaf9SJohnathan Mantey         bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Disk";
753944ffaf9SJohnathan Mantey     }
754944ffaf9SJohnathan Mantey     else if (rfSource == "Diags")
755944ffaf9SJohnathan Mantey     {
756944ffaf9SJohnathan Mantey         bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Safe";
757944ffaf9SJohnathan Mantey     }
758944ffaf9SJohnathan Mantey     else if (rfSource == "Cd")
759944ffaf9SJohnathan Mantey     {
760944ffaf9SJohnathan Mantey         bootSource =
761944ffaf9SJohnathan Mantey             "xyz.openbmc_project.Control.Boot.Source.Sources.ExternalMedia";
762944ffaf9SJohnathan Mantey     }
763944ffaf9SJohnathan Mantey     else if (rfSource == "BiosSetup")
764944ffaf9SJohnathan Mantey     {
765944ffaf9SJohnathan Mantey         bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Setup";
766491d8ee7SSantosh Puranik     }
7679f16b2c1SJennifer Lee     else if (rfSource == "Usb")
7689f16b2c1SJennifer Lee     {
769944ffaf9SJohnathan Mantey         bootSource =
770944ffaf9SJohnathan Mantey             "xyz.openbmc_project.Control.Boot.Source.Sources.RemovableMedia";
7719f16b2c1SJennifer Lee     }
772491d8ee7SSantosh Puranik     else
773491d8ee7SSantosh Puranik     {
774944ffaf9SJohnathan Mantey         BMCWEB_LOG_DEBUG << "Invalid property value for "
775944ffaf9SJohnathan Mantey                             "BootSourceOverrideTarget: "
776944ffaf9SJohnathan Mantey                          << bootSource;
777944ffaf9SJohnathan Mantey         messages::propertyValueNotInList(aResp->res, rfSource,
778944ffaf9SJohnathan Mantey                                          "BootSourceTargetOverride");
779944ffaf9SJohnathan Mantey         return -1;
780491d8ee7SSantosh Puranik     }
781944ffaf9SJohnathan Mantey     return 0;
782491d8ee7SSantosh Puranik }
783491d8ee7SSantosh Puranik 
784491d8ee7SSantosh Puranik /**
785491d8ee7SSantosh Puranik  * @brief Retrieves boot mode over DBUS and fills out the response
786491d8ee7SSantosh Puranik  *
787491d8ee7SSantosh Puranik  * @param[in] aResp         Shared pointer for generating response message.
788491d8ee7SSantosh Puranik  * @param[in] bootDbusObj   The dbus object to query for boot properties.
789491d8ee7SSantosh Puranik  *
790491d8ee7SSantosh Puranik  * @return None.
791491d8ee7SSantosh Puranik  */
792b5a76932SEd Tanous inline void getBootMode(const std::shared_ptr<AsyncResp>& aResp,
793b5a76932SEd Tanous                         const std::string& bootDbusObj)
794491d8ee7SSantosh Puranik {
795491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
796491d8ee7SSantosh Puranik         [aResp](const boost::system::error_code ec,
797491d8ee7SSantosh Puranik                 const std::variant<std::string>& bootMode) {
798491d8ee7SSantosh Puranik             if (ec)
799491d8ee7SSantosh Puranik             {
800491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
801491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
802491d8ee7SSantosh Puranik                 return;
803491d8ee7SSantosh Puranik             }
804491d8ee7SSantosh Puranik 
805491d8ee7SSantosh Puranik             const std::string* bootModeStr =
806491d8ee7SSantosh Puranik                 std::get_if<std::string>(&bootMode);
807491d8ee7SSantosh Puranik 
808491d8ee7SSantosh Puranik             if (!bootModeStr)
809491d8ee7SSantosh Puranik             {
810491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
811491d8ee7SSantosh Puranik                 return;
812491d8ee7SSantosh Puranik             }
813491d8ee7SSantosh Puranik 
814491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot mode: " << *bootModeStr;
815491d8ee7SSantosh Puranik 
816491d8ee7SSantosh Puranik             // TODO (Santosh): Do we need to support override mode?
817491d8ee7SSantosh Puranik             aResp->res.jsonValue["Boot"]["BootSourceOverrideMode"] = "Legacy";
818491d8ee7SSantosh Puranik             aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget@Redfish."
819491d8ee7SSantosh Puranik                                          "AllowableValues"] = {
820944ffaf9SJohnathan Mantey                 "None", "Pxe", "Hdd", "Cd", "Diags", "BiosSetup", "Usb"};
821491d8ee7SSantosh Puranik 
822491d8ee7SSantosh Puranik             if (*bootModeStr !=
823491d8ee7SSantosh Puranik                 "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular")
824491d8ee7SSantosh Puranik             {
825491d8ee7SSantosh Puranik                 auto rfMode = dbusToRfBootMode(*bootModeStr);
826491d8ee7SSantosh Puranik                 if (!rfMode.empty())
827491d8ee7SSantosh Puranik                 {
828491d8ee7SSantosh Puranik                     aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] =
829491d8ee7SSantosh Puranik                         rfMode;
830491d8ee7SSantosh Puranik                 }
831491d8ee7SSantosh Puranik             }
832491d8ee7SSantosh Puranik 
833491d8ee7SSantosh Puranik             // If the BootSourceOverrideTarget is still "None" at the end,
834491d8ee7SSantosh Puranik             // reset the BootSourceOverrideEnabled to indicate that
835491d8ee7SSantosh Puranik             // overrides are disabled
836491d8ee7SSantosh Puranik             if (aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] ==
837491d8ee7SSantosh Puranik                 "None")
838491d8ee7SSantosh Puranik             {
839491d8ee7SSantosh Puranik                 aResp->res.jsonValue["Boot"]["BootSourceOverrideEnabled"] =
840491d8ee7SSantosh Puranik                     "Disabled";
841491d8ee7SSantosh Puranik             }
842491d8ee7SSantosh Puranik         },
843491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootDbusObj,
844491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
845491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Mode", "BootMode");
846491d8ee7SSantosh Puranik }
847491d8ee7SSantosh Puranik 
848491d8ee7SSantosh Puranik /**
849491d8ee7SSantosh Puranik  * @brief Retrieves boot source over DBUS
850491d8ee7SSantosh Puranik  *
851491d8ee7SSantosh Puranik  * @param[in] aResp         Shared pointer for generating response message.
852491d8ee7SSantosh Puranik  * @param[in] oneTimeEnable Boolean to indicate boot properties are one-time.
853491d8ee7SSantosh Puranik  *
854491d8ee7SSantosh Puranik  * @return None.
855491d8ee7SSantosh Puranik  */
856f23b7296SEd Tanous inline void getBootSource(const std::shared_ptr<AsyncResp>& aResp,
857f23b7296SEd Tanous                           bool oneTimeEnabled)
858491d8ee7SSantosh Puranik {
859491d8ee7SSantosh Puranik     std::string bootDbusObj =
860491d8ee7SSantosh Puranik         oneTimeEnabled ? "/xyz/openbmc_project/control/host0/boot/one_time"
861491d8ee7SSantosh Puranik                        : "/xyz/openbmc_project/control/host0/boot";
862491d8ee7SSantosh Puranik 
863491d8ee7SSantosh Puranik     BMCWEB_LOG_DEBUG << "Is one time: " << oneTimeEnabled;
864491d8ee7SSantosh Puranik     aResp->res.jsonValue["Boot"]["BootSourceOverrideEnabled"] =
865491d8ee7SSantosh Puranik         (oneTimeEnabled) ? "Once" : "Continuous";
866491d8ee7SSantosh Puranik 
867491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
868491d8ee7SSantosh Puranik         [aResp, bootDbusObj](const boost::system::error_code ec,
869491d8ee7SSantosh Puranik                              const std::variant<std::string>& bootSource) {
870491d8ee7SSantosh Puranik             if (ec)
871491d8ee7SSantosh Puranik             {
872491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
873491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
874491d8ee7SSantosh Puranik                 return;
875491d8ee7SSantosh Puranik             }
876491d8ee7SSantosh Puranik 
877491d8ee7SSantosh Puranik             const std::string* bootSourceStr =
878491d8ee7SSantosh Puranik                 std::get_if<std::string>(&bootSource);
879491d8ee7SSantosh Puranik 
880491d8ee7SSantosh Puranik             if (!bootSourceStr)
881491d8ee7SSantosh Puranik             {
882491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
883491d8ee7SSantosh Puranik                 return;
884491d8ee7SSantosh Puranik             }
885491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot source: " << *bootSourceStr;
886491d8ee7SSantosh Puranik 
887491d8ee7SSantosh Puranik             auto rfSource = dbusToRfBootSource(*bootSourceStr);
888491d8ee7SSantosh Puranik             if (!rfSource.empty())
889491d8ee7SSantosh Puranik             {
890491d8ee7SSantosh Puranik                 aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] =
891491d8ee7SSantosh Puranik                     rfSource;
892491d8ee7SSantosh Puranik             }
893491d8ee7SSantosh Puranik         },
894491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootDbusObj,
895491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
896491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Source", "BootSource");
897f23b7296SEd Tanous     getBootMode(aResp, bootDbusObj);
898491d8ee7SSantosh Puranik }
899491d8ee7SSantosh Puranik 
900491d8ee7SSantosh Puranik /**
901491d8ee7SSantosh Puranik  * @brief Retrieves "One time" enabled setting over DBUS and calls function to
902491d8ee7SSantosh Puranik  * get boot source and boot mode.
903491d8ee7SSantosh Puranik  *
904491d8ee7SSantosh Puranik  * @param[in] aResp     Shared pointer for generating response message.
905491d8ee7SSantosh Puranik  *
906491d8ee7SSantosh Puranik  * @return None.
907491d8ee7SSantosh Puranik  */
908b5a76932SEd Tanous inline void getBootProperties(const std::shared_ptr<AsyncResp>& aResp)
909491d8ee7SSantosh Puranik {
910491d8ee7SSantosh Puranik     BMCWEB_LOG_DEBUG << "Get boot information.";
911491d8ee7SSantosh Puranik 
912491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
913c5d03ff4SJennifer Lee         [aResp](const boost::system::error_code ec,
91419bd78d9SPatrick Williams                 const std::variant<bool>& oneTime) {
915491d8ee7SSantosh Puranik             if (ec)
916491d8ee7SSantosh Puranik             {
917491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
9182a833c77SJames Feist                 // not an error, don't have to have the interface
919491d8ee7SSantosh Puranik                 return;
920491d8ee7SSantosh Puranik             }
921491d8ee7SSantosh Puranik 
922491d8ee7SSantosh Puranik             const bool* oneTimePtr = std::get_if<bool>(&oneTime);
923491d8ee7SSantosh Puranik 
924491d8ee7SSantosh Puranik             if (!oneTimePtr)
925491d8ee7SSantosh Puranik             {
926491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
927491d8ee7SSantosh Puranik                 return;
928491d8ee7SSantosh Puranik             }
929491d8ee7SSantosh Puranik             getBootSource(aResp, *oneTimePtr);
930491d8ee7SSantosh Puranik         },
931491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings",
932491d8ee7SSantosh Puranik         "/xyz/openbmc_project/control/host0/boot/one_time",
933491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
934491d8ee7SSantosh Puranik         "xyz.openbmc_project.Object.Enable", "Enabled");
935491d8ee7SSantosh Puranik }
936491d8ee7SSantosh Puranik 
937491d8ee7SSantosh Puranik /**
938c0557e1aSGunnar Mills  * @brief Retrieves the Last Reset Time
939c0557e1aSGunnar Mills  *
940c0557e1aSGunnar Mills  * "Reset" is an overloaded term in Redfish, "Reset" includes power on
941c0557e1aSGunnar Mills  * and power off. Even though this is the "system" Redfish object look at the
942c0557e1aSGunnar Mills  * chassis D-Bus interface for the LastStateChangeTime since this has the
943c0557e1aSGunnar Mills  * last power operation time.
944c0557e1aSGunnar Mills  *
945c0557e1aSGunnar Mills  * @param[in] aResp     Shared pointer for generating response message.
946c0557e1aSGunnar Mills  *
947c0557e1aSGunnar Mills  * @return None.
948c0557e1aSGunnar Mills  */
949b5a76932SEd Tanous inline void getLastResetTime(const std::shared_ptr<AsyncResp>& aResp)
950c0557e1aSGunnar Mills {
951c0557e1aSGunnar Mills     BMCWEB_LOG_DEBUG << "Getting System Last Reset Time";
952c0557e1aSGunnar Mills 
953c0557e1aSGunnar Mills     crow::connections::systemBus->async_method_call(
954c0557e1aSGunnar Mills         [aResp](const boost::system::error_code ec,
955c0557e1aSGunnar Mills                 std::variant<uint64_t>& lastResetTime) {
956c0557e1aSGunnar Mills             if (ec)
957c0557e1aSGunnar Mills             {
958c0557e1aSGunnar Mills                 BMCWEB_LOG_DEBUG << "D-BUS response error " << ec;
959c0557e1aSGunnar Mills                 return;
960c0557e1aSGunnar Mills             }
961c0557e1aSGunnar Mills 
962c0557e1aSGunnar Mills             const uint64_t* lastResetTimePtr =
963c0557e1aSGunnar Mills                 std::get_if<uint64_t>(&lastResetTime);
964c0557e1aSGunnar Mills 
965c0557e1aSGunnar Mills             if (!lastResetTimePtr)
966c0557e1aSGunnar Mills             {
967c0557e1aSGunnar Mills                 messages::internalError(aResp->res);
968c0557e1aSGunnar Mills                 return;
969c0557e1aSGunnar Mills             }
970c0557e1aSGunnar Mills             // LastStateChangeTime is epoch time, in milliseconds
971c0557e1aSGunnar Mills             // https://github.com/openbmc/phosphor-dbus-interfaces/blob/33e8e1dd64da53a66e888d33dc82001305cd0bf9/xyz/openbmc_project/State/Chassis.interface.yaml#L19
972c0557e1aSGunnar Mills             time_t lastResetTimeStamp =
973c0557e1aSGunnar Mills                 static_cast<time_t>(*lastResetTimePtr / 1000);
974c0557e1aSGunnar Mills 
975c0557e1aSGunnar Mills             // Convert to ISO 8601 standard
976c0557e1aSGunnar Mills             aResp->res.jsonValue["LastResetTime"] =
977c0557e1aSGunnar Mills                 crow::utility::getDateTime(lastResetTimeStamp);
978c0557e1aSGunnar Mills         },
979c0557e1aSGunnar Mills         "xyz.openbmc_project.State.Chassis",
980c0557e1aSGunnar Mills         "/xyz/openbmc_project/state/chassis0",
981c0557e1aSGunnar Mills         "org.freedesktop.DBus.Properties", "Get",
982c0557e1aSGunnar Mills         "xyz.openbmc_project.State.Chassis", "LastStateChangeTime");
983c0557e1aSGunnar Mills }
984c0557e1aSGunnar Mills 
985c0557e1aSGunnar Mills /**
9866bd5a8d2SGunnar Mills  * @brief Retrieves Automatic Retry properties. Known on D-Bus as AutoReboot.
9876bd5a8d2SGunnar Mills  *
9886bd5a8d2SGunnar Mills  * @param[in] aResp     Shared pointer for generating response message.
9896bd5a8d2SGunnar Mills  *
9906bd5a8d2SGunnar Mills  * @return None.
9916bd5a8d2SGunnar Mills  */
992b5a76932SEd Tanous inline void getAutomaticRetry(const std::shared_ptr<AsyncResp>& aResp)
9936bd5a8d2SGunnar Mills {
9946bd5a8d2SGunnar Mills     BMCWEB_LOG_DEBUG << "Get Automatic Retry policy";
9956bd5a8d2SGunnar Mills 
9966bd5a8d2SGunnar Mills     crow::connections::systemBus->async_method_call(
9976bd5a8d2SGunnar Mills         [aResp](const boost::system::error_code ec,
9986bd5a8d2SGunnar Mills                 std::variant<bool>& autoRebootEnabled) {
9996bd5a8d2SGunnar Mills             if (ec)
10006bd5a8d2SGunnar Mills             {
10016bd5a8d2SGunnar Mills                 BMCWEB_LOG_DEBUG << "D-BUS response error " << ec;
10026bd5a8d2SGunnar Mills                 return;
10036bd5a8d2SGunnar Mills             }
10046bd5a8d2SGunnar Mills 
10056bd5a8d2SGunnar Mills             const bool* autoRebootEnabledPtr =
10066bd5a8d2SGunnar Mills                 std::get_if<bool>(&autoRebootEnabled);
10076bd5a8d2SGunnar Mills 
10086bd5a8d2SGunnar Mills             if (!autoRebootEnabledPtr)
10096bd5a8d2SGunnar Mills             {
10106bd5a8d2SGunnar Mills                 messages::internalError(aResp->res);
10116bd5a8d2SGunnar Mills                 return;
10126bd5a8d2SGunnar Mills             }
10136bd5a8d2SGunnar Mills 
10146bd5a8d2SGunnar Mills             BMCWEB_LOG_DEBUG << "Auto Reboot: " << *autoRebootEnabledPtr;
10156bd5a8d2SGunnar Mills             if (*autoRebootEnabledPtr == true)
10166bd5a8d2SGunnar Mills             {
10176bd5a8d2SGunnar Mills                 aResp->res.jsonValue["Boot"]["AutomaticRetryConfig"] =
10186bd5a8d2SGunnar Mills                     "RetryAttempts";
10196bd5a8d2SGunnar Mills                 // If AutomaticRetry (AutoReboot) is enabled see how many
10206bd5a8d2SGunnar Mills                 // attempts are left
10216bd5a8d2SGunnar Mills                 crow::connections::systemBus->async_method_call(
1022cb13a392SEd Tanous                     [aResp](const boost::system::error_code ec2,
10236bd5a8d2SGunnar Mills                             std::variant<uint32_t>& autoRebootAttemptsLeft) {
1024cb13a392SEd Tanous                         if (ec2)
10256bd5a8d2SGunnar Mills                         {
1026cb13a392SEd Tanous                             BMCWEB_LOG_DEBUG << "D-BUS response error " << ec2;
10276bd5a8d2SGunnar Mills                             return;
10286bd5a8d2SGunnar Mills                         }
10296bd5a8d2SGunnar Mills 
10306bd5a8d2SGunnar Mills                         const uint32_t* autoRebootAttemptsLeftPtr =
10316bd5a8d2SGunnar Mills                             std::get_if<uint32_t>(&autoRebootAttemptsLeft);
10326bd5a8d2SGunnar Mills 
10336bd5a8d2SGunnar Mills                         if (!autoRebootAttemptsLeftPtr)
10346bd5a8d2SGunnar Mills                         {
10356bd5a8d2SGunnar Mills                             messages::internalError(aResp->res);
10366bd5a8d2SGunnar Mills                             return;
10376bd5a8d2SGunnar Mills                         }
10386bd5a8d2SGunnar Mills 
10396bd5a8d2SGunnar Mills                         BMCWEB_LOG_DEBUG << "Auto Reboot Attempts Left: "
10406bd5a8d2SGunnar Mills                                          << *autoRebootAttemptsLeftPtr;
10416bd5a8d2SGunnar Mills 
10426bd5a8d2SGunnar Mills                         aResp->res
10436bd5a8d2SGunnar Mills                             .jsonValue["Boot"]
10446bd5a8d2SGunnar Mills                                       ["RemainingAutomaticRetryAttempts"] =
10456bd5a8d2SGunnar Mills                             *autoRebootAttemptsLeftPtr;
10466bd5a8d2SGunnar Mills                     },
10476bd5a8d2SGunnar Mills                     "xyz.openbmc_project.State.Host",
10486bd5a8d2SGunnar Mills                     "/xyz/openbmc_project/state/host0",
10496bd5a8d2SGunnar Mills                     "org.freedesktop.DBus.Properties", "Get",
10506bd5a8d2SGunnar Mills                     "xyz.openbmc_project.Control.Boot.RebootAttempts",
10516bd5a8d2SGunnar Mills                     "AttemptsLeft");
10526bd5a8d2SGunnar Mills             }
10536bd5a8d2SGunnar Mills             else
10546bd5a8d2SGunnar Mills             {
10556bd5a8d2SGunnar Mills                 aResp->res.jsonValue["Boot"]["AutomaticRetryConfig"] =
10566bd5a8d2SGunnar Mills                     "Disabled";
10576bd5a8d2SGunnar Mills             }
10586bd5a8d2SGunnar Mills 
10596bd5a8d2SGunnar Mills             // Not on D-Bus. Hardcoded here:
10606bd5a8d2SGunnar Mills             // https://github.com/openbmc/phosphor-state-manager/blob/1dbbef42675e94fb1f78edb87d6b11380260535a/meson_options.txt#L71
10616bd5a8d2SGunnar Mills             aResp->res.jsonValue["Boot"]["AutomaticRetryAttempts"] = 3;
106269f35306SGunnar Mills 
106369f35306SGunnar Mills             // "AutomaticRetryConfig" can be 3 values, Disabled, RetryAlways,
106469f35306SGunnar Mills             // and RetryAttempts. OpenBMC only supports Disabled and
106569f35306SGunnar Mills             // RetryAttempts.
106669f35306SGunnar Mills             aResp->res.jsonValue["Boot"]["AutomaticRetryConfig@Redfish."
106769f35306SGunnar Mills                                          "AllowableValues"] = {"Disabled",
106869f35306SGunnar Mills                                                                "RetryAttempts"};
10696bd5a8d2SGunnar Mills         },
10706bd5a8d2SGunnar Mills         "xyz.openbmc_project.Settings",
10716bd5a8d2SGunnar Mills         "/xyz/openbmc_project/control/host0/auto_reboot",
10726bd5a8d2SGunnar Mills         "org.freedesktop.DBus.Properties", "Get",
10736bd5a8d2SGunnar Mills         "xyz.openbmc_project.Control.Boot.RebootPolicy", "AutoReboot");
10746bd5a8d2SGunnar Mills }
10756bd5a8d2SGunnar Mills 
10766bd5a8d2SGunnar Mills /**
1077c6a620f2SGeorge Liu  * @brief Retrieves power restore policy over DBUS.
1078c6a620f2SGeorge Liu  *
1079c6a620f2SGeorge Liu  * @param[in] aResp     Shared pointer for generating response message.
1080c6a620f2SGeorge Liu  *
1081c6a620f2SGeorge Liu  * @return None.
1082c6a620f2SGeorge Liu  */
1083b5a76932SEd Tanous inline void getPowerRestorePolicy(const std::shared_ptr<AsyncResp>& aResp)
1084c6a620f2SGeorge Liu {
1085c6a620f2SGeorge Liu     BMCWEB_LOG_DEBUG << "Get power restore policy";
1086c6a620f2SGeorge Liu 
1087c6a620f2SGeorge Liu     crow::connections::systemBus->async_method_call(
1088c6a620f2SGeorge Liu         [aResp](const boost::system::error_code ec,
108919bd78d9SPatrick Williams                 std::variant<std::string>& policy) {
1090c6a620f2SGeorge Liu             if (ec)
1091c6a620f2SGeorge Liu             {
1092c6a620f2SGeorge Liu                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1093c6a620f2SGeorge Liu                 return;
1094c6a620f2SGeorge Liu             }
1095c6a620f2SGeorge Liu 
1096c6a620f2SGeorge Liu             const boost::container::flat_map<std::string, std::string>
1097c6a620f2SGeorge Liu                 policyMaps = {
1098c6a620f2SGeorge Liu                     {"xyz.openbmc_project.Control.Power.RestorePolicy.Policy."
1099c6a620f2SGeorge Liu                      "AlwaysOn",
1100c6a620f2SGeorge Liu                      "AlwaysOn"},
1101c6a620f2SGeorge Liu                     {"xyz.openbmc_project.Control.Power.RestorePolicy.Policy."
1102c6a620f2SGeorge Liu                      "AlwaysOff",
1103c6a620f2SGeorge Liu                      "AlwaysOff"},
1104c6a620f2SGeorge Liu                     {"xyz.openbmc_project.Control.Power.RestorePolicy.Policy."
1105c6a620f2SGeorge Liu                      "LastState",
1106c6a620f2SGeorge Liu                      "LastState"}};
1107c6a620f2SGeorge Liu 
1108c6a620f2SGeorge Liu             const std::string* policyPtr = std::get_if<std::string>(&policy);
1109c6a620f2SGeorge Liu 
1110c6a620f2SGeorge Liu             if (!policyPtr)
1111c6a620f2SGeorge Liu             {
1112c6a620f2SGeorge Liu                 messages::internalError(aResp->res);
1113c6a620f2SGeorge Liu                 return;
1114c6a620f2SGeorge Liu             }
1115c6a620f2SGeorge Liu 
1116c6a620f2SGeorge Liu             auto policyMapsIt = policyMaps.find(*policyPtr);
1117c6a620f2SGeorge Liu             if (policyMapsIt == policyMaps.end())
1118c6a620f2SGeorge Liu             {
1119c6a620f2SGeorge Liu                 messages::internalError(aResp->res);
1120c6a620f2SGeorge Liu                 return;
1121c6a620f2SGeorge Liu             }
1122c6a620f2SGeorge Liu 
1123c6a620f2SGeorge Liu             aResp->res.jsonValue["PowerRestorePolicy"] = policyMapsIt->second;
1124c6a620f2SGeorge Liu         },
1125c6a620f2SGeorge Liu         "xyz.openbmc_project.Settings",
1126c6a620f2SGeorge Liu         "/xyz/openbmc_project/control/host0/power_restore_policy",
1127c6a620f2SGeorge Liu         "org.freedesktop.DBus.Properties", "Get",
1128c6a620f2SGeorge Liu         "xyz.openbmc_project.Control.Power.RestorePolicy",
1129c6a620f2SGeorge Liu         "PowerRestorePolicy");
1130c6a620f2SGeorge Liu }
1131c6a620f2SGeorge Liu 
1132c6a620f2SGeorge Liu /**
1133491d8ee7SSantosh Puranik  * @brief Sets boot properties into DBUS object(s).
1134491d8ee7SSantosh Puranik  *
1135491d8ee7SSantosh Puranik  * @param[in] aResp           Shared pointer for generating response message.
1136491d8ee7SSantosh Puranik  * @param[in] oneTimeEnabled  Is "one-time" setting already enabled.
1137491d8ee7SSantosh Puranik  * @param[in] bootSource      The boot source to set.
1138491d8ee7SSantosh Puranik  * @param[in] bootEnable      The source override "enable" to set.
1139491d8ee7SSantosh Puranik  *
1140265c1602SJohnathan Mantey  * @return Integer error code.
1141491d8ee7SSantosh Puranik  */
114223a21a1cSEd Tanous inline void setBootModeOrSource(std::shared_ptr<AsyncResp> aResp,
1143491d8ee7SSantosh Puranik                                 bool oneTimeEnabled,
1144f23b7296SEd Tanous                                 const std::optional<std::string>& bootSource,
1145f23b7296SEd Tanous                                 const std::optional<std::string>& bootEnable)
1146491d8ee7SSantosh Puranik {
1147944ffaf9SJohnathan Mantey     std::string bootSourceStr =
1148944ffaf9SJohnathan Mantey         "xyz.openbmc_project.Control.Boot.Source.Sources.Default";
1149944ffaf9SJohnathan Mantey     std::string bootModeStr =
1150944ffaf9SJohnathan Mantey         "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular";
1151491d8ee7SSantosh Puranik     bool oneTimeSetting = oneTimeEnabled;
1152944ffaf9SJohnathan Mantey     bool useBootSource = true;
1153944ffaf9SJohnathan Mantey 
1154491d8ee7SSantosh Puranik     // Validate incoming parameters
1155491d8ee7SSantosh Puranik     if (bootEnable)
1156491d8ee7SSantosh Puranik     {
1157491d8ee7SSantosh Puranik         if (*bootEnable == "Once")
1158491d8ee7SSantosh Puranik         {
1159491d8ee7SSantosh Puranik             oneTimeSetting = true;
1160491d8ee7SSantosh Puranik         }
1161491d8ee7SSantosh Puranik         else if (*bootEnable == "Continuous")
1162491d8ee7SSantosh Puranik         {
1163491d8ee7SSantosh Puranik             oneTimeSetting = false;
1164491d8ee7SSantosh Puranik         }
1165491d8ee7SSantosh Puranik         else if (*bootEnable == "Disabled")
1166491d8ee7SSantosh Puranik         {
1167944ffaf9SJohnathan Mantey             BMCWEB_LOG_DEBUG << "Boot source override will be disabled";
1168491d8ee7SSantosh Puranik             oneTimeSetting = false;
1169944ffaf9SJohnathan Mantey             useBootSource = false;
1170491d8ee7SSantosh Puranik         }
1171491d8ee7SSantosh Puranik         else
1172491d8ee7SSantosh Puranik         {
1173491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Unsupported value for "
1174491d8ee7SSantosh Puranik                                 "BootSourceOverrideEnabled: "
1175491d8ee7SSantosh Puranik                              << *bootEnable;
1176491d8ee7SSantosh Puranik             messages::propertyValueNotInList(aResp->res, *bootEnable,
1177491d8ee7SSantosh Puranik                                              "BootSourceOverrideEnabled");
1178491d8ee7SSantosh Puranik             return;
1179491d8ee7SSantosh Puranik         }
1180491d8ee7SSantosh Puranik     }
1181491d8ee7SSantosh Puranik 
1182944ffaf9SJohnathan Mantey     if (bootSource && useBootSource)
1183491d8ee7SSantosh Puranik     {
1184491d8ee7SSantosh Puranik         // Source target specified
1185491d8ee7SSantosh Puranik         BMCWEB_LOG_DEBUG << "Boot source: " << *bootSource;
1186491d8ee7SSantosh Puranik         // Figure out which DBUS interface and property to use
1187944ffaf9SJohnathan Mantey         if (assignBootParameters(aResp, *bootSource, bootSourceStr,
1188944ffaf9SJohnathan Mantey                                  bootModeStr))
1189491d8ee7SSantosh Puranik         {
1190944ffaf9SJohnathan Mantey             BMCWEB_LOG_DEBUG
1191944ffaf9SJohnathan Mantey                 << "Invalid property value for BootSourceOverrideTarget: "
1192491d8ee7SSantosh Puranik                 << *bootSource;
1193491d8ee7SSantosh Puranik             messages::propertyValueNotInList(aResp->res, *bootSource,
1194491d8ee7SSantosh Puranik                                              "BootSourceTargetOverride");
1195491d8ee7SSantosh Puranik             return;
1196491d8ee7SSantosh Puranik         }
1197944ffaf9SJohnathan Mantey     }
1198491d8ee7SSantosh Puranik 
1199944ffaf9SJohnathan Mantey     // Act on validated parameters
1200944ffaf9SJohnathan Mantey     BMCWEB_LOG_DEBUG << "DBUS boot source: " << bootSourceStr;
1201944ffaf9SJohnathan Mantey     BMCWEB_LOG_DEBUG << "DBUS boot mode: " << bootModeStr;
1202944ffaf9SJohnathan Mantey     const char* bootObj =
1203944ffaf9SJohnathan Mantey         oneTimeSetting ? "/xyz/openbmc_project/control/host0/boot/one_time"
1204944ffaf9SJohnathan Mantey                        : "/xyz/openbmc_project/control/host0/boot";
1205944ffaf9SJohnathan Mantey 
1206491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1207491d8ee7SSantosh Puranik         [aResp](const boost::system::error_code ec) {
1208491d8ee7SSantosh Puranik             if (ec)
1209491d8ee7SSantosh Puranik             {
1210491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1211491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1212491d8ee7SSantosh Puranik                 return;
1213491d8ee7SSantosh Puranik             }
1214491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot source update done.";
1215491d8ee7SSantosh Puranik         },
1216491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootObj,
1217491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Set",
1218491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Source", "BootSource",
1219491d8ee7SSantosh Puranik         std::variant<std::string>(bootSourceStr));
1220944ffaf9SJohnathan Mantey 
1221491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1222491d8ee7SSantosh Puranik         [aResp](const boost::system::error_code ec) {
1223491d8ee7SSantosh Puranik             if (ec)
1224491d8ee7SSantosh Puranik             {
1225491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1226491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1227491d8ee7SSantosh Puranik                 return;
1228491d8ee7SSantosh Puranik             }
1229491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot mode update done.";
1230491d8ee7SSantosh Puranik         },
1231491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootObj,
1232491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Set",
1233491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Mode", "BootMode",
1234491d8ee7SSantosh Puranik         std::variant<std::string>(bootModeStr));
1235944ffaf9SJohnathan Mantey 
1236491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1237491d8ee7SSantosh Puranik         [aResp{std::move(aResp)}](const boost::system::error_code ec) {
1238491d8ee7SSantosh Puranik             if (ec)
1239491d8ee7SSantosh Puranik             {
1240491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1241491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1242491d8ee7SSantosh Puranik                 return;
1243491d8ee7SSantosh Puranik             }
1244491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot enable update done.";
1245491d8ee7SSantosh Puranik         },
1246491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings",
1247491d8ee7SSantosh Puranik         "/xyz/openbmc_project/control/host0/boot/one_time",
1248491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Set",
1249491d8ee7SSantosh Puranik         "xyz.openbmc_project.Object.Enable", "Enabled",
1250491d8ee7SSantosh Puranik         std::variant<bool>(oneTimeSetting));
1251491d8ee7SSantosh Puranik }
1252491d8ee7SSantosh Puranik 
1253491d8ee7SSantosh Puranik /**
1254491d8ee7SSantosh Puranik  * @brief Retrieves "One time" enabled setting over DBUS and calls function to
1255491d8ee7SSantosh Puranik  * set boot source/boot mode properties.
1256491d8ee7SSantosh Puranik  *
1257491d8ee7SSantosh Puranik  * @param[in] aResp      Shared pointer for generating response message.
1258491d8ee7SSantosh Puranik  * @param[in] bootSource The boot source from incoming RF request.
1259491d8ee7SSantosh Puranik  * @param[in] bootEnable The boot override enable from incoming RF request.
1260491d8ee7SSantosh Puranik  *
1261265c1602SJohnathan Mantey  * @return Integer error code.
1262491d8ee7SSantosh Puranik  */
1263b5a76932SEd Tanous inline void setBootSourceProperties(const std::shared_ptr<AsyncResp>& aResp,
1264491d8ee7SSantosh Puranik                                     std::optional<std::string> bootSource,
1265491d8ee7SSantosh Puranik                                     std::optional<std::string> bootEnable)
1266491d8ee7SSantosh Puranik {
1267491d8ee7SSantosh Puranik     BMCWEB_LOG_DEBUG << "Set boot information.";
1268491d8ee7SSantosh Puranik 
1269491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1270265c1602SJohnathan Mantey         [aResp, bootSource{std::move(bootSource)},
127119bd78d9SPatrick Williams          bootEnable{std::move(bootEnable)}](const boost::system::error_code ec,
127219bd78d9SPatrick Williams                                             const std::variant<bool>& oneTime) {
1273491d8ee7SSantosh Puranik             if (ec)
1274491d8ee7SSantosh Puranik             {
1275491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1276491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1277491d8ee7SSantosh Puranik                 return;
1278491d8ee7SSantosh Puranik             }
1279491d8ee7SSantosh Puranik 
1280491d8ee7SSantosh Puranik             const bool* oneTimePtr = std::get_if<bool>(&oneTime);
1281491d8ee7SSantosh Puranik 
1282491d8ee7SSantosh Puranik             if (!oneTimePtr)
1283491d8ee7SSantosh Puranik             {
1284491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1285491d8ee7SSantosh Puranik                 return;
1286491d8ee7SSantosh Puranik             }
1287491d8ee7SSantosh Puranik 
1288491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Got one time: " << *oneTimePtr;
1289491d8ee7SSantosh Puranik 
1290f23b7296SEd Tanous             setBootModeOrSource(aResp, *oneTimePtr, bootSource, bootEnable);
1291491d8ee7SSantosh Puranik         },
1292491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings",
1293491d8ee7SSantosh Puranik         "/xyz/openbmc_project/control/host0/boot/one_time",
1294491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
1295491d8ee7SSantosh Puranik         "xyz.openbmc_project.Object.Enable", "Enabled");
1296491d8ee7SSantosh Puranik }
1297491d8ee7SSantosh Puranik 
1298c6a620f2SGeorge Liu /**
129998e386ecSGunnar Mills  * @brief Sets AssetTag
130098e386ecSGunnar Mills  *
130198e386ecSGunnar Mills  * @param[in] aResp   Shared pointer for generating response message.
130298e386ecSGunnar Mills  * @param[in] assetTag  "AssetTag" from request.
130398e386ecSGunnar Mills  *
130498e386ecSGunnar Mills  * @return None.
130598e386ecSGunnar Mills  */
130698e386ecSGunnar Mills inline void setAssetTag(const std::shared_ptr<AsyncResp>& aResp,
130798e386ecSGunnar Mills                         const std::string& assetTag)
130898e386ecSGunnar Mills {
130998e386ecSGunnar Mills     crow::connections::systemBus->async_method_call(
131098e386ecSGunnar Mills         [aResp, assetTag](
131198e386ecSGunnar Mills             const boost::system::error_code ec,
131298e386ecSGunnar Mills             const std::vector<std::pair<
131398e386ecSGunnar Mills                 std::string,
131498e386ecSGunnar Mills                 std::vector<std::pair<std::string, std::vector<std::string>>>>>&
131598e386ecSGunnar Mills                 subtree) {
131698e386ecSGunnar Mills             if (ec)
131798e386ecSGunnar Mills             {
131898e386ecSGunnar Mills                 BMCWEB_LOG_DEBUG << "D-Bus response error on GetSubTree " << ec;
131998e386ecSGunnar Mills                 messages::internalError(aResp->res);
132098e386ecSGunnar Mills                 return;
132198e386ecSGunnar Mills             }
132298e386ecSGunnar Mills             if (subtree.size() == 0)
132398e386ecSGunnar Mills             {
132498e386ecSGunnar Mills                 BMCWEB_LOG_DEBUG << "Can't find system D-Bus object!";
132598e386ecSGunnar Mills                 messages::internalError(aResp->res);
132698e386ecSGunnar Mills                 return;
132798e386ecSGunnar Mills             }
132898e386ecSGunnar Mills             // Assume only 1 system D-Bus object
132998e386ecSGunnar Mills             // Throw an error if there is more than 1
133098e386ecSGunnar Mills             if (subtree.size() > 1)
133198e386ecSGunnar Mills             {
133298e386ecSGunnar Mills                 BMCWEB_LOG_DEBUG << "Found more than 1 system D-Bus object!";
133398e386ecSGunnar Mills                 messages::internalError(aResp->res);
133498e386ecSGunnar Mills                 return;
133598e386ecSGunnar Mills             }
133698e386ecSGunnar Mills             if (subtree[0].first.empty() || subtree[0].second.size() != 1)
133798e386ecSGunnar Mills             {
133898e386ecSGunnar Mills                 BMCWEB_LOG_DEBUG << "Asset Tag Set mapper error!";
133998e386ecSGunnar Mills                 messages::internalError(aResp->res);
134098e386ecSGunnar Mills                 return;
134198e386ecSGunnar Mills             }
134298e386ecSGunnar Mills 
134398e386ecSGunnar Mills             const std::string& path = subtree[0].first;
134498e386ecSGunnar Mills             const std::string& service = subtree[0].second.begin()->first;
134598e386ecSGunnar Mills 
134698e386ecSGunnar Mills             if (service.empty())
134798e386ecSGunnar Mills             {
134898e386ecSGunnar Mills                 BMCWEB_LOG_DEBUG << "Asset Tag Set service mapper error!";
134998e386ecSGunnar Mills                 messages::internalError(aResp->res);
135098e386ecSGunnar Mills                 return;
135198e386ecSGunnar Mills             }
135298e386ecSGunnar Mills 
135398e386ecSGunnar Mills             crow::connections::systemBus->async_method_call(
135498e386ecSGunnar Mills                 [aResp](const boost::system::error_code ec2) {
135598e386ecSGunnar Mills                     if (ec2)
135698e386ecSGunnar Mills                     {
135798e386ecSGunnar Mills                         BMCWEB_LOG_DEBUG
135898e386ecSGunnar Mills                             << "D-Bus response error on AssetTag Set " << ec2;
135998e386ecSGunnar Mills                         messages::internalError(aResp->res);
136098e386ecSGunnar Mills                         return;
136198e386ecSGunnar Mills                     }
136298e386ecSGunnar Mills                 },
136398e386ecSGunnar Mills                 service, path, "org.freedesktop.DBus.Properties", "Set",
136498e386ecSGunnar Mills                 "xyz.openbmc_project.Inventory.Decorator.AssetTag", "AssetTag",
136598e386ecSGunnar Mills                 std::variant<std::string>(assetTag));
136698e386ecSGunnar Mills         },
136798e386ecSGunnar Mills         "xyz.openbmc_project.ObjectMapper",
136898e386ecSGunnar Mills         "/xyz/openbmc_project/object_mapper",
136998e386ecSGunnar Mills         "xyz.openbmc_project.ObjectMapper", "GetSubTree",
137098e386ecSGunnar Mills         "/xyz/openbmc_project/inventory", int32_t(0),
137198e386ecSGunnar Mills         std::array<const char*, 1>{
137298e386ecSGunnar Mills             "xyz.openbmc_project.Inventory.Item.System"});
137398e386ecSGunnar Mills }
137498e386ecSGunnar Mills 
137598e386ecSGunnar Mills /**
137669f35306SGunnar Mills  * @brief Sets automaticRetry (Auto Reboot)
137769f35306SGunnar Mills  *
137869f35306SGunnar Mills  * @param[in] aResp   Shared pointer for generating response message.
137969f35306SGunnar Mills  * @param[in] automaticRetryConfig  "AutomaticRetryConfig" from request.
138069f35306SGunnar Mills  *
138169f35306SGunnar Mills  * @return None.
138269f35306SGunnar Mills  */
1383b5a76932SEd Tanous inline void setAutomaticRetry(const std::shared_ptr<AsyncResp>& aResp,
1384f23b7296SEd Tanous                               const std::string& automaticRetryConfig)
138569f35306SGunnar Mills {
138669f35306SGunnar Mills     BMCWEB_LOG_DEBUG << "Set Automatic Retry.";
138769f35306SGunnar Mills 
138869f35306SGunnar Mills     // OpenBMC only supports "Disabled" and "RetryAttempts".
138969f35306SGunnar Mills     bool autoRebootEnabled;
139069f35306SGunnar Mills 
139169f35306SGunnar Mills     if (automaticRetryConfig == "Disabled")
139269f35306SGunnar Mills     {
139369f35306SGunnar Mills         autoRebootEnabled = false;
139469f35306SGunnar Mills     }
139569f35306SGunnar Mills     else if (automaticRetryConfig == "RetryAttempts")
139669f35306SGunnar Mills     {
139769f35306SGunnar Mills         autoRebootEnabled = true;
139869f35306SGunnar Mills     }
139969f35306SGunnar Mills     else
140069f35306SGunnar Mills     {
140169f35306SGunnar Mills         BMCWEB_LOG_DEBUG << "Invalid property value for "
140269f35306SGunnar Mills                             "AutomaticRetryConfig: "
140369f35306SGunnar Mills                          << automaticRetryConfig;
140469f35306SGunnar Mills         messages::propertyValueNotInList(aResp->res, automaticRetryConfig,
140569f35306SGunnar Mills                                          "AutomaticRetryConfig");
140669f35306SGunnar Mills         return;
140769f35306SGunnar Mills     }
140869f35306SGunnar Mills 
140969f35306SGunnar Mills     crow::connections::systemBus->async_method_call(
141069f35306SGunnar Mills         [aResp](const boost::system::error_code ec) {
141169f35306SGunnar Mills             if (ec)
141269f35306SGunnar Mills             {
141369f35306SGunnar Mills                 messages::internalError(aResp->res);
141469f35306SGunnar Mills                 return;
141569f35306SGunnar Mills             }
141669f35306SGunnar Mills         },
141769f35306SGunnar Mills         "xyz.openbmc_project.Settings",
141869f35306SGunnar Mills         "/xyz/openbmc_project/control/host0/auto_reboot",
141969f35306SGunnar Mills         "org.freedesktop.DBus.Properties", "Set",
142069f35306SGunnar Mills         "xyz.openbmc_project.Control.Boot.RebootPolicy", "AutoReboot",
142169f35306SGunnar Mills         std::variant<bool>(autoRebootEnabled));
142269f35306SGunnar Mills }
142369f35306SGunnar Mills 
142469f35306SGunnar Mills /**
1425c6a620f2SGeorge Liu  * @brief Sets power restore policy properties.
1426c6a620f2SGeorge Liu  *
1427c6a620f2SGeorge Liu  * @param[in] aResp   Shared pointer for generating response message.
1428c6a620f2SGeorge Liu  * @param[in] policy  power restore policy properties from request.
1429c6a620f2SGeorge Liu  *
1430c6a620f2SGeorge Liu  * @return None.
1431c6a620f2SGeorge Liu  */
1432b5a76932SEd Tanous inline void setPowerRestorePolicy(const std::shared_ptr<AsyncResp>& aResp,
1433c6a620f2SGeorge Liu                                   std::optional<std::string> policy)
1434c6a620f2SGeorge Liu {
1435c6a620f2SGeorge Liu     BMCWEB_LOG_DEBUG << "Set power restore policy.";
1436c6a620f2SGeorge Liu 
1437c6a620f2SGeorge Liu     const boost::container::flat_map<std::string, std::string> policyMaps = {
1438c6a620f2SGeorge Liu         {"AlwaysOn", "xyz.openbmc_project.Control.Power.RestorePolicy.Policy."
1439c6a620f2SGeorge Liu                      "AlwaysOn"},
1440c6a620f2SGeorge Liu         {"AlwaysOff", "xyz.openbmc_project.Control.Power.RestorePolicy.Policy."
1441c6a620f2SGeorge Liu                       "AlwaysOff"},
1442c6a620f2SGeorge Liu         {"LastState", "xyz.openbmc_project.Control.Power.RestorePolicy.Policy."
1443c6a620f2SGeorge Liu                       "LastState"}};
1444c6a620f2SGeorge Liu 
1445c6a620f2SGeorge Liu     std::string powerRestorPolicy;
1446c6a620f2SGeorge Liu 
1447c6a620f2SGeorge Liu     auto policyMapsIt = policyMaps.find(*policy);
1448c6a620f2SGeorge Liu     if (policyMapsIt == policyMaps.end())
1449c6a620f2SGeorge Liu     {
1450c6a620f2SGeorge Liu         messages::internalError(aResp->res);
1451c6a620f2SGeorge Liu         return;
1452c6a620f2SGeorge Liu     }
1453c6a620f2SGeorge Liu 
1454c6a620f2SGeorge Liu     powerRestorPolicy = policyMapsIt->second;
1455c6a620f2SGeorge Liu 
1456c6a620f2SGeorge Liu     crow::connections::systemBus->async_method_call(
1457c6a620f2SGeorge Liu         [aResp](const boost::system::error_code ec) {
1458c6a620f2SGeorge Liu             if (ec)
1459c6a620f2SGeorge Liu             {
1460c6a620f2SGeorge Liu                 messages::internalError(aResp->res);
1461c6a620f2SGeorge Liu                 return;
1462c6a620f2SGeorge Liu             }
1463c6a620f2SGeorge Liu         },
1464c6a620f2SGeorge Liu         "xyz.openbmc_project.Settings",
1465c6a620f2SGeorge Liu         "/xyz/openbmc_project/control/host0/power_restore_policy",
1466c6a620f2SGeorge Liu         "org.freedesktop.DBus.Properties", "Set",
1467c6a620f2SGeorge Liu         "xyz.openbmc_project.Control.Power.RestorePolicy", "PowerRestorePolicy",
1468c6a620f2SGeorge Liu         std::variant<std::string>(powerRestorPolicy));
1469c6a620f2SGeorge Liu }
1470c6a620f2SGeorge Liu 
1471a6349918SAppaRao Puli #ifdef BMCWEB_ENABLE_REDFISH_PROVISIONING_FEATURE
1472a6349918SAppaRao Puli /**
1473a6349918SAppaRao Puli  * @brief Retrieves provisioning status
1474a6349918SAppaRao Puli  *
1475a6349918SAppaRao Puli  * @param[in] aResp     Shared pointer for completing asynchronous calls.
1476a6349918SAppaRao Puli  *
1477a6349918SAppaRao Puli  * @return None.
1478a6349918SAppaRao Puli  */
147923a21a1cSEd Tanous inline void getProvisioningStatus(std::shared_ptr<AsyncResp> aResp)
1480a6349918SAppaRao Puli {
1481a6349918SAppaRao Puli     BMCWEB_LOG_DEBUG << "Get OEM information.";
1482a6349918SAppaRao Puli     crow::connections::systemBus->async_method_call(
1483a6349918SAppaRao Puli         [aResp](const boost::system::error_code ec,
14841214b7e7SGunnar Mills                 const std::vector<std::pair<std::string, VariantType>>&
14851214b7e7SGunnar Mills                     propertiesList) {
1486b99fb1a9SAppaRao Puli             nlohmann::json& oemPFR =
1487b99fb1a9SAppaRao Puli                 aResp->res.jsonValue["Oem"]["OpenBmc"]["FirmwareProvisioning"];
148850626f4fSJames Feist             aResp->res.jsonValue["Oem"]["OpenBmc"]["@odata.type"] =
148950626f4fSJames Feist                 "#OemComputerSystem.OpenBmc";
149050626f4fSJames Feist             oemPFR["@odata.type"] = "#OemComputerSystem.FirmwareProvisioning";
149150626f4fSJames Feist 
1492a6349918SAppaRao Puli             if (ec)
1493a6349918SAppaRao Puli             {
1494a6349918SAppaRao Puli                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1495b99fb1a9SAppaRao Puli                 // not an error, don't have to have the interface
1496b99fb1a9SAppaRao Puli                 oemPFR["ProvisioningStatus"] = "NotProvisioned";
1497a6349918SAppaRao Puli                 return;
1498a6349918SAppaRao Puli             }
1499a6349918SAppaRao Puli 
1500a6349918SAppaRao Puli             const bool* provState = nullptr;
1501a6349918SAppaRao Puli             const bool* lockState = nullptr;
1502a6349918SAppaRao Puli             for (const std::pair<std::string, VariantType>& property :
1503a6349918SAppaRao Puli                  propertiesList)
1504a6349918SAppaRao Puli             {
1505a6349918SAppaRao Puli                 if (property.first == "UfmProvisioned")
1506a6349918SAppaRao Puli                 {
1507a6349918SAppaRao Puli                     provState = std::get_if<bool>(&property.second);
1508a6349918SAppaRao Puli                 }
1509a6349918SAppaRao Puli                 else if (property.first == "UfmLocked")
1510a6349918SAppaRao Puli                 {
1511a6349918SAppaRao Puli                     lockState = std::get_if<bool>(&property.second);
1512a6349918SAppaRao Puli                 }
1513a6349918SAppaRao Puli             }
1514a6349918SAppaRao Puli 
1515a6349918SAppaRao Puli             if ((provState == nullptr) || (lockState == nullptr))
1516a6349918SAppaRao Puli             {
1517a6349918SAppaRao Puli                 BMCWEB_LOG_DEBUG << "Unable to get PFR attributes.";
1518a6349918SAppaRao Puli                 messages::internalError(aResp->res);
1519a6349918SAppaRao Puli                 return;
1520a6349918SAppaRao Puli             }
1521a6349918SAppaRao Puli 
1522a6349918SAppaRao Puli             if (*provState == true)
1523a6349918SAppaRao Puli             {
1524a6349918SAppaRao Puli                 if (*lockState == true)
1525a6349918SAppaRao Puli                 {
1526a6349918SAppaRao Puli                     oemPFR["ProvisioningStatus"] = "ProvisionedAndLocked";
1527a6349918SAppaRao Puli                 }
1528a6349918SAppaRao Puli                 else
1529a6349918SAppaRao Puli                 {
1530a6349918SAppaRao Puli                     oemPFR["ProvisioningStatus"] = "ProvisionedButNotLocked";
1531a6349918SAppaRao Puli                 }
1532a6349918SAppaRao Puli             }
1533a6349918SAppaRao Puli             else
1534a6349918SAppaRao Puli             {
1535a6349918SAppaRao Puli                 oemPFR["ProvisioningStatus"] = "NotProvisioned";
1536a6349918SAppaRao Puli             }
1537a6349918SAppaRao Puli         },
1538a6349918SAppaRao Puli         "xyz.openbmc_project.PFR.Manager", "/xyz/openbmc_project/pfr",
1539a6349918SAppaRao Puli         "org.freedesktop.DBus.Properties", "GetAll",
1540a6349918SAppaRao Puli         "xyz.openbmc_project.PFR.Attributes");
1541a6349918SAppaRao Puli }
1542a6349918SAppaRao Puli #endif
1543a6349918SAppaRao Puli 
1544491d8ee7SSantosh Puranik /**
154551709ffdSYong Li  * @brief Translates watchdog timeout action DBUS property value to redfish.
154651709ffdSYong Li  *
154751709ffdSYong Li  * @param[in] dbusAction    The watchdog timeout action in D-BUS.
154851709ffdSYong Li  *
154951709ffdSYong Li  * @return Returns as a string, the timeout action in Redfish terms. If
155051709ffdSYong Li  * translation cannot be done, returns an empty string.
155151709ffdSYong Li  */
155223a21a1cSEd Tanous inline std::string dbusToRfWatchdogAction(const std::string& dbusAction)
155351709ffdSYong Li {
155451709ffdSYong Li     if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.None")
155551709ffdSYong Li     {
155651709ffdSYong Li         return "None";
155751709ffdSYong Li     }
15583174e4dfSEd Tanous     if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.HardReset")
155951709ffdSYong Li     {
156051709ffdSYong Li         return "ResetSystem";
156151709ffdSYong Li     }
15623174e4dfSEd Tanous     if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.PowerOff")
156351709ffdSYong Li     {
156451709ffdSYong Li         return "PowerDown";
156551709ffdSYong Li     }
15663174e4dfSEd Tanous     if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.PowerCycle")
156751709ffdSYong Li     {
156851709ffdSYong Li         return "PowerCycle";
156951709ffdSYong Li     }
157051709ffdSYong Li 
157151709ffdSYong Li     return "";
157251709ffdSYong Li }
157351709ffdSYong Li 
157451709ffdSYong Li /**
1575c45f0082SYong Li  *@brief Translates timeout action from Redfish to DBUS property value.
1576c45f0082SYong Li  *
1577c45f0082SYong Li  *@param[in] rfAction The timeout action in Redfish.
1578c45f0082SYong Li  *
1579c45f0082SYong Li  *@return Returns as a string, the time_out action as expected by DBUS.
1580c45f0082SYong Li  *If translation cannot be done, returns an empty string.
1581c45f0082SYong Li  */
1582c45f0082SYong Li 
158323a21a1cSEd Tanous inline std::string rfToDbusWDTTimeOutAct(const std::string& rfAction)
1584c45f0082SYong Li {
1585c45f0082SYong Li     if (rfAction == "None")
1586c45f0082SYong Li     {
1587c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.None";
1588c45f0082SYong Li     }
15893174e4dfSEd Tanous     if (rfAction == "PowerCycle")
1590c45f0082SYong Li     {
1591c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.PowerCycle";
1592c45f0082SYong Li     }
15933174e4dfSEd Tanous     if (rfAction == "PowerDown")
1594c45f0082SYong Li     {
1595c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.PowerOff";
1596c45f0082SYong Li     }
15973174e4dfSEd Tanous     if (rfAction == "ResetSystem")
1598c45f0082SYong Li     {
1599c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.HardReset";
1600c45f0082SYong Li     }
1601c45f0082SYong Li 
1602c45f0082SYong Li     return "";
1603c45f0082SYong Li }
1604c45f0082SYong Li 
1605c45f0082SYong Li /**
160651709ffdSYong Li  * @brief Retrieves host watchdog timer properties over DBUS
160751709ffdSYong Li  *
160851709ffdSYong Li  * @param[in] aResp     Shared pointer for completing asynchronous calls.
160951709ffdSYong Li  *
161051709ffdSYong Li  * @return None.
161151709ffdSYong Li  */
1612b5a76932SEd Tanous inline void getHostWatchdogTimer(const std::shared_ptr<AsyncResp>& aResp)
161351709ffdSYong Li {
161451709ffdSYong Li     BMCWEB_LOG_DEBUG << "Get host watchodg";
161551709ffdSYong Li     crow::connections::systemBus->async_method_call(
161651709ffdSYong Li         [aResp](const boost::system::error_code ec,
161751709ffdSYong Li                 PropertiesType& properties) {
161851709ffdSYong Li             if (ec)
161951709ffdSYong Li             {
162051709ffdSYong Li                 // watchdog service is stopped
162151709ffdSYong Li                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
162251709ffdSYong Li                 return;
162351709ffdSYong Li             }
162451709ffdSYong Li 
162551709ffdSYong Li             BMCWEB_LOG_DEBUG << "Got " << properties.size() << " wdt prop.";
162651709ffdSYong Li 
162751709ffdSYong Li             nlohmann::json& hostWatchdogTimer =
162851709ffdSYong Li                 aResp->res.jsonValue["HostWatchdogTimer"];
162951709ffdSYong Li 
163051709ffdSYong Li             // watchdog service is running/enabled
163151709ffdSYong Li             hostWatchdogTimer["Status"]["State"] = "Enabled";
163251709ffdSYong Li 
163351709ffdSYong Li             for (const auto& property : properties)
163451709ffdSYong Li             {
163551709ffdSYong Li                 BMCWEB_LOG_DEBUG << "prop=" << property.first;
163651709ffdSYong Li                 if (property.first == "Enabled")
163751709ffdSYong Li                 {
163851709ffdSYong Li                     const bool* state = std::get_if<bool>(&property.second);
163951709ffdSYong Li 
164051709ffdSYong Li                     if (!state)
164151709ffdSYong Li                     {
164251709ffdSYong Li                         messages::internalError(aResp->res);
164351709ffdSYong Li                         continue;
164451709ffdSYong Li                     }
164551709ffdSYong Li 
164651709ffdSYong Li                     hostWatchdogTimer["FunctionEnabled"] = *state;
164751709ffdSYong Li                 }
164851709ffdSYong Li                 else if (property.first == "ExpireAction")
164951709ffdSYong Li                 {
165051709ffdSYong Li                     const std::string* s =
165151709ffdSYong Li                         std::get_if<std::string>(&property.second);
165251709ffdSYong Li                     if (!s)
165351709ffdSYong Li                     {
165451709ffdSYong Li                         messages::internalError(aResp->res);
165551709ffdSYong Li                         continue;
165651709ffdSYong Li                     }
165751709ffdSYong Li 
165851709ffdSYong Li                     std::string action = dbusToRfWatchdogAction(*s);
165951709ffdSYong Li                     if (action.empty())
166051709ffdSYong Li                     {
166151709ffdSYong Li                         messages::internalError(aResp->res);
166251709ffdSYong Li                         continue;
166351709ffdSYong Li                     }
166451709ffdSYong Li                     hostWatchdogTimer["TimeoutAction"] = action;
166551709ffdSYong Li                 }
166651709ffdSYong Li             }
166751709ffdSYong Li         },
166851709ffdSYong Li         "xyz.openbmc_project.Watchdog", "/xyz/openbmc_project/watchdog/host0",
166951709ffdSYong Li         "org.freedesktop.DBus.Properties", "GetAll",
167051709ffdSYong Li         "xyz.openbmc_project.State.Watchdog");
167151709ffdSYong Li }
167251709ffdSYong Li 
167351709ffdSYong Li /**
1674c45f0082SYong Li  * @brief Sets Host WatchDog Timer properties.
1675c45f0082SYong Li  *
1676c45f0082SYong Li  * @param[in] aResp      Shared pointer for generating response message.
1677c45f0082SYong Li  * @param[in] wdtEnable  The WDTimer Enable value (true/false) from incoming
1678c45f0082SYong Li  *                       RF request.
1679c45f0082SYong Li  * @param[in] wdtTimeOutAction The WDT Timeout action, from incoming RF request.
1680c45f0082SYong Li  *
1681c45f0082SYong Li  * @return None.
1682c45f0082SYong Li  */
1683b5a76932SEd Tanous inline void setWDTProperties(const std::shared_ptr<AsyncResp>& aResp,
1684c45f0082SYong Li                              const std::optional<bool> wdtEnable,
1685c45f0082SYong Li                              const std::optional<std::string>& wdtTimeOutAction)
1686c45f0082SYong Li {
1687c45f0082SYong Li     BMCWEB_LOG_DEBUG << "Set host watchdog";
1688c45f0082SYong Li 
1689c45f0082SYong Li     if (wdtTimeOutAction)
1690c45f0082SYong Li     {
1691c45f0082SYong Li         std::string wdtTimeOutActStr = rfToDbusWDTTimeOutAct(*wdtTimeOutAction);
1692c45f0082SYong Li         // check if TimeOut Action is Valid
1693c45f0082SYong Li         if (wdtTimeOutActStr.empty())
1694c45f0082SYong Li         {
1695c45f0082SYong Li             BMCWEB_LOG_DEBUG << "Unsupported value for TimeoutAction: "
1696c45f0082SYong Li                              << *wdtTimeOutAction;
1697c45f0082SYong Li             messages::propertyValueNotInList(aResp->res, *wdtTimeOutAction,
1698c45f0082SYong Li                                              "TimeoutAction");
1699c45f0082SYong Li             return;
1700c45f0082SYong Li         }
1701c45f0082SYong Li 
1702c45f0082SYong Li         crow::connections::systemBus->async_method_call(
1703c45f0082SYong Li             [aResp](const boost::system::error_code ec) {
1704c45f0082SYong Li                 if (ec)
1705c45f0082SYong Li                 {
1706c45f0082SYong Li                     BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1707c45f0082SYong Li                     messages::internalError(aResp->res);
1708c45f0082SYong Li                     return;
1709c45f0082SYong Li                 }
1710c45f0082SYong Li             },
1711c45f0082SYong Li             "xyz.openbmc_project.Watchdog",
1712c45f0082SYong Li             "/xyz/openbmc_project/watchdog/host0",
1713c45f0082SYong Li             "org.freedesktop.DBus.Properties", "Set",
1714c45f0082SYong Li             "xyz.openbmc_project.State.Watchdog", "ExpireAction",
1715c45f0082SYong Li             std::variant<std::string>(wdtTimeOutActStr));
1716c45f0082SYong Li     }
1717c45f0082SYong Li 
1718c45f0082SYong Li     if (wdtEnable)
1719c45f0082SYong Li     {
1720c45f0082SYong Li         crow::connections::systemBus->async_method_call(
1721c45f0082SYong Li             [aResp](const boost::system::error_code ec) {
1722c45f0082SYong Li                 if (ec)
1723c45f0082SYong Li                 {
1724c45f0082SYong Li                     BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1725c45f0082SYong Li                     messages::internalError(aResp->res);
1726c45f0082SYong Li                     return;
1727c45f0082SYong Li                 }
1728c45f0082SYong Li             },
1729c45f0082SYong Li             "xyz.openbmc_project.Watchdog",
1730c45f0082SYong Li             "/xyz/openbmc_project/watchdog/host0",
1731c45f0082SYong Li             "org.freedesktop.DBus.Properties", "Set",
1732c45f0082SYong Li             "xyz.openbmc_project.State.Watchdog", "Enabled",
1733c45f0082SYong Li             std::variant<bool>(*wdtEnable));
1734c45f0082SYong Li     }
1735c45f0082SYong Li }
1736c45f0082SYong Li 
1737c45f0082SYong Li /**
1738c5b2abe0SLewanczyk, Dawid  * SystemsCollection derived class for delivering ComputerSystems Collection
1739c5b2abe0SLewanczyk, Dawid  * Schema
1740c5b2abe0SLewanczyk, Dawid  */
17411abe55efSEd Tanous class SystemsCollection : public Node
17421abe55efSEd Tanous {
1743c5b2abe0SLewanczyk, Dawid   public:
174452cc112dSEd Tanous     SystemsCollection(App& app) : Node(app, "/redfish/v1/Systems/")
17451abe55efSEd Tanous     {
1746c5b2abe0SLewanczyk, Dawid         entityPrivileges = {
1747c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::get, {{"Login"}}},
1748c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::head, {{"Login"}}},
1749c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::patch, {{"ConfigureComponents"}}},
1750c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::put, {{"ConfigureComponents"}}},
1751c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}},
1752c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
1753c5b2abe0SLewanczyk, Dawid     }
1754c5b2abe0SLewanczyk, Dawid 
1755c5b2abe0SLewanczyk, Dawid   private:
1756cb13a392SEd Tanous     void doGet(crow::Response& res, const crow::Request&,
1757cb13a392SEd Tanous                const std::vector<std::string>&) override
17581abe55efSEd Tanous     {
1759462023adSSunitha Harish         std::shared_ptr<AsyncResp> asyncResp = std::make_shared<AsyncResp>(res);
17600f74e643SEd Tanous         res.jsonValue["@odata.type"] =
17610f74e643SEd Tanous             "#ComputerSystemCollection.ComputerSystemCollection";
17620f74e643SEd Tanous         res.jsonValue["@odata.id"] = "/redfish/v1/Systems";
17630f74e643SEd Tanous         res.jsonValue["Name"] = "Computer System Collection";
1764462023adSSunitha Harish 
1765462023adSSunitha Harish         crow::connections::systemBus->async_method_call(
1766462023adSSunitha Harish             [asyncResp](const boost::system::error_code ec,
1767cb13a392SEd Tanous                         const std::variant<std::string>& /*hostName*/) {
17682c70f800SEd Tanous                 nlohmann::json& ifaceArray =
1769462023adSSunitha Harish                     asyncResp->res.jsonValue["Members"];
17702c70f800SEd Tanous                 ifaceArray = nlohmann::json::array();
1771462023adSSunitha Harish                 auto& count = asyncResp->res.jsonValue["Members@odata.count"];
17722c70f800SEd Tanous                 ifaceArray.push_back(
1773cb13a392SEd Tanous                     {{"@odata.id", "/redfish/v1/Systems/system"}});
1774*94bda602STim Lee                 count = ifaceArray.size();
1775cb13a392SEd Tanous                 if (!ec)
1776462023adSSunitha Harish                 {
1777462023adSSunitha Harish                     BMCWEB_LOG_DEBUG << "Hypervisor is available";
17782c70f800SEd Tanous                     ifaceArray.push_back(
1779462023adSSunitha Harish                         {{"@odata.id", "/redfish/v1/Systems/hypervisor"}});
17802c70f800SEd Tanous                     count = ifaceArray.size();
1781cb13a392SEd Tanous                     return;
1782cb13a392SEd Tanous                 }
1783462023adSSunitha Harish             },
17848e651fbfSSunitha Harish             "xyz.openbmc_project.Settings",
17858e651fbfSSunitha Harish             "/xyz/openbmc_project/network/hypervisor",
1786462023adSSunitha Harish             "org.freedesktop.DBus.Properties", "Get",
1787462023adSSunitha Harish             "xyz.openbmc_project.Network.SystemConfiguration", "HostName");
1788c5b2abe0SLewanczyk, Dawid     }
1789c5b2abe0SLewanczyk, Dawid };
1790c5b2abe0SLewanczyk, Dawid 
1791c5b2abe0SLewanczyk, Dawid /**
1792cc340dd9SEd Tanous  * SystemActionsReset class supports handle POST method for Reset action.
1793cc340dd9SEd Tanous  * The class retrieves and sends data directly to D-Bus.
1794cc340dd9SEd Tanous  */
1795cc340dd9SEd Tanous class SystemActionsReset : public Node
1796cc340dd9SEd Tanous {
1797cc340dd9SEd Tanous   public:
179852cc112dSEd Tanous     SystemActionsReset(App& app) :
1799029573d4SEd Tanous         Node(app, "/redfish/v1/Systems/system/Actions/ComputerSystem.Reset/")
1800cc340dd9SEd Tanous     {
1801cc340dd9SEd Tanous         entityPrivileges = {
1802cc340dd9SEd Tanous             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
1803cc340dd9SEd Tanous     }
1804cc340dd9SEd Tanous 
1805cc340dd9SEd Tanous   private:
1806cc340dd9SEd Tanous     /**
1807cc340dd9SEd Tanous      * Function handles POST method request.
1808cc340dd9SEd Tanous      * Analyzes POST body message before sends Reset request data to D-Bus.
1809cc340dd9SEd Tanous      */
1810cc340dd9SEd Tanous     void doPost(crow::Response& res, const crow::Request& req,
1811cb13a392SEd Tanous                 const std::vector<std::string>&) override
1812cc340dd9SEd Tanous     {
1813cc340dd9SEd Tanous         auto asyncResp = std::make_shared<AsyncResp>(res);
1814cc340dd9SEd Tanous 
18159712f8acSEd Tanous         std::string resetType;
18169712f8acSEd Tanous         if (!json_util::readJson(req, res, "ResetType", resetType))
1817cc340dd9SEd Tanous         {
1818cc340dd9SEd Tanous             return;
1819cc340dd9SEd Tanous         }
1820cc340dd9SEd Tanous 
1821d22c8396SJason M. Bills         // Get the command and host vs. chassis
1822cc340dd9SEd Tanous         std::string command;
1823d22c8396SJason M. Bills         bool hostCommand;
1824d4d25793SEd Tanous         if ((resetType == "On") || (resetType == "ForceOn"))
1825cc340dd9SEd Tanous         {
1826cc340dd9SEd Tanous             command = "xyz.openbmc_project.State.Host.Transition.On";
1827d22c8396SJason M. Bills             hostCommand = true;
1828d22c8396SJason M. Bills         }
1829d22c8396SJason M. Bills         else if (resetType == "ForceOff")
1830d22c8396SJason M. Bills         {
1831d22c8396SJason M. Bills             command = "xyz.openbmc_project.State.Chassis.Transition.Off";
1832d22c8396SJason M. Bills             hostCommand = false;
1833d22c8396SJason M. Bills         }
1834d22c8396SJason M. Bills         else if (resetType == "ForceRestart")
1835d22c8396SJason M. Bills         {
183686a0851aSJason M. Bills             command =
183786a0851aSJason M. Bills                 "xyz.openbmc_project.State.Host.Transition.ForceWarmReboot";
183886a0851aSJason M. Bills             hostCommand = true;
1839cc340dd9SEd Tanous         }
18409712f8acSEd Tanous         else if (resetType == "GracefulShutdown")
1841cc340dd9SEd Tanous         {
1842cc340dd9SEd Tanous             command = "xyz.openbmc_project.State.Host.Transition.Off";
1843d22c8396SJason M. Bills             hostCommand = true;
1844cc340dd9SEd Tanous         }
18459712f8acSEd Tanous         else if (resetType == "GracefulRestart")
1846cc340dd9SEd Tanous         {
184786a0851aSJason M. Bills             command =
184886a0851aSJason M. Bills                 "xyz.openbmc_project.State.Host.Transition.GracefulWarmReboot";
1849d22c8396SJason M. Bills             hostCommand = true;
1850d22c8396SJason M. Bills         }
1851d22c8396SJason M. Bills         else if (resetType == "PowerCycle")
1852d22c8396SJason M. Bills         {
185386a0851aSJason M. Bills             command = "xyz.openbmc_project.State.Host.Transition.Reboot";
185486a0851aSJason M. Bills             hostCommand = true;
1855cc340dd9SEd Tanous         }
1856bfd5b826SLakshminarayana R. Kammath         else if (resetType == "Nmi")
1857bfd5b826SLakshminarayana R. Kammath         {
1858bfd5b826SLakshminarayana R. Kammath             doNMI(asyncResp);
1859bfd5b826SLakshminarayana R. Kammath             return;
1860bfd5b826SLakshminarayana R. Kammath         }
1861cc340dd9SEd Tanous         else
1862cc340dd9SEd Tanous         {
1863f12894f8SJason M. Bills             messages::actionParameterUnknown(res, "Reset", resetType);
1864cc340dd9SEd Tanous             return;
1865cc340dd9SEd Tanous         }
1866cc340dd9SEd Tanous 
1867d22c8396SJason M. Bills         if (hostCommand)
1868d22c8396SJason M. Bills         {
1869cc340dd9SEd Tanous             crow::connections::systemBus->async_method_call(
1870d22c8396SJason M. Bills                 [asyncResp, resetType](const boost::system::error_code ec) {
1871cc340dd9SEd Tanous                     if (ec)
1872cc340dd9SEd Tanous                     {
1873cc340dd9SEd Tanous                         BMCWEB_LOG_ERROR << "D-Bus responses error: " << ec;
1874d22c8396SJason M. Bills                         if (ec.value() == boost::asio::error::invalid_argument)
1875d22c8396SJason M. Bills                         {
1876d22c8396SJason M. Bills                             messages::actionParameterNotSupported(
1877d22c8396SJason M. Bills                                 asyncResp->res, resetType, "Reset");
1878d22c8396SJason M. Bills                         }
1879d22c8396SJason M. Bills                         else
1880d22c8396SJason M. Bills                         {
1881f12894f8SJason M. Bills                             messages::internalError(asyncResp->res);
1882d22c8396SJason M. Bills                         }
1883cc340dd9SEd Tanous                         return;
1884cc340dd9SEd Tanous                     }
1885f12894f8SJason M. Bills                     messages::success(asyncResp->res);
1886cc340dd9SEd Tanous                 },
1887cc340dd9SEd Tanous                 "xyz.openbmc_project.State.Host",
1888cc340dd9SEd Tanous                 "/xyz/openbmc_project/state/host0",
1889cc340dd9SEd Tanous                 "org.freedesktop.DBus.Properties", "Set",
18909712f8acSEd Tanous                 "xyz.openbmc_project.State.Host", "RequestedHostTransition",
1891abf2add6SEd Tanous                 std::variant<std::string>{command});
1892cc340dd9SEd Tanous         }
1893d22c8396SJason M. Bills         else
1894d22c8396SJason M. Bills         {
1895d22c8396SJason M. Bills             crow::connections::systemBus->async_method_call(
1896d22c8396SJason M. Bills                 [asyncResp, resetType](const boost::system::error_code ec) {
1897d22c8396SJason M. Bills                     if (ec)
1898d22c8396SJason M. Bills                     {
1899d22c8396SJason M. Bills                         BMCWEB_LOG_ERROR << "D-Bus responses error: " << ec;
1900d22c8396SJason M. Bills                         if (ec.value() == boost::asio::error::invalid_argument)
1901d22c8396SJason M. Bills                         {
1902d22c8396SJason M. Bills                             messages::actionParameterNotSupported(
1903d22c8396SJason M. Bills                                 asyncResp->res, resetType, "Reset");
1904d22c8396SJason M. Bills                         }
1905d22c8396SJason M. Bills                         else
1906d22c8396SJason M. Bills                         {
1907d22c8396SJason M. Bills                             messages::internalError(asyncResp->res);
1908d22c8396SJason M. Bills                         }
1909d22c8396SJason M. Bills                         return;
1910d22c8396SJason M. Bills                     }
1911d22c8396SJason M. Bills                     messages::success(asyncResp->res);
1912d22c8396SJason M. Bills                 },
1913d22c8396SJason M. Bills                 "xyz.openbmc_project.State.Chassis",
1914d22c8396SJason M. Bills                 "/xyz/openbmc_project/state/chassis0",
1915d22c8396SJason M. Bills                 "org.freedesktop.DBus.Properties", "Set",
1916d22c8396SJason M. Bills                 "xyz.openbmc_project.State.Chassis", "RequestedPowerTransition",
1917d22c8396SJason M. Bills                 std::variant<std::string>{command});
1918d22c8396SJason M. Bills         }
1919d22c8396SJason M. Bills     }
1920bfd5b826SLakshminarayana R. Kammath     /**
1921bfd5b826SLakshminarayana R. Kammath      * Function transceives data with dbus directly.
1922bfd5b826SLakshminarayana R. Kammath      */
1923bfd5b826SLakshminarayana R. Kammath     void doNMI(const std::shared_ptr<AsyncResp>& asyncResp)
1924bfd5b826SLakshminarayana R. Kammath     {
1925bfd5b826SLakshminarayana R. Kammath         constexpr char const* serviceName =
1926bfd5b826SLakshminarayana R. Kammath             "xyz.openbmc_project.Control.Host.NMI";
1927bfd5b826SLakshminarayana R. Kammath         constexpr char const* objectPath =
1928bfd5b826SLakshminarayana R. Kammath             "/xyz/openbmc_project/control/host0/nmi";
1929bfd5b826SLakshminarayana R. Kammath         constexpr char const* interfaceName =
1930bfd5b826SLakshminarayana R. Kammath             "xyz.openbmc_project.Control.Host.NMI";
1931bfd5b826SLakshminarayana R. Kammath         constexpr char const* method = "NMI";
1932bfd5b826SLakshminarayana R. Kammath 
1933bfd5b826SLakshminarayana R. Kammath         crow::connections::systemBus->async_method_call(
1934bfd5b826SLakshminarayana R. Kammath             [asyncResp](const boost::system::error_code ec) {
1935bfd5b826SLakshminarayana R. Kammath                 if (ec)
1936bfd5b826SLakshminarayana R. Kammath                 {
1937bfd5b826SLakshminarayana R. Kammath                     BMCWEB_LOG_ERROR << " Bad D-Bus request error: " << ec;
1938bfd5b826SLakshminarayana R. Kammath                     messages::internalError(asyncResp->res);
1939bfd5b826SLakshminarayana R. Kammath                     return;
1940bfd5b826SLakshminarayana R. Kammath                 }
1941bfd5b826SLakshminarayana R. Kammath                 messages::success(asyncResp->res);
1942bfd5b826SLakshminarayana R. Kammath             },
1943bfd5b826SLakshminarayana R. Kammath             serviceName, objectPath, interfaceName, method);
1944bfd5b826SLakshminarayana R. Kammath     }
1945cc340dd9SEd Tanous };
1946cc340dd9SEd Tanous 
1947cc340dd9SEd Tanous /**
19486617338dSEd Tanous  * Systems derived class for delivering Computer Systems Schema.
1949c5b2abe0SLewanczyk, Dawid  */
19501abe55efSEd Tanous class Systems : public Node
19511abe55efSEd Tanous {
1952c5b2abe0SLewanczyk, Dawid   public:
1953c5b2abe0SLewanczyk, Dawid     /*
1954c5b2abe0SLewanczyk, Dawid      * Default Constructor
1955c5b2abe0SLewanczyk, Dawid      */
195652cc112dSEd Tanous     Systems(App& app) : Node(app, "/redfish/v1/Systems/system/")
19571abe55efSEd Tanous     {
1958c5b2abe0SLewanczyk, Dawid         entityPrivileges = {
1959c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::get, {{"Login"}}},
1960c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::head, {{"Login"}}},
1961c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::patch, {{"ConfigureComponents"}}},
1962c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::put, {{"ConfigureComponents"}}},
1963c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}},
1964c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
1965c5b2abe0SLewanczyk, Dawid     }
1966c5b2abe0SLewanczyk, Dawid 
1967c5b2abe0SLewanczyk, Dawid   private:
1968c5b2abe0SLewanczyk, Dawid     /**
1969c5b2abe0SLewanczyk, Dawid      * Functions triggers appropriate requests on DBus
1970c5b2abe0SLewanczyk, Dawid      */
1971cb13a392SEd Tanous     void doGet(crow::Response& res, const crow::Request&,
1972cb13a392SEd Tanous                const std::vector<std::string>&) override
19731abe55efSEd Tanous     {
19749f8bfa7cSGunnar Mills         res.jsonValue["@odata.type"] = "#ComputerSystem.v1_13_0.ComputerSystem";
1975450a25cbSGunnar Mills         res.jsonValue["Name"] = "system";
1976029573d4SEd Tanous         res.jsonValue["Id"] = "system";
19770f74e643SEd Tanous         res.jsonValue["SystemType"] = "Physical";
19780f74e643SEd Tanous         res.jsonValue["Description"] = "Computer System";
19790f74e643SEd Tanous         res.jsonValue["ProcessorSummary"]["Count"] = 0;
19800f74e643SEd Tanous         res.jsonValue["ProcessorSummary"]["Status"]["State"] = "Disabled";
19815fd7ba65SCheng C Yang         res.jsonValue["MemorySummary"]["TotalSystemMemoryGiB"] = uint64_t(0);
19820f74e643SEd Tanous         res.jsonValue["MemorySummary"]["Status"]["State"] = "Disabled";
1983029573d4SEd Tanous         res.jsonValue["@odata.id"] = "/redfish/v1/Systems/system";
198404a258f4SEd Tanous 
1985443c2934SRapkiewicz, Pawel         res.jsonValue["Processors"] = {
1986029573d4SEd Tanous             {"@odata.id", "/redfish/v1/Systems/system/Processors"}};
1987443c2934SRapkiewicz, Pawel         res.jsonValue["Memory"] = {
1988029573d4SEd Tanous             {"@odata.id", "/redfish/v1/Systems/system/Memory"}};
1989a25aeccfSNikhil Potade         res.jsonValue["Storage"] = {
1990a25aeccfSNikhil Potade             {"@odata.id", "/redfish/v1/Systems/system/Storage"}};
1991029573d4SEd Tanous 
1992cc340dd9SEd Tanous         res.jsonValue["Actions"]["#ComputerSystem.Reset"] = {
1993cc340dd9SEd Tanous             {"target",
1994029573d4SEd Tanous              "/redfish/v1/Systems/system/Actions/ComputerSystem.Reset"},
19951cb1a9e6SAppaRao Puli             {"@Redfish.ActionInfo",
19961cb1a9e6SAppaRao Puli              "/redfish/v1/Systems/system/ResetActionInfo"}};
1997c5b2abe0SLewanczyk, Dawid 
1998c4bf6374SJason M. Bills         res.jsonValue["LogServices"] = {
1999029573d4SEd Tanous             {"@odata.id", "/redfish/v1/Systems/system/LogServices"}};
2000c4bf6374SJason M. Bills 
2001d82a3acdSCarol Wang         res.jsonValue["Bios"] = {
2002d82a3acdSCarol Wang             {"@odata.id", "/redfish/v1/Systems/system/Bios"}};
2003d82a3acdSCarol Wang 
2004c5d03ff4SJennifer Lee         res.jsonValue["Links"]["ManagedBy"] = {
2005c5d03ff4SJennifer Lee             {{"@odata.id", "/redfish/v1/Managers/bmc"}}};
2006c5d03ff4SJennifer Lee 
2007c5d03ff4SJennifer Lee         res.jsonValue["Status"] = {
2008c5d03ff4SJennifer Lee             {"Health", "OK"},
2009c5d03ff4SJennifer Lee             {"State", "Enabled"},
2010c5d03ff4SJennifer Lee         };
2011a0803efaSEd Tanous         auto asyncResp = std::make_shared<AsyncResp>(res);
2012c5b2abe0SLewanczyk, Dawid 
2013e284a7c1SJames Feist         constexpr const std::array<const char*, 4> inventoryForSystems = {
2014b49ac873SJames Feist             "xyz.openbmc_project.Inventory.Item.Dimm",
20152ad9c2f6SJames Feist             "xyz.openbmc_project.Inventory.Item.Cpu",
2016e284a7c1SJames Feist             "xyz.openbmc_project.Inventory.Item.Drive",
2017e284a7c1SJames Feist             "xyz.openbmc_project.Inventory.Item.StorageController"};
2018b49ac873SJames Feist 
2019b49ac873SJames Feist         auto health = std::make_shared<HealthPopulate>(asyncResp);
2020b49ac873SJames Feist         crow::connections::systemBus->async_method_call(
2021b49ac873SJames Feist             [health](const boost::system::error_code ec,
2022b49ac873SJames Feist                      std::vector<std::string>& resp) {
2023b49ac873SJames Feist                 if (ec)
2024b49ac873SJames Feist                 {
2025b49ac873SJames Feist                     // no inventory
2026b49ac873SJames Feist                     return;
2027b49ac873SJames Feist                 }
2028b49ac873SJames Feist 
2029b49ac873SJames Feist                 health->inventory = std::move(resp);
2030b49ac873SJames Feist             },
2031b49ac873SJames Feist             "xyz.openbmc_project.ObjectMapper",
2032b49ac873SJames Feist             "/xyz/openbmc_project/object_mapper",
2033b49ac873SJames Feist             "xyz.openbmc_project.ObjectMapper", "GetSubTreePaths", "/",
2034b49ac873SJames Feist             int32_t(0), inventoryForSystems);
2035b49ac873SJames Feist 
2036b49ac873SJames Feist         health->populate();
2037b49ac873SJames Feist 
2038c5d03ff4SJennifer Lee         getMainChassisId(asyncResp, [](const std::string& chassisId,
2039b5a76932SEd Tanous                                        const std::shared_ptr<AsyncResp>& aRsp) {
2040c5d03ff4SJennifer Lee             aRsp->res.jsonValue["Links"]["Chassis"] = {
2041c5d03ff4SJennifer Lee                 {{"@odata.id", "/redfish/v1/Chassis/" + chassisId}}};
2042c5d03ff4SJennifer Lee         });
2043a3002228SAppaRao Puli 
20449f8bfa7cSGunnar Mills         getLocationIndicatorActive(asyncResp);
20459f8bfa7cSGunnar Mills         // TODO (Gunnar): Remove IndicatorLED after enough time has passed
2046a3002228SAppaRao Puli         getIndicatorLedState(asyncResp);
20475bc2dc8eSJames Feist         getComputerSystem(asyncResp, health);
20486c34de48SEd Tanous         getHostState(asyncResp);
2049491d8ee7SSantosh Puranik         getBootProperties(asyncResp);
2050adbe192aSJason M. Bills         getPCIeDeviceList(asyncResp, "PCIeDevices");
205151709ffdSYong Li         getHostWatchdogTimer(asyncResp);
2052c6a620f2SGeorge Liu         getPowerRestorePolicy(asyncResp);
20536bd5a8d2SGunnar Mills         getAutomaticRetry(asyncResp);
2054c0557e1aSGunnar Mills         getLastResetTime(asyncResp);
2055a6349918SAppaRao Puli #ifdef BMCWEB_ENABLE_REDFISH_PROVISIONING_FEATURE
2056a6349918SAppaRao Puli         getProvisioningStatus(asyncResp);
2057a6349918SAppaRao Puli #endif
2058c5b2abe0SLewanczyk, Dawid     }
2059c5b2abe0SLewanczyk, Dawid 
206055c7b7a2SEd Tanous     void doPatch(crow::Response& res, const crow::Request& req,
2061cb13a392SEd Tanous                  const std::vector<std::string>&) override
20621abe55efSEd Tanous     {
20639f8bfa7cSGunnar Mills         std::optional<bool> locationIndicatorActive;
2064cde19e5fSSantosh Puranik         std::optional<std::string> indicatorLed;
2065491d8ee7SSantosh Puranik         std::optional<nlohmann::json> bootProps;
2066c45f0082SYong Li         std::optional<nlohmann::json> wdtTimerProps;
206798e386ecSGunnar Mills         std::optional<std::string> assetTag;
2068c6a620f2SGeorge Liu         std::optional<std::string> powerRestorePolicy;
206941352c24SSantosh Puranik         auto asyncResp = std::make_shared<AsyncResp>(res);
207041352c24SSantosh Puranik 
20719f8bfa7cSGunnar Mills         if (!json_util::readJson(
20729f8bfa7cSGunnar Mills                 req, res, "IndicatorLED", indicatorLed,
20739f8bfa7cSGunnar Mills                 "LocationIndicatorActive", locationIndicatorActive, "Boot",
20749f8bfa7cSGunnar Mills                 bootProps, "WatchdogTimer", wdtTimerProps, "PowerRestorePolicy",
20759f8bfa7cSGunnar Mills                 powerRestorePolicy, "AssetTag", assetTag))
20766617338dSEd Tanous         {
20776617338dSEd Tanous             return;
20786617338dSEd Tanous         }
2079491d8ee7SSantosh Puranik 
2080944ffaf9SJohnathan Mantey         res.result(boost::beast::http::status::no_content);
2081c45f0082SYong Li 
208298e386ecSGunnar Mills         if (assetTag)
208398e386ecSGunnar Mills         {
208498e386ecSGunnar Mills             setAssetTag(asyncResp, *assetTag);
208598e386ecSGunnar Mills         }
208698e386ecSGunnar Mills 
2087c45f0082SYong Li         if (wdtTimerProps)
2088c45f0082SYong Li         {
2089c45f0082SYong Li             std::optional<bool> wdtEnable;
2090c45f0082SYong Li             std::optional<std::string> wdtTimeOutAction;
2091c45f0082SYong Li 
2092c45f0082SYong Li             if (!json_util::readJson(*wdtTimerProps, asyncResp->res,
2093c45f0082SYong Li                                      "FunctionEnabled", wdtEnable,
2094c45f0082SYong Li                                      "TimeoutAction", wdtTimeOutAction))
2095c45f0082SYong Li             {
2096c45f0082SYong Li                 return;
2097c45f0082SYong Li             }
2098f23b7296SEd Tanous             setWDTProperties(asyncResp, wdtEnable, wdtTimeOutAction);
2099c45f0082SYong Li         }
2100c45f0082SYong Li 
2101491d8ee7SSantosh Puranik         if (bootProps)
2102491d8ee7SSantosh Puranik         {
2103491d8ee7SSantosh Puranik             std::optional<std::string> bootSource;
2104491d8ee7SSantosh Puranik             std::optional<std::string> bootEnable;
210569f35306SGunnar Mills             std::optional<std::string> automaticRetryConfig;
2106491d8ee7SSantosh Puranik 
210769f35306SGunnar Mills             if (!json_util::readJson(
210869f35306SGunnar Mills                     *bootProps, asyncResp->res, "BootSourceOverrideTarget",
210969f35306SGunnar Mills                     bootSource, "BootSourceOverrideEnabled", bootEnable,
211069f35306SGunnar Mills                     "AutomaticRetryConfig", automaticRetryConfig))
2111491d8ee7SSantosh Puranik             {
2112491d8ee7SSantosh Puranik                 return;
2113491d8ee7SSantosh Puranik             }
211469f35306SGunnar Mills             if (bootSource || bootEnable)
211569f35306SGunnar Mills             {
211669f35306SGunnar Mills                 setBootSourceProperties(asyncResp, std::move(bootSource),
2117491d8ee7SSantosh Puranik                                         std::move(bootEnable));
2118491d8ee7SSantosh Puranik             }
211969f35306SGunnar Mills             if (automaticRetryConfig)
212069f35306SGunnar Mills             {
2121f23b7296SEd Tanous                 setAutomaticRetry(asyncResp, *automaticRetryConfig);
212269f35306SGunnar Mills             }
212369f35306SGunnar Mills         }
2124265c1602SJohnathan Mantey 
21259f8bfa7cSGunnar Mills         if (locationIndicatorActive)
21269f8bfa7cSGunnar Mills         {
21279f8bfa7cSGunnar Mills             setLocationIndicatorActive(asyncResp, *locationIndicatorActive);
21289f8bfa7cSGunnar Mills         }
21299f8bfa7cSGunnar Mills 
21309f8bfa7cSGunnar Mills         // TODO (Gunnar): Remove IndicatorLED after enough time has passed
21319712f8acSEd Tanous         if (indicatorLed)
21326617338dSEd Tanous         {
2133f23b7296SEd Tanous             setIndicatorLedState(asyncResp, *indicatorLed);
21346617338dSEd Tanous         }
2135c6a620f2SGeorge Liu 
2136c6a620f2SGeorge Liu         if (powerRestorePolicy)
2137c6a620f2SGeorge Liu         {
2138c6a620f2SGeorge Liu             setPowerRestorePolicy(asyncResp, std::move(*powerRestorePolicy));
2139c6a620f2SGeorge Liu         }
2140c5b2abe0SLewanczyk, Dawid     }
2141c5b2abe0SLewanczyk, Dawid };
21421cb1a9e6SAppaRao Puli 
21431cb1a9e6SAppaRao Puli /**
21441cb1a9e6SAppaRao Puli  * SystemResetActionInfo derived class for delivering Computer Systems
21451cb1a9e6SAppaRao Puli  * ResetType AllowableValues using ResetInfo schema.
21461cb1a9e6SAppaRao Puli  */
21471cb1a9e6SAppaRao Puli class SystemResetActionInfo : public Node
21481cb1a9e6SAppaRao Puli {
21491cb1a9e6SAppaRao Puli   public:
21501cb1a9e6SAppaRao Puli     /*
21511cb1a9e6SAppaRao Puli      * Default Constructor
21521cb1a9e6SAppaRao Puli      */
215352cc112dSEd Tanous     SystemResetActionInfo(App& app) :
21541cb1a9e6SAppaRao Puli         Node(app, "/redfish/v1/Systems/system/ResetActionInfo/")
21551cb1a9e6SAppaRao Puli     {
21561cb1a9e6SAppaRao Puli         entityPrivileges = {
21571cb1a9e6SAppaRao Puli             {boost::beast::http::verb::get, {{"Login"}}},
21581cb1a9e6SAppaRao Puli             {boost::beast::http::verb::head, {{"Login"}}},
21591cb1a9e6SAppaRao Puli             {boost::beast::http::verb::patch, {{"ConfigureComponents"}}},
21601cb1a9e6SAppaRao Puli             {boost::beast::http::verb::put, {{"ConfigureComponents"}}},
21611cb1a9e6SAppaRao Puli             {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}},
21621cb1a9e6SAppaRao Puli             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
21631cb1a9e6SAppaRao Puli     }
21641cb1a9e6SAppaRao Puli 
21651cb1a9e6SAppaRao Puli   private:
21661cb1a9e6SAppaRao Puli     /**
21671cb1a9e6SAppaRao Puli      * Functions triggers appropriate requests on DBus
21681cb1a9e6SAppaRao Puli      */
2169cb13a392SEd Tanous     void doGet(crow::Response& res, const crow::Request&,
2170cb13a392SEd Tanous                const std::vector<std::string>&) override
21711cb1a9e6SAppaRao Puli     {
21721cb1a9e6SAppaRao Puli         res.jsonValue = {
21731cb1a9e6SAppaRao Puli             {"@odata.type", "#ActionInfo.v1_1_2.ActionInfo"},
21741cb1a9e6SAppaRao Puli             {"@odata.id", "/redfish/v1/Systems/system/ResetActionInfo"},
21751cb1a9e6SAppaRao Puli             {"Name", "Reset Action Info"},
21761cb1a9e6SAppaRao Puli             {"Id", "ResetActionInfo"},
21771cb1a9e6SAppaRao Puli             {"Parameters",
21781cb1a9e6SAppaRao Puli              {{{"Name", "ResetType"},
21791cb1a9e6SAppaRao Puli                {"Required", true},
21801cb1a9e6SAppaRao Puli                {"DataType", "String"},
21811cb1a9e6SAppaRao Puli                {"AllowableValues",
21821cb1a9e6SAppaRao Puli                 {"On", "ForceOff", "ForceOn", "ForceRestart", "GracefulRestart",
21831cb1a9e6SAppaRao Puli                  "GracefulShutdown", "PowerCycle", "Nmi"}}}}}};
21841cb1a9e6SAppaRao Puli         res.end();
21851cb1a9e6SAppaRao Puli     }
21861cb1a9e6SAppaRao Puli };
2187c5b2abe0SLewanczyk, Dawid } // namespace redfish
2188