xref: /openbmc/bmcweb/features/redfish/lib/systems.hpp (revision 2ad9c2f694b9a75b5f14f485ebab28bd32d0f575)
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"
19f5c9f8bdSJason M. Bills #include "pcie.hpp"
20c5d03ff4SJennifer Lee #include "redfish_util.hpp"
21c5d03ff4SJennifer Lee 
229712f8acSEd Tanous #include <boost/container/flat_map.hpp>
239712f8acSEd Tanous #include <node.hpp>
24cb7e1e7bSAndrew Geissler #include <utils/fw_utils.hpp>
25c5b2abe0SLewanczyk, Dawid #include <utils/json_utils.hpp>
26abf2add6SEd Tanous #include <variant>
27c5b2abe0SLewanczyk, Dawid 
281abe55efSEd Tanous namespace redfish
291abe55efSEd Tanous {
30c5b2abe0SLewanczyk, Dawid 
319d3ae10eSAlpana Kumari /**
329d3ae10eSAlpana Kumari  * @brief Updates the Functional State of DIMMs
339d3ae10eSAlpana Kumari  *
349d3ae10eSAlpana Kumari  * @param[in] aResp Shared pointer for completing asynchronous calls
359d3ae10eSAlpana Kumari  * @param[in] dimmState Dimm's Functional state, true/false
369d3ae10eSAlpana Kumari  *
379d3ae10eSAlpana Kumari  * @return None.
389d3ae10eSAlpana Kumari  */
399d3ae10eSAlpana Kumari void updateDimmProperties(std::shared_ptr<AsyncResp> aResp,
409d3ae10eSAlpana Kumari                           const std::variant<bool> &dimmState)
419d3ae10eSAlpana Kumari {
429d3ae10eSAlpana Kumari     const bool *isDimmFunctional = std::get_if<bool>(&dimmState);
439d3ae10eSAlpana Kumari     if (isDimmFunctional == nullptr)
449d3ae10eSAlpana Kumari     {
459d3ae10eSAlpana Kumari         messages::internalError(aResp->res);
469d3ae10eSAlpana Kumari         return;
479d3ae10eSAlpana Kumari     }
489d3ae10eSAlpana Kumari     BMCWEB_LOG_DEBUG << "Dimm Functional: " << *isDimmFunctional;
499d3ae10eSAlpana Kumari 
509d3ae10eSAlpana Kumari     // Set it as Enabled if atleast one DIMM is functional
519d3ae10eSAlpana Kumari     // Update STATE only if previous State was DISABLED and current Dimm is
529d3ae10eSAlpana Kumari     // ENABLED.
539d3ae10eSAlpana Kumari     nlohmann::json &prevMemSummary =
549d3ae10eSAlpana Kumari         aResp->res.jsonValue["MemorySummary"]["Status"]["State"];
559d3ae10eSAlpana Kumari     if (prevMemSummary == "Disabled")
569d3ae10eSAlpana Kumari     {
579d3ae10eSAlpana Kumari         if (*isDimmFunctional == true)
589d3ae10eSAlpana Kumari         {
599d3ae10eSAlpana Kumari             aResp->res.jsonValue["MemorySummary"]["Status"]["State"] =
609d3ae10eSAlpana Kumari                 "Enabled";
619d3ae10eSAlpana Kumari         }
629d3ae10eSAlpana Kumari     }
639d3ae10eSAlpana Kumari }
649d3ae10eSAlpana Kumari 
6557e8c9beSAlpana Kumari /*
6657e8c9beSAlpana Kumari  * @brief Update "ProcessorSummary" "Count" based on Cpu PresenceState
6757e8c9beSAlpana Kumari  *
6857e8c9beSAlpana Kumari  * @param[in] aResp Shared pointer for completing asynchronous calls
6957e8c9beSAlpana Kumari  * @param[in] cpuPresenceState CPU present or not
7057e8c9beSAlpana Kumari  *
7157e8c9beSAlpana Kumari  * @return None.
7257e8c9beSAlpana Kumari  */
7357e8c9beSAlpana Kumari void modifyCpuPresenceState(std::shared_ptr<AsyncResp> aResp,
7457e8c9beSAlpana Kumari                             const std::variant<bool> &cpuPresenceState)
7557e8c9beSAlpana Kumari {
7657e8c9beSAlpana Kumari     const bool *isCpuPresent = std::get_if<bool>(&cpuPresenceState);
7757e8c9beSAlpana Kumari 
7857e8c9beSAlpana Kumari     if (isCpuPresent == nullptr)
7957e8c9beSAlpana Kumari     {
8057e8c9beSAlpana Kumari         messages::internalError(aResp->res);
8157e8c9beSAlpana Kumari         return;
8257e8c9beSAlpana Kumari     }
8357e8c9beSAlpana Kumari     BMCWEB_LOG_DEBUG << "Cpu Present: " << *isCpuPresent;
8457e8c9beSAlpana Kumari 
8557e8c9beSAlpana Kumari     nlohmann::json &procCount =
8657e8c9beSAlpana Kumari         aResp->res.jsonValue["ProcessorSummary"]["Count"];
8757e8c9beSAlpana Kumari     if (*isCpuPresent == true)
8857e8c9beSAlpana Kumari     {
8957e8c9beSAlpana Kumari         procCount = procCount.get<int>() + 1;
9057e8c9beSAlpana Kumari     }
9157e8c9beSAlpana Kumari     aResp->res.jsonValue["ProcessorSummary"]["Count"] = procCount;
9257e8c9beSAlpana Kumari }
9357e8c9beSAlpana Kumari 
9457e8c9beSAlpana Kumari /*
9557e8c9beSAlpana Kumari  * @brief Update "ProcessorSummary" "Status" "State" based on
9657e8c9beSAlpana Kumari  *        CPU Functional State
9757e8c9beSAlpana Kumari  *
9857e8c9beSAlpana Kumari  * @param[in] aResp Shared pointer for completing asynchronous calls
9957e8c9beSAlpana Kumari  * @param[in] cpuFunctionalState is CPU functional true/false
10057e8c9beSAlpana Kumari  *
10157e8c9beSAlpana Kumari  * @return None.
10257e8c9beSAlpana Kumari  */
10357e8c9beSAlpana Kumari void modifyCpuFunctionalState(std::shared_ptr<AsyncResp> aResp,
10457e8c9beSAlpana Kumari                               const std::variant<bool> &cpuFunctionalState)
10557e8c9beSAlpana Kumari {
10657e8c9beSAlpana Kumari     const bool *isCpuFunctional = std::get_if<bool>(&cpuFunctionalState);
10757e8c9beSAlpana Kumari 
10857e8c9beSAlpana Kumari     if (isCpuFunctional == nullptr)
10957e8c9beSAlpana Kumari     {
11057e8c9beSAlpana Kumari         messages::internalError(aResp->res);
11157e8c9beSAlpana Kumari         return;
11257e8c9beSAlpana Kumari     }
11357e8c9beSAlpana Kumari     BMCWEB_LOG_DEBUG << "Cpu Functional: " << *isCpuFunctional;
11457e8c9beSAlpana Kumari 
11557e8c9beSAlpana Kumari     nlohmann::json &prevProcState =
11657e8c9beSAlpana Kumari         aResp->res.jsonValue["ProcessorSummary"]["Status"]["State"];
11757e8c9beSAlpana Kumari 
11857e8c9beSAlpana Kumari     // Set it as Enabled if atleast one CPU is functional
11957e8c9beSAlpana Kumari     // Update STATE only if previous State was Non_Functional and current CPU is
12057e8c9beSAlpana Kumari     // Functional.
12157e8c9beSAlpana Kumari     if (prevProcState == "Disabled")
12257e8c9beSAlpana Kumari     {
12357e8c9beSAlpana Kumari         if (*isCpuFunctional == true)
12457e8c9beSAlpana Kumari         {
12557e8c9beSAlpana Kumari             aResp->res.jsonValue["ProcessorSummary"]["Status"]["State"] =
12657e8c9beSAlpana Kumari                 "Enabled";
12757e8c9beSAlpana Kumari         }
12857e8c9beSAlpana Kumari     }
12957e8c9beSAlpana Kumari }
13057e8c9beSAlpana Kumari 
13157e8c9beSAlpana Kumari /*
132c5b2abe0SLewanczyk, Dawid  * @brief Retrieves computer system properties over dbus
133c5b2abe0SLewanczyk, Dawid  *
134c5b2abe0SLewanczyk, Dawid  * @param[in] aResp Shared pointer for completing asynchronous calls
135c5b2abe0SLewanczyk, Dawid  * @param[in] name  Computer system name from request
136c5b2abe0SLewanczyk, Dawid  *
137c5b2abe0SLewanczyk, Dawid  * @return None.
138c5b2abe0SLewanczyk, Dawid  */
1395bc2dc8eSJames Feist void getComputerSystem(std::shared_ptr<AsyncResp> aResp,
1405bc2dc8eSJames Feist                        std::shared_ptr<HealthPopulate> systemHealth)
1411abe55efSEd Tanous {
14255c7b7a2SEd Tanous     BMCWEB_LOG_DEBUG << "Get available system components.";
1439d3ae10eSAlpana Kumari 
14455c7b7a2SEd Tanous     crow::connections::systemBus->async_method_call(
1455bc2dc8eSJames Feist         [aResp, systemHealth](
146c5b2abe0SLewanczyk, Dawid             const boost::system::error_code ec,
147c5b2abe0SLewanczyk, Dawid             const std::vector<std::pair<
1486c34de48SEd Tanous                 std::string,
1496c34de48SEd Tanous                 std::vector<std::pair<std::string, std::vector<std::string>>>>>
150c5b2abe0SLewanczyk, Dawid                 &subtree) {
1511abe55efSEd Tanous             if (ec)
1521abe55efSEd Tanous             {
15355c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "DBUS response error";
154f12894f8SJason M. Bills                 messages::internalError(aResp->res);
155c5b2abe0SLewanczyk, Dawid                 return;
156c5b2abe0SLewanczyk, Dawid             }
157c5b2abe0SLewanczyk, Dawid             // Iterate over all retrieved ObjectPaths.
1586c34de48SEd Tanous             for (const std::pair<std::string,
1596c34de48SEd Tanous                                  std::vector<std::pair<
1606c34de48SEd Tanous                                      std::string, std::vector<std::string>>>>
1611abe55efSEd Tanous                      &object : subtree)
1621abe55efSEd Tanous             {
163c5b2abe0SLewanczyk, Dawid                 const std::string &path = object.first;
16455c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "Got path: " << path;
1651abe55efSEd Tanous                 const std::vector<
1661abe55efSEd Tanous                     std::pair<std::string, std::vector<std::string>>>
167c5b2abe0SLewanczyk, Dawid                     &connectionNames = object.second;
1681abe55efSEd Tanous                 if (connectionNames.size() < 1)
1691abe55efSEd Tanous                 {
170c5b2abe0SLewanczyk, Dawid                     continue;
171c5b2abe0SLewanczyk, Dawid                 }
172029573d4SEd Tanous 
1735bc2dc8eSJames Feist                 auto memoryHealth = std::make_shared<HealthPopulate>(
1745bc2dc8eSJames Feist                     aResp, aResp->res.jsonValue["MemorySummary"]["Status"]);
1755bc2dc8eSJames Feist 
1765bc2dc8eSJames Feist                 auto cpuHealth = std::make_shared<HealthPopulate>(
1775bc2dc8eSJames Feist                     aResp, aResp->res.jsonValue["ProcessorSummary"]["Status"]);
1785bc2dc8eSJames Feist 
1795bc2dc8eSJames Feist                 systemHealth->children.emplace_back(memoryHealth);
1805bc2dc8eSJames Feist                 systemHealth->children.emplace_back(cpuHealth);
1815bc2dc8eSJames Feist 
1826c34de48SEd Tanous                 // This is not system, so check if it's cpu, dimm, UUID or
1836c34de48SEd Tanous                 // BiosVer
18404a258f4SEd Tanous                 for (const auto &connection : connectionNames)
1851abe55efSEd Tanous                 {
18604a258f4SEd Tanous                     for (const auto &interfaceName : connection.second)
1871abe55efSEd Tanous                     {
18804a258f4SEd Tanous                         if (interfaceName ==
18904a258f4SEd Tanous                             "xyz.openbmc_project.Inventory.Item.Dimm")
1901abe55efSEd Tanous                         {
1911abe55efSEd Tanous                             BMCWEB_LOG_DEBUG
19204a258f4SEd Tanous                                 << "Found Dimm, now get its properties.";
1939d3ae10eSAlpana Kumari 
19455c7b7a2SEd Tanous                             crow::connections::systemBus->async_method_call(
1959d3ae10eSAlpana Kumari                                 [aResp, service{connection.first},
1969d3ae10eSAlpana Kumari                                  path(std::move(path))](
1979d3ae10eSAlpana Kumari                                     const boost::system::error_code ec,
1986c34de48SEd Tanous                                     const std::vector<
1996c34de48SEd Tanous                                         std::pair<std::string, VariantType>>
2001abe55efSEd Tanous                                         &properties) {
2011abe55efSEd Tanous                                     if (ec)
2021abe55efSEd Tanous                                     {
2031abe55efSEd Tanous                                         BMCWEB_LOG_ERROR
2046c34de48SEd Tanous                                             << "DBUS response error " << ec;
205f12894f8SJason M. Bills                                         messages::internalError(aResp->res);
206c5b2abe0SLewanczyk, Dawid                                         return;
207c5b2abe0SLewanczyk, Dawid                                     }
2086c34de48SEd Tanous                                     BMCWEB_LOG_DEBUG << "Got "
2096c34de48SEd Tanous                                                      << properties.size()
210c5b2abe0SLewanczyk, Dawid                                                      << " Dimm properties.";
2119d3ae10eSAlpana Kumari 
2129d3ae10eSAlpana Kumari                                     if (properties.size() > 0)
2139d3ae10eSAlpana Kumari                                     {
21404a258f4SEd Tanous                                         for (const std::pair<std::string,
21504a258f4SEd Tanous                                                              VariantType>
21604a258f4SEd Tanous                                                  &property : properties)
2171abe55efSEd Tanous                                         {
2189d3ae10eSAlpana Kumari                                             if (property.first ==
2199d3ae10eSAlpana Kumari                                                 "MemorySizeInKb")
2201abe55efSEd Tanous                                             {
22104a258f4SEd Tanous                                                 const uint64_t *value =
2229d3ae10eSAlpana Kumari                                                     sdbusplus::message::
2239d3ae10eSAlpana Kumari                                                         variant_ns::get_if<
2249d3ae10eSAlpana Kumari                                                             uint64_t>(
2251b6b96c5SEd Tanous                                                             &property.second);
22604a258f4SEd Tanous                                                 if (value != nullptr)
2271abe55efSEd Tanous                                                 {
2281abe55efSEd Tanous                                                     aResp->res.jsonValue
2296c34de48SEd Tanous                                                         ["TotalSystemMemoryGi"
2306c34de48SEd Tanous                                                          "B"] +=
23104a258f4SEd Tanous                                                         *value / (1024 * 1024);
2329d3ae10eSAlpana Kumari                                                     aResp->res.jsonValue
2339d3ae10eSAlpana Kumari                                                         ["MemorySummary"]
2349d3ae10eSAlpana Kumari                                                         ["Status"]["State"] =
2351abe55efSEd Tanous                                                         "Enabled";
236c5b2abe0SLewanczyk, Dawid                                                 }
237c5b2abe0SLewanczyk, Dawid                                             }
238c5b2abe0SLewanczyk, Dawid                                         }
2399d3ae10eSAlpana Kumari                                     }
2409d3ae10eSAlpana Kumari                                     else
2419d3ae10eSAlpana Kumari                                     {
2429d3ae10eSAlpana Kumari                                         auto getDimmProperties =
2439d3ae10eSAlpana Kumari                                             [aResp](
2449d3ae10eSAlpana Kumari                                                 const boost::system::error_code
2459d3ae10eSAlpana Kumari                                                     ec,
2469d3ae10eSAlpana Kumari                                                 const std::variant<bool>
2479d3ae10eSAlpana Kumari                                                     &dimmState) {
2489d3ae10eSAlpana Kumari                                                 if (ec)
2499d3ae10eSAlpana Kumari                                                 {
2509d3ae10eSAlpana Kumari                                                     BMCWEB_LOG_ERROR
2519d3ae10eSAlpana Kumari                                                         << "DBUS response "
2529d3ae10eSAlpana Kumari                                                            "error "
2539d3ae10eSAlpana Kumari                                                         << ec;
2549d3ae10eSAlpana Kumari                                                     return;
2559d3ae10eSAlpana Kumari                                                 }
2569d3ae10eSAlpana Kumari                                                 updateDimmProperties(aResp,
2579d3ae10eSAlpana Kumari                                                                      dimmState);
2589d3ae10eSAlpana Kumari                                             };
2599d3ae10eSAlpana Kumari                                         crow::connections::systemBus
2609d3ae10eSAlpana Kumari                                             ->async_method_call(
2619d3ae10eSAlpana Kumari                                                 std::move(getDimmProperties),
2629d3ae10eSAlpana Kumari                                                 service, path,
2639d3ae10eSAlpana Kumari                                                 "org.freedesktop.DBus."
2649d3ae10eSAlpana Kumari                                                 "Properties",
2659d3ae10eSAlpana Kumari                                                 "Get",
2669d3ae10eSAlpana Kumari                                                 "xyz.openbmc_project.State."
2679d3ae10eSAlpana Kumari                                                 "Decorator.OperationalStatus",
2689d3ae10eSAlpana Kumari                                                 "Functional");
2699d3ae10eSAlpana Kumari                                     }
270c5b2abe0SLewanczyk, Dawid                                 },
27104a258f4SEd Tanous                                 connection.first, path,
2726c34de48SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
2736c34de48SEd Tanous                                 "xyz.openbmc_project.Inventory.Item.Dimm");
2745bc2dc8eSJames Feist 
2755bc2dc8eSJames Feist                             memoryHealth->inventory.emplace_back(path);
2761abe55efSEd Tanous                         }
27704a258f4SEd Tanous                         else if (interfaceName ==
27804a258f4SEd Tanous                                  "xyz.openbmc_project.Inventory.Item.Cpu")
2791abe55efSEd Tanous                         {
2801abe55efSEd Tanous                             BMCWEB_LOG_DEBUG
28104a258f4SEd Tanous                                 << "Found Cpu, now get its properties.";
28257e8c9beSAlpana Kumari 
283a0803efaSEd Tanous                             crow::connections::systemBus->async_method_call(
28457e8c9beSAlpana Kumari                                 [aResp, service{connection.first},
28557e8c9beSAlpana Kumari                                  path(std::move(path))](
28657e8c9beSAlpana Kumari                                     const boost::system::error_code ec,
2876c34de48SEd Tanous                                     const std::vector<
2886c34de48SEd Tanous                                         std::pair<std::string, VariantType>>
2891abe55efSEd Tanous                                         &properties) {
2901abe55efSEd Tanous                                     if (ec)
2911abe55efSEd Tanous                                     {
2921abe55efSEd Tanous                                         BMCWEB_LOG_ERROR
2936c34de48SEd Tanous                                             << "DBUS response error " << ec;
294f12894f8SJason M. Bills                                         messages::internalError(aResp->res);
295c5b2abe0SLewanczyk, Dawid                                         return;
296c5b2abe0SLewanczyk, Dawid                                     }
2976c34de48SEd Tanous                                     BMCWEB_LOG_DEBUG << "Got "
2986c34de48SEd Tanous                                                      << properties.size()
299c5b2abe0SLewanczyk, Dawid                                                      << " Cpu properties.";
30057e8c9beSAlpana Kumari 
30157e8c9beSAlpana Kumari                                     if (properties.size() > 0)
30257e8c9beSAlpana Kumari                                     {
30304a258f4SEd Tanous                                         for (const auto &property : properties)
3041abe55efSEd Tanous                                         {
30557e8c9beSAlpana Kumari                                             if (property.first ==
30657e8c9beSAlpana Kumari                                                 "ProcessorFamily")
3071abe55efSEd Tanous                                             {
308a0803efaSEd Tanous                                                 const std::string *value =
30957e8c9beSAlpana Kumari                                                     sdbusplus::message::
31057e8c9beSAlpana Kumari                                                         variant_ns::get_if<
31157e8c9beSAlpana Kumari                                                             std::string>(
3121b6b96c5SEd Tanous                                                             &property.second);
3131abe55efSEd Tanous                                                 if (value != nullptr)
3141abe55efSEd Tanous                                                 {
31557e8c9beSAlpana Kumari                                                     nlohmann::json
31657e8c9beSAlpana Kumari                                                         &procSummary =
3171abe55efSEd Tanous                                                             aResp->res.jsonValue
3186c34de48SEd Tanous                                                                 ["ProcessorSumm"
31904a258f4SEd Tanous                                                                  "ary"];
32004a258f4SEd Tanous                                                     nlohmann::json &procCount =
32104a258f4SEd Tanous                                                         procSummary["Count"];
32204a258f4SEd Tanous                                                     procCount =
32357e8c9beSAlpana Kumari                                                         procCount.get<int>() +
32457e8c9beSAlpana Kumari                                                         1;
32557e8c9beSAlpana Kumari                                                     procSummary["Status"]
32657e8c9beSAlpana Kumari                                                                ["State"] =
327c5b2abe0SLewanczyk, Dawid                                                                    "Enabled";
32857e8c9beSAlpana Kumari                                                     procSummary["Model"] =
32957e8c9beSAlpana Kumari                                                         *value;
330c5b2abe0SLewanczyk, Dawid                                                 }
331c5b2abe0SLewanczyk, Dawid                                             }
332c5b2abe0SLewanczyk, Dawid                                         }
33357e8c9beSAlpana Kumari                                     }
33457e8c9beSAlpana Kumari                                     else
33557e8c9beSAlpana Kumari                                     {
33657e8c9beSAlpana Kumari                                         auto getCpuPresenceState =
33757e8c9beSAlpana Kumari                                             [aResp](
33857e8c9beSAlpana Kumari                                                 const boost::system::error_code
33957e8c9beSAlpana Kumari                                                     ec,
34057e8c9beSAlpana Kumari                                                 const std::variant<bool>
34157e8c9beSAlpana Kumari                                                     &cpuPresenceCheck) {
34257e8c9beSAlpana Kumari                                                 if (ec)
34357e8c9beSAlpana Kumari                                                 {
34457e8c9beSAlpana Kumari                                                     BMCWEB_LOG_ERROR
34557e8c9beSAlpana Kumari                                                         << "DBUS response "
34657e8c9beSAlpana Kumari                                                            "error "
34757e8c9beSAlpana Kumari                                                         << ec;
34857e8c9beSAlpana Kumari                                                     return;
34957e8c9beSAlpana Kumari                                                 }
35057e8c9beSAlpana Kumari                                                 modifyCpuPresenceState(
35157e8c9beSAlpana Kumari                                                     aResp, cpuPresenceCheck);
35257e8c9beSAlpana Kumari                                             };
35357e8c9beSAlpana Kumari 
35457e8c9beSAlpana Kumari                                         auto getCpuFunctionalState =
35557e8c9beSAlpana Kumari                                             [aResp](
35657e8c9beSAlpana Kumari                                                 const boost::system::error_code
35757e8c9beSAlpana Kumari                                                     ec,
35857e8c9beSAlpana Kumari                                                 const std::variant<bool>
35957e8c9beSAlpana Kumari                                                     &cpuFunctionalCheck) {
36057e8c9beSAlpana Kumari                                                 if (ec)
36157e8c9beSAlpana Kumari                                                 {
36257e8c9beSAlpana Kumari                                                     BMCWEB_LOG_ERROR
36357e8c9beSAlpana Kumari                                                         << "DBUS response "
36457e8c9beSAlpana Kumari                                                            "error "
36557e8c9beSAlpana Kumari                                                         << ec;
36657e8c9beSAlpana Kumari                                                     return;
36757e8c9beSAlpana Kumari                                                 }
36857e8c9beSAlpana Kumari                                                 modifyCpuFunctionalState(
36957e8c9beSAlpana Kumari                                                     aResp, cpuFunctionalCheck);
37057e8c9beSAlpana Kumari                                             };
37157e8c9beSAlpana Kumari                                         // Get the Presence of CPU
37257e8c9beSAlpana Kumari                                         crow::connections::systemBus
37357e8c9beSAlpana Kumari                                             ->async_method_call(
37457e8c9beSAlpana Kumari                                                 std::move(getCpuPresenceState),
37557e8c9beSAlpana Kumari                                                 service, path,
37657e8c9beSAlpana Kumari                                                 "org.freedesktop.DBus."
37757e8c9beSAlpana Kumari                                                 "Properties",
37857e8c9beSAlpana Kumari                                                 "Get",
37957e8c9beSAlpana Kumari                                                 "xyz.openbmc_project.Inventory."
38057e8c9beSAlpana Kumari                                                 "Item",
38157e8c9beSAlpana Kumari                                                 "Present");
38257e8c9beSAlpana Kumari 
38357e8c9beSAlpana Kumari                                         // Get the Functional State
38457e8c9beSAlpana Kumari                                         crow::connections::systemBus
38557e8c9beSAlpana Kumari                                             ->async_method_call(
38657e8c9beSAlpana Kumari                                                 std::move(
38757e8c9beSAlpana Kumari                                                     getCpuFunctionalState),
38857e8c9beSAlpana Kumari                                                 service, path,
38957e8c9beSAlpana Kumari                                                 "org.freedesktop.DBus."
39057e8c9beSAlpana Kumari                                                 "Properties",
39157e8c9beSAlpana Kumari                                                 "Get",
39257e8c9beSAlpana Kumari                                                 "xyz.openbmc_project.State."
39357e8c9beSAlpana Kumari                                                 "Decorator."
39457e8c9beSAlpana Kumari                                                 "OperationalStatus",
39557e8c9beSAlpana Kumari                                                 "Functional");
39657e8c9beSAlpana Kumari 
39757e8c9beSAlpana Kumari                                         // Get the MODEL from
39857e8c9beSAlpana Kumari                                         // xyz.openbmc_project.Inventory.Decorator.Asset
39957e8c9beSAlpana Kumari                                         // support it later as Model  is Empty
40057e8c9beSAlpana Kumari                                         // currently.
40157e8c9beSAlpana Kumari                                     }
402c5b2abe0SLewanczyk, Dawid                                 },
40304a258f4SEd Tanous                                 connection.first, path,
4046c34de48SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
4056c34de48SEd Tanous                                 "xyz.openbmc_project.Inventory.Item.Cpu");
4065bc2dc8eSJames Feist 
4075bc2dc8eSJames Feist                             cpuHealth->inventory.emplace_back(path);
4081abe55efSEd Tanous                         }
40904a258f4SEd Tanous                         else if (interfaceName ==
41004a258f4SEd Tanous                                  "xyz.openbmc_project.Common.UUID")
4111abe55efSEd Tanous                         {
4121abe55efSEd Tanous                             BMCWEB_LOG_DEBUG
41304a258f4SEd Tanous                                 << "Found UUID, now get its properties.";
41455c7b7a2SEd Tanous                             crow::connections::systemBus->async_method_call(
415029573d4SEd Tanous                                 [aResp](const boost::system::error_code ec,
4166c34de48SEd Tanous                                         const std::vector<
4176c34de48SEd Tanous                                             std::pair<std::string, VariantType>>
4181abe55efSEd Tanous                                             &properties) {
4191abe55efSEd Tanous                                     if (ec)
4201abe55efSEd Tanous                                     {
4211abe55efSEd Tanous                                         BMCWEB_LOG_DEBUG
4226c34de48SEd Tanous                                             << "DBUS response error " << ec;
423f12894f8SJason M. Bills                                         messages::internalError(aResp->res);
424c5b2abe0SLewanczyk, Dawid                                         return;
425c5b2abe0SLewanczyk, Dawid                                     }
4266c34de48SEd Tanous                                     BMCWEB_LOG_DEBUG << "Got "
4276c34de48SEd Tanous                                                      << properties.size()
428c5b2abe0SLewanczyk, Dawid                                                      << " UUID properties.";
4291abe55efSEd Tanous                                     for (const std::pair<std::string,
43004a258f4SEd Tanous                                                          VariantType>
43104a258f4SEd Tanous                                              &property : properties)
4321abe55efSEd Tanous                                     {
43304a258f4SEd Tanous                                         if (property.first == "UUID")
4341abe55efSEd Tanous                                         {
435c5b2abe0SLewanczyk, Dawid                                             const std::string *value =
436029573d4SEd Tanous                                                 sdbusplus::message::variant_ns::
437029573d4SEd Tanous                                                     get_if<std::string>(
4381b6b96c5SEd Tanous                                                         &property.second);
43904a258f4SEd Tanous 
4401abe55efSEd Tanous                                             if (value != nullptr)
4411abe55efSEd Tanous                                             {
442029573d4SEd Tanous                                                 std::string valueStr = *value;
44304a258f4SEd Tanous                                                 if (valueStr.size() == 32)
4441abe55efSEd Tanous                                                 {
445029573d4SEd Tanous                                                     valueStr.insert(8, 1, '-');
446029573d4SEd Tanous                                                     valueStr.insert(13, 1, '-');
447029573d4SEd Tanous                                                     valueStr.insert(18, 1, '-');
448029573d4SEd Tanous                                                     valueStr.insert(23, 1, '-');
44904a258f4SEd Tanous                                                 }
450029573d4SEd Tanous                                                 BMCWEB_LOG_DEBUG << "UUID = "
45104a258f4SEd Tanous                                                                  << valueStr;
452029573d4SEd Tanous                                                 aResp->res.jsonValue["UUID"] =
45304a258f4SEd Tanous                                                     valueStr;
454c5b2abe0SLewanczyk, Dawid                                             }
455c5b2abe0SLewanczyk, Dawid                                         }
456c5b2abe0SLewanczyk, Dawid                                     }
457c5b2abe0SLewanczyk, Dawid                                 },
45804a258f4SEd Tanous                                 connection.first, path,
4596c34de48SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
4601abe55efSEd Tanous                                 "xyz.openbmc_project.Common.UUID");
461c5b2abe0SLewanczyk, Dawid                         }
462029573d4SEd Tanous                         else if (interfaceName ==
463029573d4SEd Tanous                                  "xyz.openbmc_project.Inventory.Item.System")
4641abe55efSEd Tanous                         {
465029573d4SEd Tanous                             crow::connections::systemBus->async_method_call(
466029573d4SEd Tanous                                 [aResp](const boost::system::error_code ec,
467029573d4SEd Tanous                                         const std::vector<
468029573d4SEd Tanous                                             std::pair<std::string, VariantType>>
469029573d4SEd Tanous                                             &propertiesList) {
470029573d4SEd Tanous                                     if (ec)
471029573d4SEd Tanous                                     {
472e4a4b9a9SJames Feist                                         // doesn't have to include this
473e4a4b9a9SJames Feist                                         // interface
474029573d4SEd Tanous                                         return;
475029573d4SEd Tanous                                     }
476698654b6SGunnar Mills                                     BMCWEB_LOG_DEBUG
477698654b6SGunnar Mills                                         << "Got " << propertiesList.size()
478029573d4SEd Tanous                                         << " properties for system";
479029573d4SEd Tanous                                     for (const std::pair<std::string,
480029573d4SEd Tanous                                                          VariantType>
481029573d4SEd Tanous                                              &property : propertiesList)
482029573d4SEd Tanous                                     {
483fc5afcf9Sbeccabroek                                         const std::string &propertyName =
484fc5afcf9Sbeccabroek                                             property.first;
485fc5afcf9Sbeccabroek                                         if ((propertyName == "PartNumber") ||
486fc5afcf9Sbeccabroek                                             (propertyName == "SerialNumber") ||
487fc5afcf9Sbeccabroek                                             (propertyName == "Manufacturer") ||
488fc5afcf9Sbeccabroek                                             (propertyName == "Model"))
489fc5afcf9Sbeccabroek                                         {
490029573d4SEd Tanous                                             const std::string *value =
491fc5afcf9Sbeccabroek                                                 std::get_if<std::string>(
492029573d4SEd Tanous                                                     &property.second);
493029573d4SEd Tanous                                             if (value != nullptr)
494029573d4SEd Tanous                                             {
495029573d4SEd Tanous                                                 aResp->res
496fc5afcf9Sbeccabroek                                                     .jsonValue[propertyName] =
497029573d4SEd Tanous                                                     *value;
498029573d4SEd Tanous                                             }
499029573d4SEd Tanous                                         }
500fc5afcf9Sbeccabroek                                     }
501029573d4SEd Tanous                                     aResp->res.jsonValue["Name"] = "system";
502029573d4SEd Tanous                                     aResp->res.jsonValue["Id"] =
503029573d4SEd Tanous                                         aResp->res.jsonValue["SerialNumber"];
504cb7e1e7bSAndrew Geissler                                     // Grab the bios version
505cb7e1e7bSAndrew Geissler                                     fw_util::getActiveFwVersion(
506cb7e1e7bSAndrew Geissler                                         aResp, fw_util::biosPurpose,
507cb7e1e7bSAndrew Geissler                                         "BiosVersion");
508029573d4SEd Tanous                                 },
509029573d4SEd Tanous                                 connection.first, path,
510029573d4SEd Tanous                                 "org.freedesktop.DBus.Properties", "GetAll",
511029573d4SEd Tanous                                 "xyz.openbmc_project.Inventory.Decorator."
512029573d4SEd Tanous                                 "Asset");
513e4a4b9a9SJames Feist 
514e4a4b9a9SJames Feist                             crow::connections::systemBus->async_method_call(
515e4a4b9a9SJames Feist                                 [aResp](
516e4a4b9a9SJames Feist                                     const boost::system::error_code ec,
517e4a4b9a9SJames Feist                                     const std::variant<std::string> &property) {
518e4a4b9a9SJames Feist                                     if (ec)
519e4a4b9a9SJames Feist                                     {
520e4a4b9a9SJames Feist                                         // doesn't have to include this
521e4a4b9a9SJames Feist                                         // interface
522e4a4b9a9SJames Feist                                         return;
523e4a4b9a9SJames Feist                                     }
524e4a4b9a9SJames Feist 
525e4a4b9a9SJames Feist                                     const std::string *value =
526e4a4b9a9SJames Feist                                         std::get_if<std::string>(&property);
527e4a4b9a9SJames Feist                                     if (value != nullptr)
528e4a4b9a9SJames Feist                                     {
529e4a4b9a9SJames Feist                                         aResp->res.jsonValue["AssetTag"] =
530e4a4b9a9SJames Feist                                             *value;
531e4a4b9a9SJames Feist                                     }
532e4a4b9a9SJames Feist                                 },
533e4a4b9a9SJames Feist                                 connection.first, path,
534e4a4b9a9SJames Feist                                 "org.freedesktop.DBus.Properties", "Get",
535e4a4b9a9SJames Feist                                 "xyz.openbmc_project.Inventory.Decorator."
536e4a4b9a9SJames Feist                                 "AssetTag",
537e4a4b9a9SJames Feist                                 "AssetTag");
538029573d4SEd Tanous                         }
539029573d4SEd Tanous                     }
540029573d4SEd Tanous                 }
541c5b2abe0SLewanczyk, Dawid             }
542c5b2abe0SLewanczyk, Dawid         },
543c5b2abe0SLewanczyk, Dawid         "xyz.openbmc_project.ObjectMapper",
544c5b2abe0SLewanczyk, Dawid         "/xyz/openbmc_project/object_mapper",
545c5b2abe0SLewanczyk, Dawid         "xyz.openbmc_project.ObjectMapper", "GetSubTree",
5466617338dSEd Tanous         "/xyz/openbmc_project/inventory", int32_t(0),
5476617338dSEd Tanous         std::array<const char *, 5>{
5486617338dSEd Tanous             "xyz.openbmc_project.Inventory.Decorator.Asset",
5496617338dSEd Tanous             "xyz.openbmc_project.Inventory.Item.Cpu",
5506617338dSEd Tanous             "xyz.openbmc_project.Inventory.Item.Dimm",
5516617338dSEd Tanous             "xyz.openbmc_project.Inventory.Item.System",
5526617338dSEd Tanous             "xyz.openbmc_project.Common.UUID",
5536617338dSEd Tanous         });
554c5b2abe0SLewanczyk, Dawid }
555c5b2abe0SLewanczyk, Dawid 
556c5b2abe0SLewanczyk, Dawid /**
557c5b2abe0SLewanczyk, Dawid  * @brief Retrieves identify led group properties over dbus
558c5b2abe0SLewanczyk, Dawid  *
559491d8ee7SSantosh Puranik  * @param[in] aResp     Shared pointer for generating response message.
560c5b2abe0SLewanczyk, Dawid  * @param[in] callback  Callback for process retrieved data.
561c5b2abe0SLewanczyk, Dawid  *
562c5b2abe0SLewanczyk, Dawid  * @return None.
563c5b2abe0SLewanczyk, Dawid  */
564c5b2abe0SLewanczyk, Dawid template <typename CallbackFunc>
565a0803efaSEd Tanous void getLedGroupIdentify(std::shared_ptr<AsyncResp> aResp,
5661abe55efSEd Tanous                          CallbackFunc &&callback)
5671abe55efSEd Tanous {
56855c7b7a2SEd Tanous     BMCWEB_LOG_DEBUG << "Get led groups";
56955c7b7a2SEd Tanous     crow::connections::systemBus->async_method_call(
570c5d03ff4SJennifer Lee         [aResp,
5716617338dSEd Tanous          callback{std::move(callback)}](const boost::system::error_code &ec,
5721abe55efSEd Tanous                                         const ManagedObjectsType &resp) {
5731abe55efSEd Tanous             if (ec)
5741abe55efSEd Tanous             {
57555c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
576f12894f8SJason M. Bills                 messages::internalError(aResp->res);
577c5b2abe0SLewanczyk, Dawid                 return;
578c5b2abe0SLewanczyk, Dawid             }
5796c34de48SEd Tanous             BMCWEB_LOG_DEBUG << "Got " << resp.size() << " led group objects.";
5801abe55efSEd Tanous             for (const auto &objPath : resp)
5811abe55efSEd Tanous             {
582c5b2abe0SLewanczyk, Dawid                 const std::string &path = objPath.first;
5831abe55efSEd Tanous                 if (path.rfind("enclosure_identify") != std::string::npos)
5841abe55efSEd Tanous                 {
5851abe55efSEd Tanous                     for (const auto &interface : objPath.second)
5861abe55efSEd Tanous                     {
5876c34de48SEd Tanous                         if (interface.first == "xyz.openbmc_project.Led.Group")
5881abe55efSEd Tanous                         {
5891abe55efSEd Tanous                             for (const auto &property : interface.second)
5901abe55efSEd Tanous                             {
5911abe55efSEd Tanous                                 if (property.first == "Asserted")
5921abe55efSEd Tanous                                 {
593c5b2abe0SLewanczyk, Dawid                                     const bool *asserted =
594abf2add6SEd Tanous                                         std::get_if<bool>(&property.second);
5951abe55efSEd Tanous                                     if (nullptr != asserted)
5961abe55efSEd Tanous                                     {
597c5b2abe0SLewanczyk, Dawid                                         callback(*asserted, aResp);
5981abe55efSEd Tanous                                     }
5991abe55efSEd Tanous                                     else
6001abe55efSEd Tanous                                     {
601c5b2abe0SLewanczyk, Dawid                                         callback(false, aResp);
602c5b2abe0SLewanczyk, Dawid                                     }
603c5b2abe0SLewanczyk, Dawid                                 }
604c5b2abe0SLewanczyk, Dawid                             }
605c5b2abe0SLewanczyk, Dawid                         }
606c5b2abe0SLewanczyk, Dawid                     }
607c5b2abe0SLewanczyk, Dawid                 }
608c5b2abe0SLewanczyk, Dawid             }
609c5b2abe0SLewanczyk, Dawid         },
610c5b2abe0SLewanczyk, Dawid         "xyz.openbmc_project.LED.GroupManager",
6116c34de48SEd Tanous         "/xyz/openbmc_project/led/groups", "org.freedesktop.DBus.ObjectManager",
6126c34de48SEd Tanous         "GetManagedObjects");
613c5b2abe0SLewanczyk, Dawid }
614c5b2abe0SLewanczyk, Dawid 
615c5b2abe0SLewanczyk, Dawid /**
616c5b2abe0SLewanczyk, Dawid  * @brief Retrieves host state properties over dbus
617c5b2abe0SLewanczyk, Dawid  *
618c5b2abe0SLewanczyk, Dawid  * @param[in] aResp     Shared pointer for completing asynchronous calls.
619c5b2abe0SLewanczyk, Dawid  *
620c5b2abe0SLewanczyk, Dawid  * @return None.
621c5b2abe0SLewanczyk, Dawid  */
622a0803efaSEd Tanous void getHostState(std::shared_ptr<AsyncResp> aResp)
6231abe55efSEd Tanous {
62455c7b7a2SEd Tanous     BMCWEB_LOG_DEBUG << "Get host information.";
62555c7b7a2SEd Tanous     crow::connections::systemBus->async_method_call(
626c5d03ff4SJennifer Lee         [aResp](const boost::system::error_code ec,
627abf2add6SEd Tanous                 const std::variant<std::string> &hostState) {
6281abe55efSEd Tanous             if (ec)
6291abe55efSEd Tanous             {
63055c7b7a2SEd Tanous                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
631f12894f8SJason M. Bills                 messages::internalError(aResp->res);
632c5b2abe0SLewanczyk, Dawid                 return;
633c5b2abe0SLewanczyk, Dawid             }
6346617338dSEd Tanous 
635abf2add6SEd Tanous             const std::string *s = std::get_if<std::string>(&hostState);
63655c7b7a2SEd Tanous             BMCWEB_LOG_DEBUG << "Host state: " << *s;
6376617338dSEd Tanous             if (s != nullptr)
6381abe55efSEd Tanous             {
639c5b2abe0SLewanczyk, Dawid                 // Verify Host State
64094732661SAndrew Geissler                 if (*s == "xyz.openbmc_project.State.Host.HostState.Running")
6411abe55efSEd Tanous                 {
64255c7b7a2SEd Tanous                     aResp->res.jsonValue["PowerState"] = "On";
6436617338dSEd Tanous                     aResp->res.jsonValue["Status"]["State"] = "Enabled";
6441abe55efSEd Tanous                 }
6451abe55efSEd Tanous                 else
6461abe55efSEd Tanous                 {
64755c7b7a2SEd Tanous                     aResp->res.jsonValue["PowerState"] = "Off";
6486617338dSEd Tanous                     aResp->res.jsonValue["Status"]["State"] = "Disabled";
649c5b2abe0SLewanczyk, Dawid                 }
650c5b2abe0SLewanczyk, Dawid             }
651c5b2abe0SLewanczyk, Dawid         },
6526c34de48SEd Tanous         "xyz.openbmc_project.State.Host", "/xyz/openbmc_project/state/host0",
6536617338dSEd Tanous         "org.freedesktop.DBus.Properties", "Get",
6546617338dSEd Tanous         "xyz.openbmc_project.State.Host", "CurrentHostState");
655c5b2abe0SLewanczyk, Dawid }
656c5b2abe0SLewanczyk, Dawid 
657c5b2abe0SLewanczyk, Dawid /**
658491d8ee7SSantosh Puranik  * @brief Traslates boot source DBUS property value to redfish.
659491d8ee7SSantosh Puranik  *
660491d8ee7SSantosh Puranik  * @param[in] dbusSource    The boot source in DBUS speak.
661491d8ee7SSantosh Puranik  *
662491d8ee7SSantosh Puranik  * @return Returns as a string, the boot source in Redfish terms. If translation
663491d8ee7SSantosh Puranik  * cannot be done, returns an empty string.
664491d8ee7SSantosh Puranik  */
665491d8ee7SSantosh Puranik static std::string dbusToRfBootSource(const std::string &dbusSource)
666491d8ee7SSantosh Puranik {
667491d8ee7SSantosh Puranik     if (dbusSource == "xyz.openbmc_project.Control.Boot.Source.Sources.Default")
668491d8ee7SSantosh Puranik     {
669491d8ee7SSantosh Puranik         return "None";
670491d8ee7SSantosh Puranik     }
671491d8ee7SSantosh Puranik     else if (dbusSource ==
672491d8ee7SSantosh Puranik              "xyz.openbmc_project.Control.Boot.Source.Sources.Disk")
673491d8ee7SSantosh Puranik     {
674491d8ee7SSantosh Puranik         return "Hdd";
675491d8ee7SSantosh Puranik     }
676491d8ee7SSantosh Puranik     else if (dbusSource ==
677a71dc0b7SSantosh Puranik              "xyz.openbmc_project.Control.Boot.Source.Sources.ExternalMedia")
678491d8ee7SSantosh Puranik     {
679491d8ee7SSantosh Puranik         return "Cd";
680491d8ee7SSantosh Puranik     }
681491d8ee7SSantosh Puranik     else if (dbusSource ==
682491d8ee7SSantosh Puranik              "xyz.openbmc_project.Control.Boot.Source.Sources.Network")
683491d8ee7SSantosh Puranik     {
684491d8ee7SSantosh Puranik         return "Pxe";
685491d8ee7SSantosh Puranik     }
6869f16b2c1SJennifer Lee     else if (dbusSource ==
687944ffaf9SJohnathan Mantey              "xyz.openbmc_project.Control.Boot.Source.Sources.RemovableMedia")
6889f16b2c1SJennifer Lee     {
6899f16b2c1SJennifer Lee         return "Usb";
6909f16b2c1SJennifer Lee     }
691491d8ee7SSantosh Puranik     else
692491d8ee7SSantosh Puranik     {
693491d8ee7SSantosh Puranik         return "";
694491d8ee7SSantosh Puranik     }
695491d8ee7SSantosh Puranik }
696491d8ee7SSantosh Puranik 
697491d8ee7SSantosh Puranik /**
698491d8ee7SSantosh Puranik  * @brief Traslates boot mode DBUS property value to redfish.
699491d8ee7SSantosh Puranik  *
700491d8ee7SSantosh Puranik  * @param[in] dbusMode    The boot mode in DBUS speak.
701491d8ee7SSantosh Puranik  *
702491d8ee7SSantosh Puranik  * @return Returns as a string, the boot mode in Redfish terms. If translation
703491d8ee7SSantosh Puranik  * cannot be done, returns an empty string.
704491d8ee7SSantosh Puranik  */
705491d8ee7SSantosh Puranik static std::string dbusToRfBootMode(const std::string &dbusMode)
706491d8ee7SSantosh Puranik {
707491d8ee7SSantosh Puranik     if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular")
708491d8ee7SSantosh Puranik     {
709491d8ee7SSantosh Puranik         return "None";
710491d8ee7SSantosh Puranik     }
711491d8ee7SSantosh Puranik     else if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Safe")
712491d8ee7SSantosh Puranik     {
713491d8ee7SSantosh Puranik         return "Diags";
714491d8ee7SSantosh Puranik     }
715491d8ee7SSantosh Puranik     else if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Setup")
716491d8ee7SSantosh Puranik     {
717491d8ee7SSantosh Puranik         return "BiosSetup";
718491d8ee7SSantosh Puranik     }
719491d8ee7SSantosh Puranik     else
720491d8ee7SSantosh Puranik     {
721491d8ee7SSantosh Puranik         return "";
722491d8ee7SSantosh Puranik     }
723491d8ee7SSantosh Puranik }
724491d8ee7SSantosh Puranik 
725491d8ee7SSantosh Puranik /**
726944ffaf9SJohnathan Mantey  * @brief Traslates boot source from Redfish to the DBus boot paths.
727491d8ee7SSantosh Puranik  *
728491d8ee7SSantosh Puranik  * @param[in] rfSource    The boot source in Redfish.
729944ffaf9SJohnathan Mantey  * @param[out] bootSource The DBus source
730944ffaf9SJohnathan Mantey  * @param[out] bootMode   the DBus boot mode
731491d8ee7SSantosh Puranik  *
732944ffaf9SJohnathan Mantey  * @return Integer error code.
733491d8ee7SSantosh Puranik  */
734944ffaf9SJohnathan Mantey static int assignBootParameters(std::shared_ptr<AsyncResp> aResp,
735944ffaf9SJohnathan Mantey                                 const std::string &rfSource,
736944ffaf9SJohnathan Mantey                                 std::string &bootSource, std::string &bootMode)
737491d8ee7SSantosh Puranik {
738944ffaf9SJohnathan Mantey     // The caller has initialized the bootSource and bootMode to:
739944ffaf9SJohnathan Mantey     // bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular";
740944ffaf9SJohnathan Mantey     // bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Default";
741944ffaf9SJohnathan Mantey     // Only modify the bootSource/bootMode variable needed to achieve the
742944ffaf9SJohnathan Mantey     // desired boot action.
743944ffaf9SJohnathan Mantey 
744491d8ee7SSantosh Puranik     if (rfSource == "None")
745491d8ee7SSantosh Puranik     {
746944ffaf9SJohnathan Mantey         return 0;
747491d8ee7SSantosh Puranik     }
748491d8ee7SSantosh Puranik     else if (rfSource == "Pxe")
749491d8ee7SSantosh Puranik     {
750944ffaf9SJohnathan Mantey         bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Network";
751944ffaf9SJohnathan Mantey     }
752944ffaf9SJohnathan Mantey     else if (rfSource == "Hdd")
753944ffaf9SJohnathan Mantey     {
754944ffaf9SJohnathan Mantey         bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Disk";
755944ffaf9SJohnathan Mantey     }
756944ffaf9SJohnathan Mantey     else if (rfSource == "Diags")
757944ffaf9SJohnathan Mantey     {
758944ffaf9SJohnathan Mantey         bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Safe";
759944ffaf9SJohnathan Mantey     }
760944ffaf9SJohnathan Mantey     else if (rfSource == "Cd")
761944ffaf9SJohnathan Mantey     {
762944ffaf9SJohnathan Mantey         bootSource =
763944ffaf9SJohnathan Mantey             "xyz.openbmc_project.Control.Boot.Source.Sources.ExternalMedia";
764944ffaf9SJohnathan Mantey     }
765944ffaf9SJohnathan Mantey     else if (rfSource == "BiosSetup")
766944ffaf9SJohnathan Mantey     {
767944ffaf9SJohnathan Mantey         bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Setup";
768491d8ee7SSantosh Puranik     }
7699f16b2c1SJennifer Lee     else if (rfSource == "Usb")
7709f16b2c1SJennifer Lee     {
771944ffaf9SJohnathan Mantey         bootSource =
772944ffaf9SJohnathan Mantey             "xyz.openbmc_project.Control.Boot.Source.Sources.RemovableMedia";
7739f16b2c1SJennifer Lee     }
774491d8ee7SSantosh Puranik     else
775491d8ee7SSantosh Puranik     {
776944ffaf9SJohnathan Mantey         BMCWEB_LOG_DEBUG << "Invalid property value for "
777944ffaf9SJohnathan Mantey                             "BootSourceOverrideTarget: "
778944ffaf9SJohnathan Mantey                          << bootSource;
779944ffaf9SJohnathan Mantey         messages::propertyValueNotInList(aResp->res, rfSource,
780944ffaf9SJohnathan Mantey                                          "BootSourceTargetOverride");
781944ffaf9SJohnathan Mantey         return -1;
782491d8ee7SSantosh Puranik     }
783944ffaf9SJohnathan Mantey     return 0;
784491d8ee7SSantosh Puranik }
785491d8ee7SSantosh Puranik 
786491d8ee7SSantosh Puranik /**
787491d8ee7SSantosh Puranik  * @brief Retrieves boot mode over DBUS and fills out the response
788491d8ee7SSantosh Puranik  *
789491d8ee7SSantosh Puranik  * @param[in] aResp         Shared pointer for generating response message.
790491d8ee7SSantosh Puranik  * @param[in] bootDbusObj   The dbus object to query for boot properties.
791491d8ee7SSantosh Puranik  *
792491d8ee7SSantosh Puranik  * @return None.
793491d8ee7SSantosh Puranik  */
794491d8ee7SSantosh Puranik static void getBootMode(std::shared_ptr<AsyncResp> aResp,
795491d8ee7SSantosh Puranik                         std::string bootDbusObj)
796491d8ee7SSantosh Puranik {
797491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
798491d8ee7SSantosh Puranik         [aResp](const boost::system::error_code ec,
799491d8ee7SSantosh Puranik                 const std::variant<std::string> &bootMode) {
800491d8ee7SSantosh Puranik             if (ec)
801491d8ee7SSantosh Puranik             {
802491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
803491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
804491d8ee7SSantosh Puranik                 return;
805491d8ee7SSantosh Puranik             }
806491d8ee7SSantosh Puranik 
807491d8ee7SSantosh Puranik             const std::string *bootModeStr =
808491d8ee7SSantosh Puranik                 std::get_if<std::string>(&bootMode);
809491d8ee7SSantosh Puranik 
810491d8ee7SSantosh Puranik             if (!bootModeStr)
811491d8ee7SSantosh Puranik             {
812491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
813491d8ee7SSantosh Puranik                 return;
814491d8ee7SSantosh Puranik             }
815491d8ee7SSantosh Puranik 
816491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot mode: " << *bootModeStr;
817491d8ee7SSantosh Puranik 
818491d8ee7SSantosh Puranik             // TODO (Santosh): Do we need to support override mode?
819491d8ee7SSantosh Puranik             aResp->res.jsonValue["Boot"]["BootSourceOverrideMode"] = "Legacy";
820491d8ee7SSantosh Puranik             aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget@Redfish."
821491d8ee7SSantosh Puranik                                          "AllowableValues"] = {
822944ffaf9SJohnathan Mantey                 "None", "Pxe", "Hdd", "Cd", "Diags", "BiosSetup", "Usb"};
823491d8ee7SSantosh Puranik 
824491d8ee7SSantosh Puranik             if (*bootModeStr !=
825491d8ee7SSantosh Puranik                 "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular")
826491d8ee7SSantosh Puranik             {
827491d8ee7SSantosh Puranik                 auto rfMode = dbusToRfBootMode(*bootModeStr);
828491d8ee7SSantosh Puranik                 if (!rfMode.empty())
829491d8ee7SSantosh Puranik                 {
830491d8ee7SSantosh Puranik                     aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] =
831491d8ee7SSantosh Puranik                         rfMode;
832491d8ee7SSantosh Puranik                 }
833491d8ee7SSantosh Puranik             }
834491d8ee7SSantosh Puranik 
835491d8ee7SSantosh Puranik             // If the BootSourceOverrideTarget is still "None" at the end,
836491d8ee7SSantosh Puranik             // reset the BootSourceOverrideEnabled to indicate that
837491d8ee7SSantosh Puranik             // overrides are disabled
838491d8ee7SSantosh Puranik             if (aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] ==
839491d8ee7SSantosh Puranik                 "None")
840491d8ee7SSantosh Puranik             {
841491d8ee7SSantosh Puranik                 aResp->res.jsonValue["Boot"]["BootSourceOverrideEnabled"] =
842491d8ee7SSantosh Puranik                     "Disabled";
843491d8ee7SSantosh Puranik             }
844491d8ee7SSantosh Puranik         },
845491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootDbusObj,
846491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
847491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Mode", "BootMode");
848491d8ee7SSantosh Puranik }
849491d8ee7SSantosh Puranik 
850491d8ee7SSantosh Puranik /**
851491d8ee7SSantosh Puranik  * @brief Retrieves boot source over DBUS
852491d8ee7SSantosh Puranik  *
853491d8ee7SSantosh Puranik  * @param[in] aResp         Shared pointer for generating response message.
854491d8ee7SSantosh Puranik  * @param[in] oneTimeEnable Boolean to indicate boot properties are one-time.
855491d8ee7SSantosh Puranik  *
856491d8ee7SSantosh Puranik  * @return None.
857491d8ee7SSantosh Puranik  */
858491d8ee7SSantosh Puranik static void getBootSource(std::shared_ptr<AsyncResp> aResp, bool oneTimeEnabled)
859491d8ee7SSantosh Puranik {
860491d8ee7SSantosh Puranik     std::string bootDbusObj =
861491d8ee7SSantosh Puranik         oneTimeEnabled ? "/xyz/openbmc_project/control/host0/boot/one_time"
862491d8ee7SSantosh Puranik                        : "/xyz/openbmc_project/control/host0/boot";
863491d8ee7SSantosh Puranik 
864491d8ee7SSantosh Puranik     BMCWEB_LOG_DEBUG << "Is one time: " << oneTimeEnabled;
865491d8ee7SSantosh Puranik     aResp->res.jsonValue["Boot"]["BootSourceOverrideEnabled"] =
866491d8ee7SSantosh Puranik         (oneTimeEnabled) ? "Once" : "Continuous";
867491d8ee7SSantosh Puranik 
868491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
869491d8ee7SSantosh Puranik         [aResp, bootDbusObj](const boost::system::error_code ec,
870491d8ee7SSantosh Puranik                              const std::variant<std::string> &bootSource) {
871491d8ee7SSantosh Puranik             if (ec)
872491d8ee7SSantosh Puranik             {
873491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
874491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
875491d8ee7SSantosh Puranik                 return;
876491d8ee7SSantosh Puranik             }
877491d8ee7SSantosh Puranik 
878491d8ee7SSantosh Puranik             const std::string *bootSourceStr =
879491d8ee7SSantosh Puranik                 std::get_if<std::string>(&bootSource);
880491d8ee7SSantosh Puranik 
881491d8ee7SSantosh Puranik             if (!bootSourceStr)
882491d8ee7SSantosh Puranik             {
883491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
884491d8ee7SSantosh Puranik                 return;
885491d8ee7SSantosh Puranik             }
886491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot source: " << *bootSourceStr;
887491d8ee7SSantosh Puranik 
888491d8ee7SSantosh Puranik             auto rfSource = dbusToRfBootSource(*bootSourceStr);
889491d8ee7SSantosh Puranik             if (!rfSource.empty())
890491d8ee7SSantosh Puranik             {
891491d8ee7SSantosh Puranik                 aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] =
892491d8ee7SSantosh Puranik                     rfSource;
893491d8ee7SSantosh Puranik             }
894491d8ee7SSantosh Puranik         },
895491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootDbusObj,
896491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
897491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Source", "BootSource");
898491d8ee7SSantosh Puranik     getBootMode(std::move(aResp), std::move(bootDbusObj));
899491d8ee7SSantosh Puranik }
900491d8ee7SSantosh Puranik 
901491d8ee7SSantosh Puranik /**
902491d8ee7SSantosh Puranik  * @brief Retrieves "One time" enabled setting over DBUS and calls function to
903491d8ee7SSantosh Puranik  * get boot source and boot mode.
904491d8ee7SSantosh Puranik  *
905491d8ee7SSantosh Puranik  * @param[in] aResp     Shared pointer for generating response message.
906491d8ee7SSantosh Puranik  *
907491d8ee7SSantosh Puranik  * @return None.
908491d8ee7SSantosh Puranik  */
909491d8ee7SSantosh Puranik static void getBootProperties(std::shared_ptr<AsyncResp> aResp)
910491d8ee7SSantosh Puranik {
911491d8ee7SSantosh Puranik     BMCWEB_LOG_DEBUG << "Get boot information.";
912491d8ee7SSantosh Puranik 
913491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
914c5d03ff4SJennifer Lee         [aResp](const boost::system::error_code ec,
915491d8ee7SSantosh Puranik                 const sdbusplus::message::variant<bool> &oneTime) {
916491d8ee7SSantosh Puranik             if (ec)
917491d8ee7SSantosh Puranik             {
918491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
9192a833c77SJames Feist                 // not an error, don't have to have the interface
920491d8ee7SSantosh Puranik                 return;
921491d8ee7SSantosh Puranik             }
922491d8ee7SSantosh Puranik 
923491d8ee7SSantosh Puranik             const bool *oneTimePtr = std::get_if<bool>(&oneTime);
924491d8ee7SSantosh Puranik 
925491d8ee7SSantosh Puranik             if (!oneTimePtr)
926491d8ee7SSantosh Puranik             {
927491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
928491d8ee7SSantosh Puranik                 return;
929491d8ee7SSantosh Puranik             }
930491d8ee7SSantosh Puranik             getBootSource(aResp, *oneTimePtr);
931491d8ee7SSantosh Puranik         },
932491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings",
933491d8ee7SSantosh Puranik         "/xyz/openbmc_project/control/host0/boot/one_time",
934491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
935491d8ee7SSantosh Puranik         "xyz.openbmc_project.Object.Enable", "Enabled");
936491d8ee7SSantosh Puranik }
937491d8ee7SSantosh Puranik 
938491d8ee7SSantosh Puranik /**
939491d8ee7SSantosh Puranik  * @brief Sets boot properties into DBUS object(s).
940491d8ee7SSantosh Puranik  *
941491d8ee7SSantosh Puranik  * @param[in] aResp           Shared pointer for generating response message.
942491d8ee7SSantosh Puranik  * @param[in] oneTimeEnabled  Is "one-time" setting already enabled.
943491d8ee7SSantosh Puranik  * @param[in] bootSource      The boot source to set.
944491d8ee7SSantosh Puranik  * @param[in] bootEnable      The source override "enable" to set.
945491d8ee7SSantosh Puranik  *
946265c1602SJohnathan Mantey  * @return Integer error code.
947491d8ee7SSantosh Puranik  */
948491d8ee7SSantosh Puranik static void setBootModeOrSource(std::shared_ptr<AsyncResp> aResp,
949491d8ee7SSantosh Puranik                                 bool oneTimeEnabled,
950491d8ee7SSantosh Puranik                                 std::optional<std::string> bootSource,
951491d8ee7SSantosh Puranik                                 std::optional<std::string> bootEnable)
952491d8ee7SSantosh Puranik {
953944ffaf9SJohnathan Mantey     std::string bootSourceStr =
954944ffaf9SJohnathan Mantey         "xyz.openbmc_project.Control.Boot.Source.Sources.Default";
955944ffaf9SJohnathan Mantey     std::string bootModeStr =
956944ffaf9SJohnathan Mantey         "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular";
957491d8ee7SSantosh Puranik     bool oneTimeSetting = oneTimeEnabled;
958944ffaf9SJohnathan Mantey     bool useBootSource = true;
959944ffaf9SJohnathan Mantey 
960491d8ee7SSantosh Puranik     // Validate incoming parameters
961491d8ee7SSantosh Puranik     if (bootEnable)
962491d8ee7SSantosh Puranik     {
963491d8ee7SSantosh Puranik         if (*bootEnable == "Once")
964491d8ee7SSantosh Puranik         {
965491d8ee7SSantosh Puranik             oneTimeSetting = true;
966491d8ee7SSantosh Puranik         }
967491d8ee7SSantosh Puranik         else if (*bootEnable == "Continuous")
968491d8ee7SSantosh Puranik         {
969491d8ee7SSantosh Puranik             oneTimeSetting = false;
970491d8ee7SSantosh Puranik         }
971491d8ee7SSantosh Puranik         else if (*bootEnable == "Disabled")
972491d8ee7SSantosh Puranik         {
973944ffaf9SJohnathan Mantey             BMCWEB_LOG_DEBUG << "Boot source override will be disabled";
974491d8ee7SSantosh Puranik             oneTimeSetting = false;
975944ffaf9SJohnathan Mantey             useBootSource = false;
976491d8ee7SSantosh Puranik         }
977491d8ee7SSantosh Puranik         else
978491d8ee7SSantosh Puranik         {
979491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Unsupported value for "
980491d8ee7SSantosh Puranik                                 "BootSourceOverrideEnabled: "
981491d8ee7SSantosh Puranik                              << *bootEnable;
982491d8ee7SSantosh Puranik             messages::propertyValueNotInList(aResp->res, *bootEnable,
983491d8ee7SSantosh Puranik                                              "BootSourceOverrideEnabled");
984491d8ee7SSantosh Puranik             return;
985491d8ee7SSantosh Puranik         }
986491d8ee7SSantosh Puranik     }
987491d8ee7SSantosh Puranik 
988944ffaf9SJohnathan Mantey     if (bootSource && useBootSource)
989491d8ee7SSantosh Puranik     {
990491d8ee7SSantosh Puranik         // Source target specified
991491d8ee7SSantosh Puranik         BMCWEB_LOG_DEBUG << "Boot source: " << *bootSource;
992491d8ee7SSantosh Puranik         // Figure out which DBUS interface and property to use
993944ffaf9SJohnathan Mantey         if (assignBootParameters(aResp, *bootSource, bootSourceStr,
994944ffaf9SJohnathan Mantey                                  bootModeStr))
995491d8ee7SSantosh Puranik         {
996944ffaf9SJohnathan Mantey             BMCWEB_LOG_DEBUG
997944ffaf9SJohnathan Mantey                 << "Invalid property value for BootSourceOverrideTarget: "
998491d8ee7SSantosh Puranik                 << *bootSource;
999491d8ee7SSantosh Puranik             messages::propertyValueNotInList(aResp->res, *bootSource,
1000491d8ee7SSantosh Puranik                                              "BootSourceTargetOverride");
1001491d8ee7SSantosh Puranik             return;
1002491d8ee7SSantosh Puranik         }
1003944ffaf9SJohnathan Mantey     }
1004491d8ee7SSantosh Puranik 
1005944ffaf9SJohnathan Mantey     // Act on validated parameters
1006944ffaf9SJohnathan Mantey     BMCWEB_LOG_DEBUG << "DBUS boot source: " << bootSourceStr;
1007944ffaf9SJohnathan Mantey     BMCWEB_LOG_DEBUG << "DBUS boot mode: " << bootModeStr;
1008944ffaf9SJohnathan Mantey     const char *bootObj =
1009944ffaf9SJohnathan Mantey         oneTimeSetting ? "/xyz/openbmc_project/control/host0/boot/one_time"
1010944ffaf9SJohnathan Mantey                        : "/xyz/openbmc_project/control/host0/boot";
1011944ffaf9SJohnathan Mantey 
1012491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1013491d8ee7SSantosh Puranik         [aResp](const boost::system::error_code ec) {
1014491d8ee7SSantosh Puranik             if (ec)
1015491d8ee7SSantosh Puranik             {
1016491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1017491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1018491d8ee7SSantosh Puranik                 return;
1019491d8ee7SSantosh Puranik             }
1020491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot source update done.";
1021491d8ee7SSantosh Puranik         },
1022491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootObj,
1023491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Set",
1024491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Source", "BootSource",
1025491d8ee7SSantosh Puranik         std::variant<std::string>(bootSourceStr));
1026944ffaf9SJohnathan Mantey 
1027491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1028491d8ee7SSantosh Puranik         [aResp](const boost::system::error_code ec) {
1029491d8ee7SSantosh Puranik             if (ec)
1030491d8ee7SSantosh Puranik             {
1031491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1032491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1033491d8ee7SSantosh Puranik                 return;
1034491d8ee7SSantosh Puranik             }
1035491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot mode update done.";
1036491d8ee7SSantosh Puranik         },
1037491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings", bootObj,
1038491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Set",
1039491d8ee7SSantosh Puranik         "xyz.openbmc_project.Control.Boot.Mode", "BootMode",
1040491d8ee7SSantosh Puranik         std::variant<std::string>(bootModeStr));
1041944ffaf9SJohnathan Mantey 
1042491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1043491d8ee7SSantosh Puranik         [aResp{std::move(aResp)}](const boost::system::error_code ec) {
1044491d8ee7SSantosh Puranik             if (ec)
1045491d8ee7SSantosh Puranik             {
1046491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1047491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1048491d8ee7SSantosh Puranik                 return;
1049491d8ee7SSantosh Puranik             }
1050491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Boot enable update done.";
1051491d8ee7SSantosh Puranik         },
1052491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings",
1053491d8ee7SSantosh Puranik         "/xyz/openbmc_project/control/host0/boot/one_time",
1054491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Set",
1055491d8ee7SSantosh Puranik         "xyz.openbmc_project.Object.Enable", "Enabled",
1056491d8ee7SSantosh Puranik         std::variant<bool>(oneTimeSetting));
1057491d8ee7SSantosh Puranik }
1058491d8ee7SSantosh Puranik 
1059491d8ee7SSantosh Puranik /**
1060491d8ee7SSantosh Puranik  * @brief Retrieves "One time" enabled setting over DBUS and calls function to
1061491d8ee7SSantosh Puranik  * set boot source/boot mode properties.
1062491d8ee7SSantosh Puranik  *
1063491d8ee7SSantosh Puranik  * @param[in] aResp      Shared pointer for generating response message.
1064491d8ee7SSantosh Puranik  * @param[in] bootSource The boot source from incoming RF request.
1065491d8ee7SSantosh Puranik  * @param[in] bootEnable The boot override enable from incoming RF request.
1066491d8ee7SSantosh Puranik  *
1067265c1602SJohnathan Mantey  * @return Integer error code.
1068491d8ee7SSantosh Puranik  */
1069491d8ee7SSantosh Puranik static void setBootProperties(std::shared_ptr<AsyncResp> aResp,
1070491d8ee7SSantosh Puranik                               std::optional<std::string> bootSource,
1071491d8ee7SSantosh Puranik                               std::optional<std::string> bootEnable)
1072491d8ee7SSantosh Puranik {
1073491d8ee7SSantosh Puranik     BMCWEB_LOG_DEBUG << "Set boot information.";
1074491d8ee7SSantosh Puranik 
1075491d8ee7SSantosh Puranik     crow::connections::systemBus->async_method_call(
1076265c1602SJohnathan Mantey         [aResp, bootSource{std::move(bootSource)},
1077491d8ee7SSantosh Puranik          bootEnable{std::move(bootEnable)}](
1078491d8ee7SSantosh Puranik             const boost::system::error_code ec,
1079491d8ee7SSantosh Puranik             const sdbusplus::message::variant<bool> &oneTime) {
1080491d8ee7SSantosh Puranik             if (ec)
1081491d8ee7SSantosh Puranik             {
1082491d8ee7SSantosh Puranik                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1083491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1084491d8ee7SSantosh Puranik                 return;
1085491d8ee7SSantosh Puranik             }
1086491d8ee7SSantosh Puranik 
1087491d8ee7SSantosh Puranik             const bool *oneTimePtr = std::get_if<bool>(&oneTime);
1088491d8ee7SSantosh Puranik 
1089491d8ee7SSantosh Puranik             if (!oneTimePtr)
1090491d8ee7SSantosh Puranik             {
1091491d8ee7SSantosh Puranik                 messages::internalError(aResp->res);
1092491d8ee7SSantosh Puranik                 return;
1093491d8ee7SSantosh Puranik             }
1094491d8ee7SSantosh Puranik 
1095491d8ee7SSantosh Puranik             BMCWEB_LOG_DEBUG << "Got one time: " << *oneTimePtr;
1096491d8ee7SSantosh Puranik 
1097491d8ee7SSantosh Puranik             setBootModeOrSource(aResp, *oneTimePtr, std::move(bootSource),
1098491d8ee7SSantosh Puranik                                 std::move(bootEnable));
1099491d8ee7SSantosh Puranik         },
1100491d8ee7SSantosh Puranik         "xyz.openbmc_project.Settings",
1101491d8ee7SSantosh Puranik         "/xyz/openbmc_project/control/host0/boot/one_time",
1102491d8ee7SSantosh Puranik         "org.freedesktop.DBus.Properties", "Get",
1103491d8ee7SSantosh Puranik         "xyz.openbmc_project.Object.Enable", "Enabled");
1104491d8ee7SSantosh Puranik }
1105491d8ee7SSantosh Puranik 
1106a6349918SAppaRao Puli #ifdef BMCWEB_ENABLE_REDFISH_PROVISIONING_FEATURE
1107a6349918SAppaRao Puli /**
1108a6349918SAppaRao Puli  * @brief Retrieves provisioning status
1109a6349918SAppaRao Puli  *
1110a6349918SAppaRao Puli  * @param[in] aResp     Shared pointer for completing asynchronous calls.
1111a6349918SAppaRao Puli  *
1112a6349918SAppaRao Puli  * @return None.
1113a6349918SAppaRao Puli  */
1114a6349918SAppaRao Puli void getProvisioningStatus(std::shared_ptr<AsyncResp> aResp)
1115a6349918SAppaRao Puli {
1116a6349918SAppaRao Puli     BMCWEB_LOG_DEBUG << "Get OEM information.";
1117a6349918SAppaRao Puli     crow::connections::systemBus->async_method_call(
1118a6349918SAppaRao Puli         [aResp](const boost::system::error_code ec,
1119a6349918SAppaRao Puli                 const std::vector<std::pair<std::string, VariantType>>
1120a6349918SAppaRao Puli                     &propertiesList) {
1121a6349918SAppaRao Puli             if (ec)
1122a6349918SAppaRao Puli             {
1123a6349918SAppaRao Puli                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1124a6349918SAppaRao Puli                 messages::internalError(aResp->res);
1125a6349918SAppaRao Puli                 return;
1126a6349918SAppaRao Puli             }
1127a6349918SAppaRao Puli 
1128a6349918SAppaRao Puli             const bool *provState = nullptr;
1129a6349918SAppaRao Puli             const bool *lockState = nullptr;
1130a6349918SAppaRao Puli             for (const std::pair<std::string, VariantType> &property :
1131a6349918SAppaRao Puli                  propertiesList)
1132a6349918SAppaRao Puli             {
1133a6349918SAppaRao Puli                 if (property.first == "UfmProvisioned")
1134a6349918SAppaRao Puli                 {
1135a6349918SAppaRao Puli                     provState = std::get_if<bool>(&property.second);
1136a6349918SAppaRao Puli                 }
1137a6349918SAppaRao Puli                 else if (property.first == "UfmLocked")
1138a6349918SAppaRao Puli                 {
1139a6349918SAppaRao Puli                     lockState = std::get_if<bool>(&property.second);
1140a6349918SAppaRao Puli                 }
1141a6349918SAppaRao Puli             }
1142a6349918SAppaRao Puli 
1143a6349918SAppaRao Puli             if ((provState == nullptr) || (lockState == nullptr))
1144a6349918SAppaRao Puli             {
1145a6349918SAppaRao Puli                 BMCWEB_LOG_DEBUG << "Unable to get PFR attributes.";
1146a6349918SAppaRao Puli                 messages::internalError(aResp->res);
1147a6349918SAppaRao Puli                 return;
1148a6349918SAppaRao Puli             }
1149a6349918SAppaRao Puli 
1150a6349918SAppaRao Puli             nlohmann::json &oemPFR =
1151a6349918SAppaRao Puli                 aResp->res.jsonValue["Oem"]["OpenBmc"]["FirmwareProvisioning"];
1152a6349918SAppaRao Puli             if (*provState == true)
1153a6349918SAppaRao Puli             {
1154a6349918SAppaRao Puli                 if (*lockState == true)
1155a6349918SAppaRao Puli                 {
1156a6349918SAppaRao Puli                     oemPFR["ProvisioningStatus"] = "ProvisionedAndLocked";
1157a6349918SAppaRao Puli                 }
1158a6349918SAppaRao Puli                 else
1159a6349918SAppaRao Puli                 {
1160a6349918SAppaRao Puli                     oemPFR["ProvisioningStatus"] = "ProvisionedButNotLocked";
1161a6349918SAppaRao Puli                 }
1162a6349918SAppaRao Puli             }
1163a6349918SAppaRao Puli             else
1164a6349918SAppaRao Puli             {
1165a6349918SAppaRao Puli                 oemPFR["ProvisioningStatus"] = "NotProvisioned";
1166a6349918SAppaRao Puli             }
1167a6349918SAppaRao Puli         },
1168a6349918SAppaRao Puli         "xyz.openbmc_project.PFR.Manager", "/xyz/openbmc_project/pfr",
1169a6349918SAppaRao Puli         "org.freedesktop.DBus.Properties", "GetAll",
1170a6349918SAppaRao Puli         "xyz.openbmc_project.PFR.Attributes");
1171a6349918SAppaRao Puli }
1172a6349918SAppaRao Puli #endif
1173a6349918SAppaRao Puli 
1174491d8ee7SSantosh Puranik /**
117551709ffdSYong Li  * @brief Translates watchdog timeout action DBUS property value to redfish.
117651709ffdSYong Li  *
117751709ffdSYong Li  * @param[in] dbusAction    The watchdog timeout action in D-BUS.
117851709ffdSYong Li  *
117951709ffdSYong Li  * @return Returns as a string, the timeout action in Redfish terms. If
118051709ffdSYong Li  * translation cannot be done, returns an empty string.
118151709ffdSYong Li  */
118251709ffdSYong Li static std::string dbusToRfWatchdogAction(const std::string &dbusAction)
118351709ffdSYong Li {
118451709ffdSYong Li     if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.None")
118551709ffdSYong Li     {
118651709ffdSYong Li         return "None";
118751709ffdSYong Li     }
118851709ffdSYong Li     else if (dbusAction ==
118951709ffdSYong Li              "xyz.openbmc_project.State.Watchdog.Action.HardReset")
119051709ffdSYong Li     {
119151709ffdSYong Li         return "ResetSystem";
119251709ffdSYong Li     }
119351709ffdSYong Li     else if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.PowerOff")
119451709ffdSYong Li     {
119551709ffdSYong Li         return "PowerDown";
119651709ffdSYong Li     }
119751709ffdSYong Li     else if (dbusAction ==
119851709ffdSYong Li              "xyz.openbmc_project.State.Watchdog.Action.PowerCycle")
119951709ffdSYong Li     {
120051709ffdSYong Li         return "PowerCycle";
120151709ffdSYong Li     }
120251709ffdSYong Li 
120351709ffdSYong Li     return "";
120451709ffdSYong Li }
120551709ffdSYong Li 
120651709ffdSYong Li /**
1207c45f0082SYong Li  *@brief Translates timeout action from Redfish to DBUS property value.
1208c45f0082SYong Li  *
1209c45f0082SYong Li  *@param[in] rfAction The timeout action in Redfish.
1210c45f0082SYong Li  *
1211c45f0082SYong Li  *@return Returns as a string, the time_out action as expected by DBUS.
1212c45f0082SYong Li  *If translation cannot be done, returns an empty string.
1213c45f0082SYong Li  */
1214c45f0082SYong Li 
1215c45f0082SYong Li static std::string rfToDbusWDTTimeOutAct(const std::string &rfAction)
1216c45f0082SYong Li {
1217c45f0082SYong Li     if (rfAction == "None")
1218c45f0082SYong Li     {
1219c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.None";
1220c45f0082SYong Li     }
1221c45f0082SYong Li     else if (rfAction == "PowerCycle")
1222c45f0082SYong Li     {
1223c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.PowerCycle";
1224c45f0082SYong Li     }
1225c45f0082SYong Li     else if (rfAction == "PowerDown")
1226c45f0082SYong Li     {
1227c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.PowerOff";
1228c45f0082SYong Li     }
1229c45f0082SYong Li     else if (rfAction == "ResetSystem")
1230c45f0082SYong Li     {
1231c45f0082SYong Li         return "xyz.openbmc_project.State.Watchdog.Action.HardReset";
1232c45f0082SYong Li     }
1233c45f0082SYong Li 
1234c45f0082SYong Li     return "";
1235c45f0082SYong Li }
1236c45f0082SYong Li 
1237c45f0082SYong Li /**
123851709ffdSYong Li  * @brief Retrieves host watchdog timer properties over DBUS
123951709ffdSYong Li  *
124051709ffdSYong Li  * @param[in] aResp     Shared pointer for completing asynchronous calls.
124151709ffdSYong Li  *
124251709ffdSYong Li  * @return None.
124351709ffdSYong Li  */
124451709ffdSYong Li void getHostWatchdogTimer(std::shared_ptr<AsyncResp> aResp)
124551709ffdSYong Li {
124651709ffdSYong Li     BMCWEB_LOG_DEBUG << "Get host watchodg";
124751709ffdSYong Li     crow::connections::systemBus->async_method_call(
124851709ffdSYong Li         [aResp](const boost::system::error_code ec,
124951709ffdSYong Li                 PropertiesType &properties) {
125051709ffdSYong Li             if (ec)
125151709ffdSYong Li             {
125251709ffdSYong Li                 // watchdog service is stopped
125351709ffdSYong Li                 BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
125451709ffdSYong Li                 return;
125551709ffdSYong Li             }
125651709ffdSYong Li 
125751709ffdSYong Li             BMCWEB_LOG_DEBUG << "Got " << properties.size() << " wdt prop.";
125851709ffdSYong Li 
125951709ffdSYong Li             nlohmann::json &hostWatchdogTimer =
126051709ffdSYong Li                 aResp->res.jsonValue["HostWatchdogTimer"];
126151709ffdSYong Li 
126251709ffdSYong Li             // watchdog service is running/enabled
126351709ffdSYong Li             hostWatchdogTimer["Status"]["State"] = "Enabled";
126451709ffdSYong Li 
126551709ffdSYong Li             for (const auto &property : properties)
126651709ffdSYong Li             {
126751709ffdSYong Li                 BMCWEB_LOG_DEBUG << "prop=" << property.first;
126851709ffdSYong Li                 if (property.first == "Enabled")
126951709ffdSYong Li                 {
127051709ffdSYong Li                     const bool *state = std::get_if<bool>(&property.second);
127151709ffdSYong Li 
127251709ffdSYong Li                     if (!state)
127351709ffdSYong Li                     {
127451709ffdSYong Li                         messages::internalError(aResp->res);
127551709ffdSYong Li                         continue;
127651709ffdSYong Li                     }
127751709ffdSYong Li 
127851709ffdSYong Li                     hostWatchdogTimer["FunctionEnabled"] = *state;
127951709ffdSYong Li                 }
128051709ffdSYong Li                 else if (property.first == "ExpireAction")
128151709ffdSYong Li                 {
128251709ffdSYong Li                     const std::string *s =
128351709ffdSYong Li                         std::get_if<std::string>(&property.second);
128451709ffdSYong Li                     if (!s)
128551709ffdSYong Li                     {
128651709ffdSYong Li                         messages::internalError(aResp->res);
128751709ffdSYong Li                         continue;
128851709ffdSYong Li                     }
128951709ffdSYong Li 
129051709ffdSYong Li                     std::string action = dbusToRfWatchdogAction(*s);
129151709ffdSYong Li                     if (action.empty())
129251709ffdSYong Li                     {
129351709ffdSYong Li                         messages::internalError(aResp->res);
129451709ffdSYong Li                         continue;
129551709ffdSYong Li                     }
129651709ffdSYong Li                     hostWatchdogTimer["TimeoutAction"] = action;
129751709ffdSYong Li                 }
129851709ffdSYong Li             }
129951709ffdSYong Li         },
130051709ffdSYong Li         "xyz.openbmc_project.Watchdog", "/xyz/openbmc_project/watchdog/host0",
130151709ffdSYong Li         "org.freedesktop.DBus.Properties", "GetAll",
130251709ffdSYong Li         "xyz.openbmc_project.State.Watchdog");
130351709ffdSYong Li }
130451709ffdSYong Li 
130551709ffdSYong Li /**
1306c45f0082SYong Li  * @brief Sets Host WatchDog Timer properties.
1307c45f0082SYong Li  *
1308c45f0082SYong Li  * @param[in] aResp      Shared pointer for generating response message.
1309c45f0082SYong Li  * @param[in] wdtEnable  The WDTimer Enable value (true/false) from incoming
1310c45f0082SYong Li  *                       RF request.
1311c45f0082SYong Li  * @param[in] wdtTimeOutAction The WDT Timeout action, from incoming RF request.
1312c45f0082SYong Li  *
1313c45f0082SYong Li  * @return None.
1314c45f0082SYong Li  */
1315c45f0082SYong Li static void setWDTProperties(std::shared_ptr<AsyncResp> aResp,
1316c45f0082SYong Li                              const std::optional<bool> wdtEnable,
1317c45f0082SYong Li                              const std::optional<std::string> &wdtTimeOutAction)
1318c45f0082SYong Li {
1319c45f0082SYong Li     BMCWEB_LOG_DEBUG << "Set host watchdog";
1320c45f0082SYong Li 
1321c45f0082SYong Li     if (wdtTimeOutAction)
1322c45f0082SYong Li     {
1323c45f0082SYong Li         std::string wdtTimeOutActStr = rfToDbusWDTTimeOutAct(*wdtTimeOutAction);
1324c45f0082SYong Li         // check if TimeOut Action is Valid
1325c45f0082SYong Li         if (wdtTimeOutActStr.empty())
1326c45f0082SYong Li         {
1327c45f0082SYong Li             BMCWEB_LOG_DEBUG << "Unsupported value for TimeoutAction: "
1328c45f0082SYong Li                              << *wdtTimeOutAction;
1329c45f0082SYong Li             messages::propertyValueNotInList(aResp->res, *wdtTimeOutAction,
1330c45f0082SYong Li                                              "TimeoutAction");
1331c45f0082SYong Li             return;
1332c45f0082SYong Li         }
1333c45f0082SYong Li 
1334c45f0082SYong Li         crow::connections::systemBus->async_method_call(
1335c45f0082SYong Li             [aResp](const boost::system::error_code ec) {
1336c45f0082SYong Li                 if (ec)
1337c45f0082SYong Li                 {
1338c45f0082SYong Li                     BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1339c45f0082SYong Li                     messages::internalError(aResp->res);
1340c45f0082SYong Li                     return;
1341c45f0082SYong Li                 }
1342c45f0082SYong Li             },
1343c45f0082SYong Li             "xyz.openbmc_project.Watchdog",
1344c45f0082SYong Li             "/xyz/openbmc_project/watchdog/host0",
1345c45f0082SYong Li             "org.freedesktop.DBus.Properties", "Set",
1346c45f0082SYong Li             "xyz.openbmc_project.State.Watchdog", "ExpireAction",
1347c45f0082SYong Li             std::variant<std::string>(wdtTimeOutActStr));
1348c45f0082SYong Li     }
1349c45f0082SYong Li 
1350c45f0082SYong Li     if (wdtEnable)
1351c45f0082SYong Li     {
1352c45f0082SYong Li         crow::connections::systemBus->async_method_call(
1353c45f0082SYong Li             [aResp](const boost::system::error_code ec) {
1354c45f0082SYong Li                 if (ec)
1355c45f0082SYong Li                 {
1356c45f0082SYong Li                     BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1357c45f0082SYong Li                     messages::internalError(aResp->res);
1358c45f0082SYong Li                     return;
1359c45f0082SYong Li                 }
1360c45f0082SYong Li             },
1361c45f0082SYong Li             "xyz.openbmc_project.Watchdog",
1362c45f0082SYong Li             "/xyz/openbmc_project/watchdog/host0",
1363c45f0082SYong Li             "org.freedesktop.DBus.Properties", "Set",
1364c45f0082SYong Li             "xyz.openbmc_project.State.Watchdog", "Enabled",
1365c45f0082SYong Li             std::variant<bool>(*wdtEnable));
1366c45f0082SYong Li     }
1367c45f0082SYong Li }
1368c45f0082SYong Li 
1369c45f0082SYong Li /**
1370c5b2abe0SLewanczyk, Dawid  * SystemsCollection derived class for delivering ComputerSystems Collection
1371c5b2abe0SLewanczyk, Dawid  * Schema
1372c5b2abe0SLewanczyk, Dawid  */
13731abe55efSEd Tanous class SystemsCollection : public Node
13741abe55efSEd Tanous {
1375c5b2abe0SLewanczyk, Dawid   public:
13761abe55efSEd Tanous     SystemsCollection(CrowApp &app) : Node(app, "/redfish/v1/Systems/")
13771abe55efSEd Tanous     {
1378c5b2abe0SLewanczyk, Dawid         entityPrivileges = {
1379c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::get, {{"Login"}}},
1380c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::head, {{"Login"}}},
1381c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::patch, {{"ConfigureComponents"}}},
1382c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::put, {{"ConfigureComponents"}}},
1383c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}},
1384c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
1385c5b2abe0SLewanczyk, Dawid     }
1386c5b2abe0SLewanczyk, Dawid 
1387c5b2abe0SLewanczyk, Dawid   private:
138855c7b7a2SEd Tanous     void doGet(crow::Response &res, const crow::Request &req,
13891abe55efSEd Tanous                const std::vector<std::string> &params) override
13901abe55efSEd Tanous     {
13910f74e643SEd Tanous         res.jsonValue["@odata.type"] =
13920f74e643SEd Tanous             "#ComputerSystemCollection.ComputerSystemCollection";
13930f74e643SEd Tanous         res.jsonValue["@odata.id"] = "/redfish/v1/Systems";
13940f74e643SEd Tanous         res.jsonValue["@odata.context"] =
13950f74e643SEd Tanous             "/redfish/v1/"
13960f74e643SEd Tanous             "$metadata#ComputerSystemCollection.ComputerSystemCollection";
13970f74e643SEd Tanous         res.jsonValue["Name"] = "Computer System Collection";
1398029573d4SEd Tanous         res.jsonValue["Members"] = {
1399029573d4SEd Tanous             {{"@odata.id", "/redfish/v1/Systems/system"}}};
1400029573d4SEd Tanous         res.jsonValue["Members@odata.count"] = 1;
1401029573d4SEd Tanous         res.end();
1402c5b2abe0SLewanczyk, Dawid     }
1403c5b2abe0SLewanczyk, Dawid };
1404c5b2abe0SLewanczyk, Dawid 
1405c5b2abe0SLewanczyk, Dawid /**
1406cc340dd9SEd Tanous  * SystemActionsReset class supports handle POST method for Reset action.
1407cc340dd9SEd Tanous  * The class retrieves and sends data directly to D-Bus.
1408cc340dd9SEd Tanous  */
1409cc340dd9SEd Tanous class SystemActionsReset : public Node
1410cc340dd9SEd Tanous {
1411cc340dd9SEd Tanous   public:
1412cc340dd9SEd Tanous     SystemActionsReset(CrowApp &app) :
1413029573d4SEd Tanous         Node(app, "/redfish/v1/Systems/system/Actions/ComputerSystem.Reset/")
1414cc340dd9SEd Tanous     {
1415cc340dd9SEd Tanous         entityPrivileges = {
1416cc340dd9SEd Tanous             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
1417cc340dd9SEd Tanous     }
1418cc340dd9SEd Tanous 
1419cc340dd9SEd Tanous   private:
1420cc340dd9SEd Tanous     /**
1421cc340dd9SEd Tanous      * Function handles POST method request.
1422cc340dd9SEd Tanous      * Analyzes POST body message before sends Reset request data to D-Bus.
1423cc340dd9SEd Tanous      */
1424cc340dd9SEd Tanous     void doPost(crow::Response &res, const crow::Request &req,
1425cc340dd9SEd Tanous                 const std::vector<std::string> &params) override
1426cc340dd9SEd Tanous     {
1427cc340dd9SEd Tanous         auto asyncResp = std::make_shared<AsyncResp>(res);
1428cc340dd9SEd Tanous 
14299712f8acSEd Tanous         std::string resetType;
14309712f8acSEd Tanous         if (!json_util::readJson(req, res, "ResetType", resetType))
1431cc340dd9SEd Tanous         {
1432cc340dd9SEd Tanous             return;
1433cc340dd9SEd Tanous         }
1434cc340dd9SEd Tanous 
1435d22c8396SJason M. Bills         // Get the command and host vs. chassis
1436cc340dd9SEd Tanous         std::string command;
1437d22c8396SJason M. Bills         bool hostCommand;
14389712f8acSEd Tanous         if (resetType == "On")
1439cc340dd9SEd Tanous         {
1440cc340dd9SEd Tanous             command = "xyz.openbmc_project.State.Host.Transition.On";
1441d22c8396SJason M. Bills             hostCommand = true;
1442d22c8396SJason M. Bills         }
1443d22c8396SJason M. Bills         else if (resetType == "ForceOff")
1444d22c8396SJason M. Bills         {
1445d22c8396SJason M. Bills             command = "xyz.openbmc_project.State.Chassis.Transition.Off";
1446d22c8396SJason M. Bills             hostCommand = false;
1447d22c8396SJason M. Bills         }
1448d22c8396SJason M. Bills         else if (resetType == "ForceOn")
1449d22c8396SJason M. Bills         {
1450d22c8396SJason M. Bills             command = "xyz.openbmc_project.State.Host.Transition.On";
1451d22c8396SJason M. Bills             hostCommand = true;
1452d22c8396SJason M. Bills         }
1453d22c8396SJason M. Bills         else if (resetType == "ForceRestart")
1454d22c8396SJason M. Bills         {
1455d22c8396SJason M. Bills             command = "xyz.openbmc_project.State.Chassis.Transition.Reset";
1456d22c8396SJason M. Bills             hostCommand = false;
1457cc340dd9SEd Tanous         }
14589712f8acSEd Tanous         else if (resetType == "GracefulShutdown")
1459cc340dd9SEd Tanous         {
1460cc340dd9SEd Tanous             command = "xyz.openbmc_project.State.Host.Transition.Off";
1461d22c8396SJason M. Bills             hostCommand = true;
1462cc340dd9SEd Tanous         }
14639712f8acSEd Tanous         else if (resetType == "GracefulRestart")
1464cc340dd9SEd Tanous         {
14659712f8acSEd Tanous             command = "xyz.openbmc_project.State.Host.Transition.Reboot";
1466d22c8396SJason M. Bills             hostCommand = true;
1467d22c8396SJason M. Bills         }
1468d22c8396SJason M. Bills         else if (resetType == "PowerCycle")
1469d22c8396SJason M. Bills         {
1470d22c8396SJason M. Bills             command = "xyz.openbmc_project.State.Chassis.Transition.PowerCycle";
1471d22c8396SJason M. Bills             hostCommand = false;
1472cc340dd9SEd Tanous         }
1473bfd5b826SLakshminarayana R. Kammath         else if (resetType == "Nmi")
1474bfd5b826SLakshminarayana R. Kammath         {
1475bfd5b826SLakshminarayana R. Kammath             doNMI(asyncResp);
1476bfd5b826SLakshminarayana R. Kammath             return;
1477bfd5b826SLakshminarayana R. Kammath         }
1478cc340dd9SEd Tanous         else
1479cc340dd9SEd Tanous         {
1480f12894f8SJason M. Bills             messages::actionParameterUnknown(res, "Reset", resetType);
1481cc340dd9SEd Tanous             return;
1482cc340dd9SEd Tanous         }
1483cc340dd9SEd Tanous 
1484d22c8396SJason M. Bills         if (hostCommand)
1485d22c8396SJason M. Bills         {
1486cc340dd9SEd Tanous             crow::connections::systemBus->async_method_call(
1487d22c8396SJason M. Bills                 [asyncResp, resetType](const boost::system::error_code ec) {
1488cc340dd9SEd Tanous                     if (ec)
1489cc340dd9SEd Tanous                     {
1490cc340dd9SEd Tanous                         BMCWEB_LOG_ERROR << "D-Bus responses error: " << ec;
1491d22c8396SJason M. Bills                         if (ec.value() == boost::asio::error::invalid_argument)
1492d22c8396SJason M. Bills                         {
1493d22c8396SJason M. Bills                             messages::actionParameterNotSupported(
1494d22c8396SJason M. Bills                                 asyncResp->res, resetType, "Reset");
1495d22c8396SJason M. Bills                         }
1496d22c8396SJason M. Bills                         else
1497d22c8396SJason M. Bills                         {
1498f12894f8SJason M. Bills                             messages::internalError(asyncResp->res);
1499d22c8396SJason M. Bills                         }
1500cc340dd9SEd Tanous                         return;
1501cc340dd9SEd Tanous                     }
1502f12894f8SJason M. Bills                     messages::success(asyncResp->res);
1503cc340dd9SEd Tanous                 },
1504cc340dd9SEd Tanous                 "xyz.openbmc_project.State.Host",
1505cc340dd9SEd Tanous                 "/xyz/openbmc_project/state/host0",
1506cc340dd9SEd Tanous                 "org.freedesktop.DBus.Properties", "Set",
15079712f8acSEd Tanous                 "xyz.openbmc_project.State.Host", "RequestedHostTransition",
1508abf2add6SEd Tanous                 std::variant<std::string>{command});
1509cc340dd9SEd Tanous         }
1510d22c8396SJason M. Bills         else
1511d22c8396SJason M. Bills         {
1512d22c8396SJason M. Bills             crow::connections::systemBus->async_method_call(
1513d22c8396SJason M. Bills                 [asyncResp, resetType](const boost::system::error_code ec) {
1514d22c8396SJason M. Bills                     if (ec)
1515d22c8396SJason M. Bills                     {
1516d22c8396SJason M. Bills                         BMCWEB_LOG_ERROR << "D-Bus responses error: " << ec;
1517d22c8396SJason M. Bills                         if (ec.value() == boost::asio::error::invalid_argument)
1518d22c8396SJason M. Bills                         {
1519d22c8396SJason M. Bills                             messages::actionParameterNotSupported(
1520d22c8396SJason M. Bills                                 asyncResp->res, resetType, "Reset");
1521d22c8396SJason M. Bills                         }
1522d22c8396SJason M. Bills                         else
1523d22c8396SJason M. Bills                         {
1524d22c8396SJason M. Bills                             messages::internalError(asyncResp->res);
1525d22c8396SJason M. Bills                         }
1526d22c8396SJason M. Bills                         return;
1527d22c8396SJason M. Bills                     }
1528d22c8396SJason M. Bills                     messages::success(asyncResp->res);
1529d22c8396SJason M. Bills                 },
1530d22c8396SJason M. Bills                 "xyz.openbmc_project.State.Chassis",
1531d22c8396SJason M. Bills                 "/xyz/openbmc_project/state/chassis0",
1532d22c8396SJason M. Bills                 "org.freedesktop.DBus.Properties", "Set",
1533d22c8396SJason M. Bills                 "xyz.openbmc_project.State.Chassis", "RequestedPowerTransition",
1534d22c8396SJason M. Bills                 std::variant<std::string>{command});
1535d22c8396SJason M. Bills         }
1536d22c8396SJason M. Bills     }
1537bfd5b826SLakshminarayana R. Kammath     /**
1538bfd5b826SLakshminarayana R. Kammath      * Function transceives data with dbus directly.
1539bfd5b826SLakshminarayana R. Kammath      */
1540bfd5b826SLakshminarayana R. Kammath     void doNMI(const std::shared_ptr<AsyncResp> &asyncResp)
1541bfd5b826SLakshminarayana R. Kammath     {
1542bfd5b826SLakshminarayana R. Kammath         constexpr char const *serviceName =
1543bfd5b826SLakshminarayana R. Kammath             "xyz.openbmc_project.Control.Host.NMI";
1544bfd5b826SLakshminarayana R. Kammath         constexpr char const *objectPath =
1545bfd5b826SLakshminarayana R. Kammath             "/xyz/openbmc_project/control/host0/nmi";
1546bfd5b826SLakshminarayana R. Kammath         constexpr char const *interfaceName =
1547bfd5b826SLakshminarayana R. Kammath             "xyz.openbmc_project.Control.Host.NMI";
1548bfd5b826SLakshminarayana R. Kammath         constexpr char const *method = "NMI";
1549bfd5b826SLakshminarayana R. Kammath 
1550bfd5b826SLakshminarayana R. Kammath         crow::connections::systemBus->async_method_call(
1551bfd5b826SLakshminarayana R. Kammath             [asyncResp](const boost::system::error_code ec) {
1552bfd5b826SLakshminarayana R. Kammath                 if (ec)
1553bfd5b826SLakshminarayana R. Kammath                 {
1554bfd5b826SLakshminarayana R. Kammath                     BMCWEB_LOG_ERROR << " Bad D-Bus request error: " << ec;
1555bfd5b826SLakshminarayana R. Kammath                     messages::internalError(asyncResp->res);
1556bfd5b826SLakshminarayana R. Kammath                     return;
1557bfd5b826SLakshminarayana R. Kammath                 }
1558bfd5b826SLakshminarayana R. Kammath                 messages::success(asyncResp->res);
1559bfd5b826SLakshminarayana R. Kammath             },
1560bfd5b826SLakshminarayana R. Kammath             serviceName, objectPath, interfaceName, method);
1561bfd5b826SLakshminarayana R. Kammath     }
1562cc340dd9SEd Tanous };
1563cc340dd9SEd Tanous 
1564cc340dd9SEd Tanous /**
15656617338dSEd Tanous  * Systems derived class for delivering Computer Systems Schema.
1566c5b2abe0SLewanczyk, Dawid  */
15671abe55efSEd Tanous class Systems : public Node
15681abe55efSEd Tanous {
1569c5b2abe0SLewanczyk, Dawid   public:
1570c5b2abe0SLewanczyk, Dawid     /*
1571c5b2abe0SLewanczyk, Dawid      * Default Constructor
1572c5b2abe0SLewanczyk, Dawid      */
1573029573d4SEd Tanous     Systems(CrowApp &app) : Node(app, "/redfish/v1/Systems/system/")
15741abe55efSEd Tanous     {
1575c5b2abe0SLewanczyk, Dawid         entityPrivileges = {
1576c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::get, {{"Login"}}},
1577c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::head, {{"Login"}}},
1578c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::patch, {{"ConfigureComponents"}}},
1579c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::put, {{"ConfigureComponents"}}},
1580c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}},
1581c5b2abe0SLewanczyk, Dawid             {boost::beast::http::verb::post, {{"ConfigureComponents"}}}};
1582c5b2abe0SLewanczyk, Dawid     }
1583c5b2abe0SLewanczyk, Dawid 
1584c5b2abe0SLewanczyk, Dawid   private:
1585c5b2abe0SLewanczyk, Dawid     /**
1586c5b2abe0SLewanczyk, Dawid      * Functions triggers appropriate requests on DBus
1587c5b2abe0SLewanczyk, Dawid      */
158855c7b7a2SEd Tanous     void doGet(crow::Response &res, const crow::Request &req,
15891abe55efSEd Tanous                const std::vector<std::string> &params) override
15901abe55efSEd Tanous     {
1591491d8ee7SSantosh Puranik         res.jsonValue["@odata.type"] = "#ComputerSystem.v1_6_0.ComputerSystem";
15920f74e643SEd Tanous         res.jsonValue["@odata.context"] =
15930f74e643SEd Tanous             "/redfish/v1/$metadata#ComputerSystem.ComputerSystem";
1594029573d4SEd Tanous         res.jsonValue["Name"] = "Computer System";
1595029573d4SEd Tanous         res.jsonValue["Id"] = "system";
15960f74e643SEd Tanous         res.jsonValue["SystemType"] = "Physical";
15970f74e643SEd Tanous         res.jsonValue["Description"] = "Computer System";
15980f74e643SEd Tanous         res.jsonValue["ProcessorSummary"]["Count"] = 0;
15990f74e643SEd Tanous         res.jsonValue["ProcessorSummary"]["Status"]["State"] = "Disabled";
16000f74e643SEd Tanous         res.jsonValue["MemorySummary"]["TotalSystemMemoryGiB"] = int(0);
16010f74e643SEd Tanous         res.jsonValue["MemorySummary"]["Status"]["State"] = "Disabled";
1602029573d4SEd Tanous         res.jsonValue["@odata.id"] = "/redfish/v1/Systems/system";
160304a258f4SEd Tanous 
1604443c2934SRapkiewicz, Pawel         res.jsonValue["Processors"] = {
1605029573d4SEd Tanous             {"@odata.id", "/redfish/v1/Systems/system/Processors"}};
1606443c2934SRapkiewicz, Pawel         res.jsonValue["Memory"] = {
1607029573d4SEd Tanous             {"@odata.id", "/redfish/v1/Systems/system/Memory"}};
1608a25aeccfSNikhil Potade         res.jsonValue["Storage"] = {
1609a25aeccfSNikhil Potade             {"@odata.id", "/redfish/v1/Systems/system/Storage"}};
1610029573d4SEd Tanous 
1611cc340dd9SEd Tanous         // TODO Need to support ForceRestart.
1612cc340dd9SEd Tanous         res.jsonValue["Actions"]["#ComputerSystem.Reset"] = {
1613cc340dd9SEd Tanous             {"target",
1614029573d4SEd Tanous              "/redfish/v1/Systems/system/Actions/ComputerSystem.Reset"},
1615cc340dd9SEd Tanous             {"ResetType@Redfish.AllowableValues",
1616d22c8396SJason M. Bills              {"On", "ForceOff", "ForceOn", "ForceRestart", "GracefulRestart",
1617bfd5b826SLakshminarayana R. Kammath               "GracefulShutdown", "PowerCycle", "Nmi"}}};
1618c5b2abe0SLewanczyk, Dawid 
1619c4bf6374SJason M. Bills         res.jsonValue["LogServices"] = {
1620029573d4SEd Tanous             {"@odata.id", "/redfish/v1/Systems/system/LogServices"}};
1621c4bf6374SJason M. Bills 
1622c5d03ff4SJennifer Lee         res.jsonValue["Links"]["ManagedBy"] = {
1623c5d03ff4SJennifer Lee             {{"@odata.id", "/redfish/v1/Managers/bmc"}}};
1624c5d03ff4SJennifer Lee 
1625c5d03ff4SJennifer Lee         res.jsonValue["Status"] = {
1626c5d03ff4SJennifer Lee             {"Health", "OK"},
1627c5d03ff4SJennifer Lee             {"State", "Enabled"},
1628c5d03ff4SJennifer Lee         };
1629a0803efaSEd Tanous         auto asyncResp = std::make_shared<AsyncResp>(res);
1630c5b2abe0SLewanczyk, Dawid 
1631*2ad9c2f6SJames Feist         constexpr const std::array<const char *, 3> inventoryForSystems = {
1632b49ac873SJames Feist             "xyz.openbmc_project.Inventory.Item.Dimm",
1633*2ad9c2f6SJames Feist             "xyz.openbmc_project.Inventory.Item.Cpu",
1634*2ad9c2f6SJames Feist             "xyz.openbmc_project.Inventory.Item.Drive"};
1635b49ac873SJames Feist 
1636b49ac873SJames Feist         auto health = std::make_shared<HealthPopulate>(asyncResp);
1637b49ac873SJames Feist         crow::connections::systemBus->async_method_call(
1638b49ac873SJames Feist             [health](const boost::system::error_code ec,
1639b49ac873SJames Feist                      std::vector<std::string> &resp) {
1640b49ac873SJames Feist                 if (ec)
1641b49ac873SJames Feist                 {
1642b49ac873SJames Feist                     // no inventory
1643b49ac873SJames Feist                     return;
1644b49ac873SJames Feist                 }
1645b49ac873SJames Feist 
1646b49ac873SJames Feist                 health->inventory = std::move(resp);
1647b49ac873SJames Feist             },
1648b49ac873SJames Feist             "xyz.openbmc_project.ObjectMapper",
1649b49ac873SJames Feist             "/xyz/openbmc_project/object_mapper",
1650b49ac873SJames Feist             "xyz.openbmc_project.ObjectMapper", "GetSubTreePaths", "/",
1651b49ac873SJames Feist             int32_t(0), inventoryForSystems);
1652b49ac873SJames Feist 
1653b49ac873SJames Feist         health->populate();
1654b49ac873SJames Feist 
1655c5d03ff4SJennifer Lee         getMainChassisId(asyncResp, [](const std::string &chassisId,
1656c5d03ff4SJennifer Lee                                        std::shared_ptr<AsyncResp> aRsp) {
1657c5d03ff4SJennifer Lee             aRsp->res.jsonValue["Links"]["Chassis"] = {
1658c5d03ff4SJennifer Lee                 {{"@odata.id", "/redfish/v1/Chassis/" + chassisId}}};
1659c5d03ff4SJennifer Lee         });
16606c34de48SEd Tanous         getLedGroupIdentify(
1661a0803efaSEd Tanous             asyncResp,
1662fc41ff6eSCarol Wang             [](bool asserted, const std::shared_ptr<AsyncResp> aRsp) {
16631abe55efSEd Tanous                 if (asserted)
16641abe55efSEd Tanous                 {
1665fc41ff6eSCarol Wang                     aRsp->res.jsonValue["IndicatorLED"] = "On";
16661abe55efSEd Tanous                 }
16671abe55efSEd Tanous                 else
16681abe55efSEd Tanous                 {
1669c5d03ff4SJennifer Lee                     aRsp->res.jsonValue["IndicatorLED"] = "Off";
1670c5b2abe0SLewanczyk, Dawid                 }
1671c5b2abe0SLewanczyk, Dawid             });
16725bc2dc8eSJames Feist         getComputerSystem(asyncResp, health);
16736c34de48SEd Tanous         getHostState(asyncResp);
1674491d8ee7SSantosh Puranik         getBootProperties(asyncResp);
1675adbe192aSJason M. Bills         getPCIeDeviceList(asyncResp, "PCIeDevices");
167651709ffdSYong Li         getHostWatchdogTimer(asyncResp);
1677a6349918SAppaRao Puli #ifdef BMCWEB_ENABLE_REDFISH_PROVISIONING_FEATURE
1678a6349918SAppaRao Puli         getProvisioningStatus(asyncResp);
1679a6349918SAppaRao Puli #endif
1680c5b2abe0SLewanczyk, Dawid     }
1681c5b2abe0SLewanczyk, Dawid 
168255c7b7a2SEd Tanous     void doPatch(crow::Response &res, const crow::Request &req,
16831abe55efSEd Tanous                  const std::vector<std::string> &params) override
16841abe55efSEd Tanous     {
1685cde19e5fSSantosh Puranik         std::optional<std::string> indicatorLed;
1686491d8ee7SSantosh Puranik         std::optional<nlohmann::json> bootProps;
1687c45f0082SYong Li         std::optional<nlohmann::json> wdtTimerProps;
168841352c24SSantosh Puranik         auto asyncResp = std::make_shared<AsyncResp>(res);
168941352c24SSantosh Puranik 
1690944ffaf9SJohnathan Mantey         if (!json_util::readJson(req, res, "IndicatorLED", indicatorLed, "Boot",
1691c45f0082SYong Li                                  bootProps, "WatchdogTimer", wdtTimerProps))
16926617338dSEd Tanous         {
16936617338dSEd Tanous             return;
16946617338dSEd Tanous         }
1695491d8ee7SSantosh Puranik 
1696944ffaf9SJohnathan Mantey         res.result(boost::beast::http::status::no_content);
1697c45f0082SYong Li 
1698c45f0082SYong Li         if (wdtTimerProps)
1699c45f0082SYong Li         {
1700c45f0082SYong Li             std::optional<bool> wdtEnable;
1701c45f0082SYong Li             std::optional<std::string> wdtTimeOutAction;
1702c45f0082SYong Li 
1703c45f0082SYong Li             if (!json_util::readJson(*wdtTimerProps, asyncResp->res,
1704c45f0082SYong Li                                      "FunctionEnabled", wdtEnable,
1705c45f0082SYong Li                                      "TimeoutAction", wdtTimeOutAction))
1706c45f0082SYong Li             {
1707c45f0082SYong Li                 return;
1708c45f0082SYong Li             }
1709c45f0082SYong Li             setWDTProperties(asyncResp, std::move(wdtEnable),
1710c45f0082SYong Li                              std::move(wdtTimeOutAction));
1711c45f0082SYong Li         }
1712c45f0082SYong Li 
1713491d8ee7SSantosh Puranik         if (bootProps)
1714491d8ee7SSantosh Puranik         {
1715491d8ee7SSantosh Puranik             std::optional<std::string> bootSource;
1716491d8ee7SSantosh Puranik             std::optional<std::string> bootEnable;
1717491d8ee7SSantosh Puranik 
1718491d8ee7SSantosh Puranik             if (!json_util::readJson(*bootProps, asyncResp->res,
1719491d8ee7SSantosh Puranik                                      "BootSourceOverrideTarget", bootSource,
1720491d8ee7SSantosh Puranik                                      "BootSourceOverrideEnabled", bootEnable))
1721491d8ee7SSantosh Puranik             {
1722491d8ee7SSantosh Puranik                 return;
1723491d8ee7SSantosh Puranik             }
1724491d8ee7SSantosh Puranik             setBootProperties(asyncResp, std::move(bootSource),
1725491d8ee7SSantosh Puranik                               std::move(bootEnable));
1726491d8ee7SSantosh Puranik         }
1727265c1602SJohnathan Mantey 
17289712f8acSEd Tanous         if (indicatorLed)
17296617338dSEd Tanous         {
17309712f8acSEd Tanous             std::string dbusLedState;
1731d573bb2aSJennifer Lee             if (*indicatorLed == "Lit")
17329712f8acSEd Tanous             {
1733d573bb2aSJennifer Lee                 dbusLedState = "xyz.openbmc_project.Led.Physical.Action.On";
17346617338dSEd Tanous             }
17355c6221acSGunnar Mills             else if (*indicatorLed == "Blinking")
17366617338dSEd Tanous             {
17375c6221acSGunnar Mills                 dbusLedState = "xyz.openbmc_project.Led.Physical.Action.Blink";
17386617338dSEd Tanous             }
17399712f8acSEd Tanous             else if (*indicatorLed == "Off")
17406617338dSEd Tanous             {
17419712f8acSEd Tanous                 dbusLedState = "xyz.openbmc_project.Led.Physical.Action.Off";
17426617338dSEd Tanous             }
17436617338dSEd Tanous             else
17446617338dSEd Tanous             {
1745a08b46ccSJason M. Bills                 messages::propertyValueNotInList(res, *indicatorLed,
1746a08b46ccSJason M. Bills                                                  "IndicatorLED");
17476617338dSEd Tanous                 return;
17486617338dSEd Tanous             }
17496617338dSEd Tanous 
1750c5b2abe0SLewanczyk, Dawid             // Update led group
175155c7b7a2SEd Tanous             BMCWEB_LOG_DEBUG << "Update led group.";
175255c7b7a2SEd Tanous             crow::connections::systemBus->async_method_call(
1753cde19e5fSSantosh Puranik                 [asyncResp](const boost::system::error_code ec) {
17541abe55efSEd Tanous                     if (ec)
17551abe55efSEd Tanous                     {
175655c7b7a2SEd Tanous                         BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1757f12894f8SJason M. Bills                         messages::internalError(asyncResp->res);
1758c5b2abe0SLewanczyk, Dawid                         return;
1759c5b2abe0SLewanczyk, Dawid                     }
176055c7b7a2SEd Tanous                     BMCWEB_LOG_DEBUG << "Led group update done.";
1761c5b2abe0SLewanczyk, Dawid                 },
1762c5b2abe0SLewanczyk, Dawid                 "xyz.openbmc_project.LED.GroupManager",
1763c5b2abe0SLewanczyk, Dawid                 "/xyz/openbmc_project/led/groups/enclosure_identify",
1764c5b2abe0SLewanczyk, Dawid                 "org.freedesktop.DBus.Properties", "Set",
1765c5b2abe0SLewanczyk, Dawid                 "xyz.openbmc_project.Led.Group", "Asserted",
1766abf2add6SEd Tanous                 std::variant<bool>(
1767265c1602SJohnathan Mantey                     (dbusLedState !=
1768265c1602SJohnathan Mantey                      "xyz.openbmc_project.Led.Physical.Action.Off")));
1769265c1602SJohnathan Mantey 
1770c5b2abe0SLewanczyk, Dawid             // Update identify led status
177155c7b7a2SEd Tanous             BMCWEB_LOG_DEBUG << "Update led SoftwareInventoryCollection.";
177255c7b7a2SEd Tanous             crow::connections::systemBus->async_method_call(
1773265c1602SJohnathan Mantey                 [asyncResp](const boost::system::error_code ec) {
17741abe55efSEd Tanous                     if (ec)
17751abe55efSEd Tanous                     {
177655c7b7a2SEd Tanous                         BMCWEB_LOG_DEBUG << "DBUS response error " << ec;
1777f12894f8SJason M. Bills                         messages::internalError(asyncResp->res);
1778c5b2abe0SLewanczyk, Dawid                         return;
1779c5b2abe0SLewanczyk, Dawid                     }
178055c7b7a2SEd Tanous                     BMCWEB_LOG_DEBUG << "Led state update done.";
1781c5b2abe0SLewanczyk, Dawid                 },
1782c5b2abe0SLewanczyk, Dawid                 "xyz.openbmc_project.LED.Controller.identify",
1783c5b2abe0SLewanczyk, Dawid                 "/xyz/openbmc_project/led/physical/identify",
1784c5b2abe0SLewanczyk, Dawid                 "org.freedesktop.DBus.Properties", "Set",
1785c5b2abe0SLewanczyk, Dawid                 "xyz.openbmc_project.Led.Physical", "State",
1786abf2add6SEd Tanous                 std::variant<std::string>(dbusLedState));
17876617338dSEd Tanous         }
1788c5b2abe0SLewanczyk, Dawid     }
1789c5b2abe0SLewanczyk, Dawid };
1790c5b2abe0SLewanczyk, Dawid } // namespace redfish
1791