1c5b2abe0SLewanczyk, Dawid /* 2c5b2abe0SLewanczyk, Dawid // Copyright (c) 2018 Intel Corporation 3c5b2abe0SLewanczyk, Dawid // 4c5b2abe0SLewanczyk, Dawid // Licensed under the Apache License, Version 2.0 (the "License"); 5c5b2abe0SLewanczyk, Dawid // you may not use this file except in compliance with the License. 6c5b2abe0SLewanczyk, Dawid // You may obtain a copy of the License at 7c5b2abe0SLewanczyk, Dawid // 8c5b2abe0SLewanczyk, Dawid // http://www.apache.org/licenses/LICENSE-2.0 9c5b2abe0SLewanczyk, Dawid // 10c5b2abe0SLewanczyk, Dawid // Unless required by applicable law or agreed to in writing, software 11c5b2abe0SLewanczyk, Dawid // distributed under the License is distributed on an "AS IS" BASIS, 12c5b2abe0SLewanczyk, Dawid // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13c5b2abe0SLewanczyk, Dawid // See the License for the specific language governing permissions and 14c5b2abe0SLewanczyk, Dawid // limitations under the License. 15c5b2abe0SLewanczyk, Dawid */ 16c5b2abe0SLewanczyk, Dawid #pragma once 17c5b2abe0SLewanczyk, Dawid 18b49ac873SJames Feist #include "health.hpp" 191c8fba97SJames Feist #include "led.hpp" 20f5c9f8bdSJason M. Bills #include "pcie.hpp" 21c5d03ff4SJennifer Lee #include "redfish_util.hpp" 22c5d03ff4SJennifer Lee 239712f8acSEd Tanous #include <boost/container/flat_map.hpp> 249712f8acSEd Tanous #include <node.hpp> 25cb7e1e7bSAndrew Geissler #include <utils/fw_utils.hpp> 26c5b2abe0SLewanczyk, Dawid #include <utils/json_utils.hpp> 27abf2add6SEd Tanous #include <variant> 28c5b2abe0SLewanczyk, Dawid 291abe55efSEd Tanous namespace redfish 301abe55efSEd Tanous { 31c5b2abe0SLewanczyk, Dawid 329d3ae10eSAlpana Kumari /** 339d3ae10eSAlpana Kumari * @brief Updates the Functional State of DIMMs 349d3ae10eSAlpana Kumari * 359d3ae10eSAlpana Kumari * @param[in] aResp Shared pointer for completing asynchronous calls 369d3ae10eSAlpana Kumari * @param[in] dimmState Dimm's Functional state, true/false 379d3ae10eSAlpana Kumari * 389d3ae10eSAlpana Kumari * @return None. 399d3ae10eSAlpana Kumari */ 409d3ae10eSAlpana Kumari void updateDimmProperties(std::shared_ptr<AsyncResp> aResp, 419d3ae10eSAlpana Kumari const std::variant<bool> &dimmState) 429d3ae10eSAlpana Kumari { 439d3ae10eSAlpana Kumari const bool *isDimmFunctional = std::get_if<bool>(&dimmState); 449d3ae10eSAlpana Kumari if (isDimmFunctional == nullptr) 459d3ae10eSAlpana Kumari { 469d3ae10eSAlpana Kumari messages::internalError(aResp->res); 479d3ae10eSAlpana Kumari return; 489d3ae10eSAlpana Kumari } 499d3ae10eSAlpana Kumari BMCWEB_LOG_DEBUG << "Dimm Functional: " << *isDimmFunctional; 509d3ae10eSAlpana Kumari 519d3ae10eSAlpana Kumari // Set it as Enabled if atleast one DIMM is functional 529d3ae10eSAlpana Kumari // Update STATE only if previous State was DISABLED and current Dimm is 539d3ae10eSAlpana Kumari // ENABLED. 549d3ae10eSAlpana Kumari nlohmann::json &prevMemSummary = 559d3ae10eSAlpana Kumari aResp->res.jsonValue["MemorySummary"]["Status"]["State"]; 569d3ae10eSAlpana Kumari if (prevMemSummary == "Disabled") 579d3ae10eSAlpana Kumari { 589d3ae10eSAlpana Kumari if (*isDimmFunctional == true) 599d3ae10eSAlpana Kumari { 609d3ae10eSAlpana Kumari aResp->res.jsonValue["MemorySummary"]["Status"]["State"] = 619d3ae10eSAlpana Kumari "Enabled"; 629d3ae10eSAlpana Kumari } 639d3ae10eSAlpana Kumari } 649d3ae10eSAlpana Kumari } 659d3ae10eSAlpana Kumari 6657e8c9beSAlpana Kumari /* 6757e8c9beSAlpana Kumari * @brief Update "ProcessorSummary" "Count" based on Cpu PresenceState 6857e8c9beSAlpana Kumari * 6957e8c9beSAlpana Kumari * @param[in] aResp Shared pointer for completing asynchronous calls 7057e8c9beSAlpana Kumari * @param[in] cpuPresenceState CPU present or not 7157e8c9beSAlpana Kumari * 7257e8c9beSAlpana Kumari * @return None. 7357e8c9beSAlpana Kumari */ 7457e8c9beSAlpana Kumari void modifyCpuPresenceState(std::shared_ptr<AsyncResp> aResp, 7557e8c9beSAlpana Kumari const std::variant<bool> &cpuPresenceState) 7657e8c9beSAlpana Kumari { 7757e8c9beSAlpana Kumari const bool *isCpuPresent = std::get_if<bool>(&cpuPresenceState); 7857e8c9beSAlpana Kumari 7957e8c9beSAlpana Kumari if (isCpuPresent == nullptr) 8057e8c9beSAlpana Kumari { 8157e8c9beSAlpana Kumari messages::internalError(aResp->res); 8257e8c9beSAlpana Kumari return; 8357e8c9beSAlpana Kumari } 8457e8c9beSAlpana Kumari BMCWEB_LOG_DEBUG << "Cpu Present: " << *isCpuPresent; 8557e8c9beSAlpana Kumari 8657e8c9beSAlpana Kumari if (*isCpuPresent == true) 8757e8c9beSAlpana Kumari { 88b4b9595aSJames Feist nlohmann::json &procCount = 89b4b9595aSJames Feist aResp->res.jsonValue["ProcessorSummary"]["Count"]; 90b4b9595aSJames Feist auto procCountPtr = 91b4b9595aSJames Feist procCount.get_ptr<nlohmann::json::number_integer_t *>(); 92b4b9595aSJames Feist if (procCountPtr != nullptr) 93b4b9595aSJames Feist { 94b4b9595aSJames Feist // shouldn't be possible to be nullptr 95b4b9595aSJames Feist *procCountPtr += 1; 9657e8c9beSAlpana Kumari } 97b4b9595aSJames Feist } 9857e8c9beSAlpana Kumari } 9957e8c9beSAlpana Kumari 10057e8c9beSAlpana Kumari /* 10157e8c9beSAlpana Kumari * @brief Update "ProcessorSummary" "Status" "State" based on 10257e8c9beSAlpana Kumari * CPU Functional State 10357e8c9beSAlpana Kumari * 10457e8c9beSAlpana Kumari * @param[in] aResp Shared pointer for completing asynchronous calls 10557e8c9beSAlpana Kumari * @param[in] cpuFunctionalState is CPU functional true/false 10657e8c9beSAlpana Kumari * 10757e8c9beSAlpana Kumari * @return None. 10857e8c9beSAlpana Kumari */ 10957e8c9beSAlpana Kumari void modifyCpuFunctionalState(std::shared_ptr<AsyncResp> aResp, 11057e8c9beSAlpana Kumari const std::variant<bool> &cpuFunctionalState) 11157e8c9beSAlpana Kumari { 11257e8c9beSAlpana Kumari const bool *isCpuFunctional = std::get_if<bool>(&cpuFunctionalState); 11357e8c9beSAlpana Kumari 11457e8c9beSAlpana Kumari if (isCpuFunctional == nullptr) 11557e8c9beSAlpana Kumari { 11657e8c9beSAlpana Kumari messages::internalError(aResp->res); 11757e8c9beSAlpana Kumari return; 11857e8c9beSAlpana Kumari } 11957e8c9beSAlpana Kumari BMCWEB_LOG_DEBUG << "Cpu Functional: " << *isCpuFunctional; 12057e8c9beSAlpana Kumari 12157e8c9beSAlpana Kumari nlohmann::json &prevProcState = 12257e8c9beSAlpana Kumari aResp->res.jsonValue["ProcessorSummary"]["Status"]["State"]; 12357e8c9beSAlpana Kumari 12457e8c9beSAlpana Kumari // Set it as Enabled if atleast one CPU is functional 12557e8c9beSAlpana Kumari // Update STATE only if previous State was Non_Functional and current CPU is 12657e8c9beSAlpana Kumari // Functional. 12757e8c9beSAlpana Kumari if (prevProcState == "Disabled") 12857e8c9beSAlpana Kumari { 12957e8c9beSAlpana Kumari if (*isCpuFunctional == true) 13057e8c9beSAlpana Kumari { 13157e8c9beSAlpana Kumari aResp->res.jsonValue["ProcessorSummary"]["Status"]["State"] = 13257e8c9beSAlpana Kumari "Enabled"; 13357e8c9beSAlpana Kumari } 13457e8c9beSAlpana Kumari } 13557e8c9beSAlpana Kumari } 13657e8c9beSAlpana Kumari 13757e8c9beSAlpana Kumari /* 138c5b2abe0SLewanczyk, Dawid * @brief Retrieves computer system properties over dbus 139c5b2abe0SLewanczyk, Dawid * 140c5b2abe0SLewanczyk, Dawid * @param[in] aResp Shared pointer for completing asynchronous calls 141c5b2abe0SLewanczyk, Dawid * @param[in] name Computer system name from request 142c5b2abe0SLewanczyk, Dawid * 143c5b2abe0SLewanczyk, Dawid * @return None. 144c5b2abe0SLewanczyk, Dawid */ 1455bc2dc8eSJames Feist void getComputerSystem(std::shared_ptr<AsyncResp> aResp, 1465bc2dc8eSJames Feist std::shared_ptr<HealthPopulate> systemHealth) 1471abe55efSEd Tanous { 14855c7b7a2SEd Tanous BMCWEB_LOG_DEBUG << "Get available system components."; 1499d3ae10eSAlpana Kumari 15055c7b7a2SEd Tanous crow::connections::systemBus->async_method_call( 1515bc2dc8eSJames Feist [aResp, systemHealth]( 152c5b2abe0SLewanczyk, Dawid const boost::system::error_code ec, 153c5b2abe0SLewanczyk, Dawid const std::vector<std::pair< 1546c34de48SEd Tanous std::string, 1556c34de48SEd Tanous std::vector<std::pair<std::string, std::vector<std::string>>>>> 156c5b2abe0SLewanczyk, Dawid &subtree) { 1571abe55efSEd Tanous if (ec) 1581abe55efSEd Tanous { 15955c7b7a2SEd Tanous BMCWEB_LOG_DEBUG << "DBUS response error"; 160f12894f8SJason M. Bills messages::internalError(aResp->res); 161c5b2abe0SLewanczyk, Dawid return; 162c5b2abe0SLewanczyk, Dawid } 163c5b2abe0SLewanczyk, Dawid // Iterate over all retrieved ObjectPaths. 1646c34de48SEd Tanous for (const std::pair<std::string, 1656c34de48SEd Tanous std::vector<std::pair< 1666c34de48SEd Tanous std::string, std::vector<std::string>>>> 1671abe55efSEd Tanous &object : subtree) 1681abe55efSEd Tanous { 169c5b2abe0SLewanczyk, Dawid const std::string &path = object.first; 17055c7b7a2SEd Tanous BMCWEB_LOG_DEBUG << "Got path: " << path; 1711abe55efSEd Tanous const std::vector< 1721abe55efSEd Tanous std::pair<std::string, std::vector<std::string>>> 173c5b2abe0SLewanczyk, Dawid &connectionNames = object.second; 1741abe55efSEd Tanous if (connectionNames.size() < 1) 1751abe55efSEd Tanous { 176c5b2abe0SLewanczyk, Dawid continue; 177c5b2abe0SLewanczyk, Dawid } 178029573d4SEd Tanous 1795bc2dc8eSJames Feist auto memoryHealth = std::make_shared<HealthPopulate>( 1805bc2dc8eSJames Feist aResp, aResp->res.jsonValue["MemorySummary"]["Status"]); 1815bc2dc8eSJames Feist 1825bc2dc8eSJames Feist auto cpuHealth = std::make_shared<HealthPopulate>( 1835bc2dc8eSJames Feist aResp, aResp->res.jsonValue["ProcessorSummary"]["Status"]); 1845bc2dc8eSJames Feist 1855bc2dc8eSJames Feist systemHealth->children.emplace_back(memoryHealth); 1865bc2dc8eSJames Feist systemHealth->children.emplace_back(cpuHealth); 1875bc2dc8eSJames Feist 1886c34de48SEd Tanous // This is not system, so check if it's cpu, dimm, UUID or 1896c34de48SEd Tanous // BiosVer 19004a258f4SEd Tanous for (const auto &connection : connectionNames) 1911abe55efSEd Tanous { 19204a258f4SEd Tanous for (const auto &interfaceName : connection.second) 1931abe55efSEd Tanous { 19404a258f4SEd Tanous if (interfaceName == 19504a258f4SEd Tanous "xyz.openbmc_project.Inventory.Item.Dimm") 1961abe55efSEd Tanous { 1971abe55efSEd Tanous BMCWEB_LOG_DEBUG 19804a258f4SEd Tanous << "Found Dimm, now get its properties."; 1999d3ae10eSAlpana Kumari 20055c7b7a2SEd Tanous crow::connections::systemBus->async_method_call( 2019d3ae10eSAlpana Kumari [aResp, service{connection.first}, 2029d3ae10eSAlpana Kumari path(std::move(path))]( 2039d3ae10eSAlpana Kumari const boost::system::error_code ec, 2046c34de48SEd Tanous const std::vector< 2056c34de48SEd Tanous std::pair<std::string, VariantType>> 2061abe55efSEd Tanous &properties) { 2071abe55efSEd Tanous if (ec) 2081abe55efSEd Tanous { 2091abe55efSEd Tanous BMCWEB_LOG_ERROR 2106c34de48SEd Tanous << "DBUS response error " << ec; 211f12894f8SJason M. Bills messages::internalError(aResp->res); 212c5b2abe0SLewanczyk, Dawid return; 213c5b2abe0SLewanczyk, Dawid } 2146c34de48SEd Tanous BMCWEB_LOG_DEBUG << "Got " 2156c34de48SEd Tanous << properties.size() 216c5b2abe0SLewanczyk, Dawid << " Dimm properties."; 2179d3ae10eSAlpana Kumari 2189d3ae10eSAlpana Kumari if (properties.size() > 0) 2199d3ae10eSAlpana Kumari { 22004a258f4SEd Tanous for (const std::pair<std::string, 22104a258f4SEd Tanous VariantType> 22204a258f4SEd Tanous &property : properties) 2231abe55efSEd Tanous { 2245fd7ba65SCheng C Yang if (property.first != 2255fd7ba65SCheng C Yang "MemorySizeInKB") 2261abe55efSEd Tanous { 2275fd7ba65SCheng C Yang continue; 2285fd7ba65SCheng C Yang } 2295fd7ba65SCheng C Yang const uint32_t *value = 2305fd7ba65SCheng C Yang sdbusplus::message::variant_ns:: 2315fd7ba65SCheng C Yang get_if<uint32_t>( 2321b6b96c5SEd Tanous &property.second); 2335fd7ba65SCheng C Yang if (value == nullptr) 2341abe55efSEd Tanous { 2355fd7ba65SCheng C Yang BMCWEB_LOG_DEBUG 2365fd7ba65SCheng C Yang << "Find incorrect type of " 2375fd7ba65SCheng C Yang "MemorySize"; 2385fd7ba65SCheng C Yang continue; 2395fd7ba65SCheng C Yang } 2405fd7ba65SCheng C Yang nlohmann::json &totalMemory = 2415fd7ba65SCheng C Yang aResp->res 2425fd7ba65SCheng C Yang .jsonValue["MemorySummar" 2435fd7ba65SCheng C Yang "y"] 2445fd7ba65SCheng C Yang ["TotalSystemMe" 2455fd7ba65SCheng C Yang "moryGiB"]; 2465fd7ba65SCheng C Yang uint64_t *preValue = 2475fd7ba65SCheng C Yang totalMemory 2485fd7ba65SCheng C Yang .get_ptr<uint64_t *>(); 2495fd7ba65SCheng C Yang if (preValue == nullptr) 2505fd7ba65SCheng C Yang { 2515fd7ba65SCheng C Yang continue; 2525fd7ba65SCheng C Yang } 2535fd7ba65SCheng C Yang aResp->res 2545fd7ba65SCheng C Yang .jsonValue["MemorySummary"] 2556c34de48SEd Tanous ["TotalSystemMemoryGi" 2565fd7ba65SCheng C Yang "B"] = 2575fd7ba65SCheng C Yang *value / (1024 * 1024) + 2585fd7ba65SCheng C Yang *preValue; 2595fd7ba65SCheng C Yang aResp->res 2605fd7ba65SCheng C Yang .jsonValue["MemorySummary"] 2619d3ae10eSAlpana Kumari ["Status"]["State"] = 2621abe55efSEd Tanous "Enabled"; 263c5b2abe0SLewanczyk, Dawid } 264c5b2abe0SLewanczyk, Dawid } 2659d3ae10eSAlpana Kumari else 2669d3ae10eSAlpana Kumari { 2679d3ae10eSAlpana Kumari auto getDimmProperties = 2689d3ae10eSAlpana Kumari [aResp]( 2699d3ae10eSAlpana Kumari const boost::system::error_code 2709d3ae10eSAlpana Kumari ec, 2719d3ae10eSAlpana Kumari const std::variant<bool> 2729d3ae10eSAlpana Kumari &dimmState) { 2739d3ae10eSAlpana Kumari if (ec) 2749d3ae10eSAlpana Kumari { 2759d3ae10eSAlpana Kumari BMCWEB_LOG_ERROR 2769d3ae10eSAlpana Kumari << "DBUS response " 2779d3ae10eSAlpana Kumari "error " 2789d3ae10eSAlpana Kumari << ec; 2799d3ae10eSAlpana Kumari return; 2809d3ae10eSAlpana Kumari } 2819d3ae10eSAlpana Kumari updateDimmProperties(aResp, 2829d3ae10eSAlpana Kumari dimmState); 2839d3ae10eSAlpana Kumari }; 2849d3ae10eSAlpana Kumari crow::connections::systemBus 2859d3ae10eSAlpana Kumari ->async_method_call( 2869d3ae10eSAlpana Kumari std::move(getDimmProperties), 2879d3ae10eSAlpana Kumari service, path, 2889d3ae10eSAlpana Kumari "org.freedesktop.DBus." 2899d3ae10eSAlpana Kumari "Properties", 2909d3ae10eSAlpana Kumari "Get", 2919d3ae10eSAlpana Kumari "xyz.openbmc_project.State." 2929d3ae10eSAlpana Kumari "Decorator.OperationalStatus", 2939d3ae10eSAlpana Kumari "Functional"); 2949d3ae10eSAlpana Kumari } 295c5b2abe0SLewanczyk, Dawid }, 29604a258f4SEd Tanous connection.first, path, 2976c34de48SEd Tanous "org.freedesktop.DBus.Properties", "GetAll", 2986c34de48SEd Tanous "xyz.openbmc_project.Inventory.Item.Dimm"); 2995bc2dc8eSJames Feist 3005bc2dc8eSJames Feist memoryHealth->inventory.emplace_back(path); 3011abe55efSEd Tanous } 30204a258f4SEd Tanous else if (interfaceName == 30304a258f4SEd Tanous "xyz.openbmc_project.Inventory.Item.Cpu") 3041abe55efSEd Tanous { 3051abe55efSEd Tanous BMCWEB_LOG_DEBUG 30604a258f4SEd Tanous << "Found Cpu, now get its properties."; 30757e8c9beSAlpana Kumari 308a0803efaSEd Tanous crow::connections::systemBus->async_method_call( 30957e8c9beSAlpana Kumari [aResp, service{connection.first}, 31057e8c9beSAlpana Kumari path(std::move(path))]( 31157e8c9beSAlpana Kumari const boost::system::error_code ec, 3126c34de48SEd Tanous const std::vector< 3136c34de48SEd Tanous std::pair<std::string, VariantType>> 3141abe55efSEd Tanous &properties) { 3151abe55efSEd Tanous if (ec) 3161abe55efSEd Tanous { 3171abe55efSEd Tanous BMCWEB_LOG_ERROR 3186c34de48SEd Tanous << "DBUS response error " << ec; 319f12894f8SJason M. Bills messages::internalError(aResp->res); 320c5b2abe0SLewanczyk, Dawid return; 321c5b2abe0SLewanczyk, Dawid } 3226c34de48SEd Tanous BMCWEB_LOG_DEBUG << "Got " 3236c34de48SEd Tanous << properties.size() 324c5b2abe0SLewanczyk, Dawid << " Cpu properties."; 32557e8c9beSAlpana Kumari 32657e8c9beSAlpana Kumari if (properties.size() > 0) 32757e8c9beSAlpana Kumari { 32804a258f4SEd Tanous for (const auto &property : properties) 3291abe55efSEd Tanous { 33057e8c9beSAlpana Kumari if (property.first == 33157e8c9beSAlpana Kumari "ProcessorFamily") 3321abe55efSEd Tanous { 333a0803efaSEd Tanous const std::string *value = 33457e8c9beSAlpana Kumari sdbusplus::message:: 33557e8c9beSAlpana Kumari variant_ns::get_if< 33657e8c9beSAlpana Kumari std::string>( 3371b6b96c5SEd Tanous &property.second); 3381abe55efSEd Tanous if (value != nullptr) 3391abe55efSEd Tanous { 34057e8c9beSAlpana Kumari nlohmann::json 34157e8c9beSAlpana Kumari &procSummary = 3421abe55efSEd Tanous aResp->res.jsonValue 3436c34de48SEd Tanous ["ProcessorSumm" 34404a258f4SEd Tanous "ary"]; 34504a258f4SEd Tanous nlohmann::json &procCount = 34604a258f4SEd Tanous procSummary["Count"]; 347b4b9595aSJames Feist 348b4b9595aSJames Feist auto procCountPtr = 349b4b9595aSJames Feist procCount.get_ptr< 350b4b9595aSJames Feist nlohmann::json:: 351b4b9595aSJames Feist number_integer_t 352b4b9595aSJames Feist *>(); 353b4b9595aSJames Feist if (procCountPtr != nullptr) 354b4b9595aSJames Feist { 355b4b9595aSJames Feist // shouldn't be possible 356b4b9595aSJames Feist // to be nullptr 357b4b9595aSJames Feist *procCountPtr += 1; 358b4b9595aSJames Feist } 35957e8c9beSAlpana Kumari procSummary["Status"] 36057e8c9beSAlpana Kumari ["State"] = 361c5b2abe0SLewanczyk, Dawid "Enabled"; 36257e8c9beSAlpana Kumari procSummary["Model"] = 36357e8c9beSAlpana Kumari *value; 364c5b2abe0SLewanczyk, Dawid } 365c5b2abe0SLewanczyk, Dawid } 366c5b2abe0SLewanczyk, Dawid } 36757e8c9beSAlpana Kumari } 36857e8c9beSAlpana Kumari else 36957e8c9beSAlpana Kumari { 37057e8c9beSAlpana Kumari auto getCpuPresenceState = 37157e8c9beSAlpana Kumari [aResp]( 37257e8c9beSAlpana Kumari const boost::system::error_code 37357e8c9beSAlpana Kumari ec, 37457e8c9beSAlpana Kumari const std::variant<bool> 37557e8c9beSAlpana Kumari &cpuPresenceCheck) { 37657e8c9beSAlpana Kumari if (ec) 37757e8c9beSAlpana Kumari { 37857e8c9beSAlpana Kumari BMCWEB_LOG_ERROR 37957e8c9beSAlpana Kumari << "DBUS response " 38057e8c9beSAlpana Kumari "error " 38157e8c9beSAlpana Kumari << ec; 38257e8c9beSAlpana Kumari return; 38357e8c9beSAlpana Kumari } 38457e8c9beSAlpana Kumari modifyCpuPresenceState( 38557e8c9beSAlpana Kumari aResp, cpuPresenceCheck); 38657e8c9beSAlpana Kumari }; 38757e8c9beSAlpana Kumari 38857e8c9beSAlpana Kumari auto getCpuFunctionalState = 38957e8c9beSAlpana Kumari [aResp]( 39057e8c9beSAlpana Kumari const boost::system::error_code 39157e8c9beSAlpana Kumari ec, 39257e8c9beSAlpana Kumari const std::variant<bool> 39357e8c9beSAlpana Kumari &cpuFunctionalCheck) { 39457e8c9beSAlpana Kumari if (ec) 39557e8c9beSAlpana Kumari { 39657e8c9beSAlpana Kumari BMCWEB_LOG_ERROR 39757e8c9beSAlpana Kumari << "DBUS response " 39857e8c9beSAlpana Kumari "error " 39957e8c9beSAlpana Kumari << ec; 40057e8c9beSAlpana Kumari return; 40157e8c9beSAlpana Kumari } 40257e8c9beSAlpana Kumari modifyCpuFunctionalState( 40357e8c9beSAlpana Kumari aResp, cpuFunctionalCheck); 40457e8c9beSAlpana Kumari }; 40557e8c9beSAlpana Kumari // Get the Presence of CPU 40657e8c9beSAlpana Kumari crow::connections::systemBus 40757e8c9beSAlpana Kumari ->async_method_call( 40857e8c9beSAlpana Kumari std::move(getCpuPresenceState), 40957e8c9beSAlpana Kumari service, path, 41057e8c9beSAlpana Kumari "org.freedesktop.DBus." 41157e8c9beSAlpana Kumari "Properties", 41257e8c9beSAlpana Kumari "Get", 41357e8c9beSAlpana Kumari "xyz.openbmc_project.Inventory." 41457e8c9beSAlpana Kumari "Item", 41557e8c9beSAlpana Kumari "Present"); 41657e8c9beSAlpana Kumari 41757e8c9beSAlpana Kumari // Get the Functional State 41857e8c9beSAlpana Kumari crow::connections::systemBus 41957e8c9beSAlpana Kumari ->async_method_call( 42057e8c9beSAlpana Kumari std::move( 42157e8c9beSAlpana Kumari getCpuFunctionalState), 42257e8c9beSAlpana Kumari service, path, 42357e8c9beSAlpana Kumari "org.freedesktop.DBus." 42457e8c9beSAlpana Kumari "Properties", 42557e8c9beSAlpana Kumari "Get", 42657e8c9beSAlpana Kumari "xyz.openbmc_project.State." 42757e8c9beSAlpana Kumari "Decorator." 42857e8c9beSAlpana Kumari "OperationalStatus", 42957e8c9beSAlpana Kumari "Functional"); 43057e8c9beSAlpana Kumari 43157e8c9beSAlpana Kumari // Get the MODEL from 43257e8c9beSAlpana Kumari // xyz.openbmc_project.Inventory.Decorator.Asset 43357e8c9beSAlpana Kumari // support it later as Model is Empty 43457e8c9beSAlpana Kumari // currently. 43557e8c9beSAlpana Kumari } 436c5b2abe0SLewanczyk, Dawid }, 43704a258f4SEd Tanous connection.first, path, 4386c34de48SEd Tanous "org.freedesktop.DBus.Properties", "GetAll", 4396c34de48SEd Tanous "xyz.openbmc_project.Inventory.Item.Cpu"); 4405bc2dc8eSJames Feist 4415bc2dc8eSJames Feist cpuHealth->inventory.emplace_back(path); 4421abe55efSEd Tanous } 44304a258f4SEd Tanous else if (interfaceName == 44404a258f4SEd Tanous "xyz.openbmc_project.Common.UUID") 4451abe55efSEd Tanous { 4461abe55efSEd Tanous BMCWEB_LOG_DEBUG 44704a258f4SEd Tanous << "Found UUID, now get its properties."; 44855c7b7a2SEd Tanous crow::connections::systemBus->async_method_call( 449029573d4SEd Tanous [aResp](const boost::system::error_code ec, 4506c34de48SEd Tanous const std::vector< 4516c34de48SEd Tanous std::pair<std::string, VariantType>> 4521abe55efSEd Tanous &properties) { 4531abe55efSEd Tanous if (ec) 4541abe55efSEd Tanous { 4551abe55efSEd Tanous BMCWEB_LOG_DEBUG 4566c34de48SEd Tanous << "DBUS response error " << ec; 457f12894f8SJason M. Bills messages::internalError(aResp->res); 458c5b2abe0SLewanczyk, Dawid return; 459c5b2abe0SLewanczyk, Dawid } 4606c34de48SEd Tanous BMCWEB_LOG_DEBUG << "Got " 4616c34de48SEd Tanous << properties.size() 462c5b2abe0SLewanczyk, Dawid << " UUID properties."; 4631abe55efSEd Tanous for (const std::pair<std::string, 46404a258f4SEd Tanous VariantType> 46504a258f4SEd Tanous &property : properties) 4661abe55efSEd Tanous { 46704a258f4SEd Tanous if (property.first == "UUID") 4681abe55efSEd Tanous { 469c5b2abe0SLewanczyk, Dawid const std::string *value = 470029573d4SEd Tanous sdbusplus::message::variant_ns:: 471029573d4SEd Tanous get_if<std::string>( 4721b6b96c5SEd Tanous &property.second); 47304a258f4SEd Tanous 4741abe55efSEd Tanous if (value != nullptr) 4751abe55efSEd Tanous { 476029573d4SEd Tanous std::string valueStr = *value; 47704a258f4SEd Tanous if (valueStr.size() == 32) 4781abe55efSEd Tanous { 479029573d4SEd Tanous valueStr.insert(8, 1, '-'); 480029573d4SEd Tanous valueStr.insert(13, 1, '-'); 481029573d4SEd Tanous valueStr.insert(18, 1, '-'); 482029573d4SEd Tanous valueStr.insert(23, 1, '-'); 48304a258f4SEd Tanous } 484029573d4SEd Tanous BMCWEB_LOG_DEBUG << "UUID = " 48504a258f4SEd Tanous << valueStr; 486029573d4SEd Tanous aResp->res.jsonValue["UUID"] = 48704a258f4SEd Tanous valueStr; 488c5b2abe0SLewanczyk, Dawid } 489c5b2abe0SLewanczyk, Dawid } 490c5b2abe0SLewanczyk, Dawid } 491c5b2abe0SLewanczyk, Dawid }, 49204a258f4SEd Tanous connection.first, path, 4936c34de48SEd Tanous "org.freedesktop.DBus.Properties", "GetAll", 4941abe55efSEd Tanous "xyz.openbmc_project.Common.UUID"); 495c5b2abe0SLewanczyk, Dawid } 496029573d4SEd Tanous else if (interfaceName == 497029573d4SEd Tanous "xyz.openbmc_project.Inventory.Item.System") 4981abe55efSEd Tanous { 499029573d4SEd Tanous crow::connections::systemBus->async_method_call( 500029573d4SEd Tanous [aResp](const boost::system::error_code ec, 501029573d4SEd Tanous const std::vector< 502029573d4SEd Tanous std::pair<std::string, VariantType>> 503029573d4SEd Tanous &propertiesList) { 504029573d4SEd Tanous if (ec) 505029573d4SEd Tanous { 506e4a4b9a9SJames Feist // doesn't have to include this 507e4a4b9a9SJames Feist // interface 508029573d4SEd Tanous return; 509029573d4SEd Tanous } 510698654b6SGunnar Mills BMCWEB_LOG_DEBUG 511698654b6SGunnar Mills << "Got " << propertiesList.size() 512029573d4SEd Tanous << " properties for system"; 513029573d4SEd Tanous for (const std::pair<std::string, 514029573d4SEd Tanous VariantType> 515029573d4SEd Tanous &property : propertiesList) 516029573d4SEd Tanous { 517fc5afcf9Sbeccabroek const std::string &propertyName = 518fc5afcf9Sbeccabroek property.first; 519fc5afcf9Sbeccabroek if ((propertyName == "PartNumber") || 520fc5afcf9Sbeccabroek (propertyName == "SerialNumber") || 521fc5afcf9Sbeccabroek (propertyName == "Manufacturer") || 522fc5afcf9Sbeccabroek (propertyName == "Model")) 523fc5afcf9Sbeccabroek { 524029573d4SEd Tanous const std::string *value = 525fc5afcf9Sbeccabroek std::get_if<std::string>( 526029573d4SEd Tanous &property.second); 527029573d4SEd Tanous if (value != nullptr) 528029573d4SEd Tanous { 529029573d4SEd Tanous aResp->res 530fc5afcf9Sbeccabroek .jsonValue[propertyName] = 531029573d4SEd Tanous *value; 532029573d4SEd Tanous } 533029573d4SEd Tanous } 534fc5afcf9Sbeccabroek } 535c1e236a6SGunnar Mills 536cb7e1e7bSAndrew Geissler // Grab the bios version 537cb7e1e7bSAndrew Geissler fw_util::getActiveFwVersion( 538cb7e1e7bSAndrew Geissler aResp, fw_util::biosPurpose, 539cb7e1e7bSAndrew Geissler "BiosVersion"); 540029573d4SEd Tanous }, 541029573d4SEd Tanous connection.first, path, 542029573d4SEd Tanous "org.freedesktop.DBus.Properties", "GetAll", 543029573d4SEd Tanous "xyz.openbmc_project.Inventory.Decorator." 544029573d4SEd Tanous "Asset"); 545e4a4b9a9SJames Feist 546e4a4b9a9SJames Feist crow::connections::systemBus->async_method_call( 547e4a4b9a9SJames Feist [aResp]( 548e4a4b9a9SJames Feist const boost::system::error_code ec, 549e4a4b9a9SJames Feist const std::variant<std::string> &property) { 550e4a4b9a9SJames Feist if (ec) 551e4a4b9a9SJames Feist { 552e4a4b9a9SJames Feist // doesn't have to include this 553e4a4b9a9SJames Feist // interface 554e4a4b9a9SJames Feist return; 555e4a4b9a9SJames Feist } 556e4a4b9a9SJames Feist 557e4a4b9a9SJames Feist const std::string *value = 558e4a4b9a9SJames Feist std::get_if<std::string>(&property); 559e4a4b9a9SJames Feist if (value != nullptr) 560e4a4b9a9SJames Feist { 561e4a4b9a9SJames Feist aResp->res.jsonValue["AssetTag"] = 562e4a4b9a9SJames Feist *value; 563e4a4b9a9SJames Feist } 564e4a4b9a9SJames Feist }, 565e4a4b9a9SJames Feist connection.first, path, 566e4a4b9a9SJames Feist "org.freedesktop.DBus.Properties", "Get", 567e4a4b9a9SJames Feist "xyz.openbmc_project.Inventory.Decorator." 568e4a4b9a9SJames Feist "AssetTag", 569e4a4b9a9SJames Feist "AssetTag"); 570029573d4SEd Tanous } 571029573d4SEd Tanous } 572029573d4SEd Tanous } 573c5b2abe0SLewanczyk, Dawid } 574c5b2abe0SLewanczyk, Dawid }, 575c5b2abe0SLewanczyk, Dawid "xyz.openbmc_project.ObjectMapper", 576c5b2abe0SLewanczyk, Dawid "/xyz/openbmc_project/object_mapper", 577c5b2abe0SLewanczyk, Dawid "xyz.openbmc_project.ObjectMapper", "GetSubTree", 5786617338dSEd Tanous "/xyz/openbmc_project/inventory", int32_t(0), 5796617338dSEd Tanous std::array<const char *, 5>{ 5806617338dSEd Tanous "xyz.openbmc_project.Inventory.Decorator.Asset", 5816617338dSEd Tanous "xyz.openbmc_project.Inventory.Item.Cpu", 5826617338dSEd Tanous "xyz.openbmc_project.Inventory.Item.Dimm", 5836617338dSEd Tanous "xyz.openbmc_project.Inventory.Item.System", 5846617338dSEd Tanous "xyz.openbmc_project.Common.UUID", 5856617338dSEd Tanous }); 586c5b2abe0SLewanczyk, Dawid } 587c5b2abe0SLewanczyk, Dawid 588c5b2abe0SLewanczyk, Dawid /** 589c5b2abe0SLewanczyk, Dawid * @brief Retrieves host state properties over dbus 590c5b2abe0SLewanczyk, Dawid * 591c5b2abe0SLewanczyk, Dawid * @param[in] aResp Shared pointer for completing asynchronous calls. 592c5b2abe0SLewanczyk, Dawid * 593c5b2abe0SLewanczyk, Dawid * @return None. 594c5b2abe0SLewanczyk, Dawid */ 595a0803efaSEd Tanous void getHostState(std::shared_ptr<AsyncResp> aResp) 5961abe55efSEd Tanous { 59755c7b7a2SEd Tanous BMCWEB_LOG_DEBUG << "Get host information."; 59855c7b7a2SEd Tanous crow::connections::systemBus->async_method_call( 599c5d03ff4SJennifer Lee [aResp](const boost::system::error_code ec, 600abf2add6SEd Tanous const std::variant<std::string> &hostState) { 6011abe55efSEd Tanous if (ec) 6021abe55efSEd Tanous { 60355c7b7a2SEd Tanous BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 604f12894f8SJason M. Bills messages::internalError(aResp->res); 605c5b2abe0SLewanczyk, Dawid return; 606c5b2abe0SLewanczyk, Dawid } 6076617338dSEd Tanous 608abf2add6SEd Tanous const std::string *s = std::get_if<std::string>(&hostState); 60955c7b7a2SEd Tanous BMCWEB_LOG_DEBUG << "Host state: " << *s; 6106617338dSEd Tanous if (s != nullptr) 6111abe55efSEd Tanous { 612c5b2abe0SLewanczyk, Dawid // Verify Host State 61394732661SAndrew Geissler if (*s == "xyz.openbmc_project.State.Host.HostState.Running") 6141abe55efSEd Tanous { 61555c7b7a2SEd Tanous aResp->res.jsonValue["PowerState"] = "On"; 6166617338dSEd Tanous aResp->res.jsonValue["Status"]["State"] = "Enabled"; 6171abe55efSEd Tanous } 61883935af9SAndrew Geissler else if (*s == "xyz.openbmc_project.State.Host.HostState." 619*8c888608SGunnar Mills "Quiesced") 620*8c888608SGunnar Mills { 621*8c888608SGunnar Mills aResp->res.jsonValue["PowerState"] = "On"; 622*8c888608SGunnar Mills aResp->res.jsonValue["Status"]["State"] = "Quiesced"; 623*8c888608SGunnar Mills } 624*8c888608SGunnar Mills else if (*s == "xyz.openbmc_project.State.Host.HostState." 62583935af9SAndrew Geissler "DiagnosticMode") 62683935af9SAndrew Geissler { 62783935af9SAndrew Geissler aResp->res.jsonValue["PowerState"] = "On"; 62883935af9SAndrew Geissler aResp->res.jsonValue["Status"]["State"] = "InTest"; 62983935af9SAndrew Geissler } 6301abe55efSEd Tanous else 6311abe55efSEd Tanous { 63255c7b7a2SEd Tanous aResp->res.jsonValue["PowerState"] = "Off"; 6336617338dSEd Tanous aResp->res.jsonValue["Status"]["State"] = "Disabled"; 634c5b2abe0SLewanczyk, Dawid } 635c5b2abe0SLewanczyk, Dawid } 636c5b2abe0SLewanczyk, Dawid }, 6376c34de48SEd Tanous "xyz.openbmc_project.State.Host", "/xyz/openbmc_project/state/host0", 6386617338dSEd Tanous "org.freedesktop.DBus.Properties", "Get", 6396617338dSEd Tanous "xyz.openbmc_project.State.Host", "CurrentHostState"); 640c5b2abe0SLewanczyk, Dawid } 641c5b2abe0SLewanczyk, Dawid 642c5b2abe0SLewanczyk, Dawid /** 643491d8ee7SSantosh Puranik * @brief Traslates boot source DBUS property value to redfish. 644491d8ee7SSantosh Puranik * 645491d8ee7SSantosh Puranik * @param[in] dbusSource The boot source in DBUS speak. 646491d8ee7SSantosh Puranik * 647491d8ee7SSantosh Puranik * @return Returns as a string, the boot source in Redfish terms. If translation 648491d8ee7SSantosh Puranik * cannot be done, returns an empty string. 649491d8ee7SSantosh Puranik */ 650491d8ee7SSantosh Puranik static std::string dbusToRfBootSource(const std::string &dbusSource) 651491d8ee7SSantosh Puranik { 652491d8ee7SSantosh Puranik if (dbusSource == "xyz.openbmc_project.Control.Boot.Source.Sources.Default") 653491d8ee7SSantosh Puranik { 654491d8ee7SSantosh Puranik return "None"; 655491d8ee7SSantosh Puranik } 656491d8ee7SSantosh Puranik else if (dbusSource == 657491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Source.Sources.Disk") 658491d8ee7SSantosh Puranik { 659491d8ee7SSantosh Puranik return "Hdd"; 660491d8ee7SSantosh Puranik } 661491d8ee7SSantosh Puranik else if (dbusSource == 662a71dc0b7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Source.Sources.ExternalMedia") 663491d8ee7SSantosh Puranik { 664491d8ee7SSantosh Puranik return "Cd"; 665491d8ee7SSantosh Puranik } 666491d8ee7SSantosh Puranik else if (dbusSource == 667491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Source.Sources.Network") 668491d8ee7SSantosh Puranik { 669491d8ee7SSantosh Puranik return "Pxe"; 670491d8ee7SSantosh Puranik } 6719f16b2c1SJennifer Lee else if (dbusSource == 672944ffaf9SJohnathan Mantey "xyz.openbmc_project.Control.Boot.Source.Sources.RemovableMedia") 6739f16b2c1SJennifer Lee { 6749f16b2c1SJennifer Lee return "Usb"; 6759f16b2c1SJennifer Lee } 676491d8ee7SSantosh Puranik else 677491d8ee7SSantosh Puranik { 678491d8ee7SSantosh Puranik return ""; 679491d8ee7SSantosh Puranik } 680491d8ee7SSantosh Puranik } 681491d8ee7SSantosh Puranik 682491d8ee7SSantosh Puranik /** 683491d8ee7SSantosh Puranik * @brief Traslates boot mode DBUS property value to redfish. 684491d8ee7SSantosh Puranik * 685491d8ee7SSantosh Puranik * @param[in] dbusMode The boot mode in DBUS speak. 686491d8ee7SSantosh Puranik * 687491d8ee7SSantosh Puranik * @return Returns as a string, the boot mode in Redfish terms. If translation 688491d8ee7SSantosh Puranik * cannot be done, returns an empty string. 689491d8ee7SSantosh Puranik */ 690491d8ee7SSantosh Puranik static std::string dbusToRfBootMode(const std::string &dbusMode) 691491d8ee7SSantosh Puranik { 692491d8ee7SSantosh Puranik if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular") 693491d8ee7SSantosh Puranik { 694491d8ee7SSantosh Puranik return "None"; 695491d8ee7SSantosh Puranik } 696491d8ee7SSantosh Puranik else if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Safe") 697491d8ee7SSantosh Puranik { 698491d8ee7SSantosh Puranik return "Diags"; 699491d8ee7SSantosh Puranik } 700491d8ee7SSantosh Puranik else if (dbusMode == "xyz.openbmc_project.Control.Boot.Mode.Modes.Setup") 701491d8ee7SSantosh Puranik { 702491d8ee7SSantosh Puranik return "BiosSetup"; 703491d8ee7SSantosh Puranik } 704491d8ee7SSantosh Puranik else 705491d8ee7SSantosh Puranik { 706491d8ee7SSantosh Puranik return ""; 707491d8ee7SSantosh Puranik } 708491d8ee7SSantosh Puranik } 709491d8ee7SSantosh Puranik 710491d8ee7SSantosh Puranik /** 711944ffaf9SJohnathan Mantey * @brief Traslates boot source from Redfish to the DBus boot paths. 712491d8ee7SSantosh Puranik * 713491d8ee7SSantosh Puranik * @param[in] rfSource The boot source in Redfish. 714944ffaf9SJohnathan Mantey * @param[out] bootSource The DBus source 715944ffaf9SJohnathan Mantey * @param[out] bootMode the DBus boot mode 716491d8ee7SSantosh Puranik * 717944ffaf9SJohnathan Mantey * @return Integer error code. 718491d8ee7SSantosh Puranik */ 719944ffaf9SJohnathan Mantey static int assignBootParameters(std::shared_ptr<AsyncResp> aResp, 720944ffaf9SJohnathan Mantey const std::string &rfSource, 721944ffaf9SJohnathan Mantey std::string &bootSource, std::string &bootMode) 722491d8ee7SSantosh Puranik { 723944ffaf9SJohnathan Mantey // The caller has initialized the bootSource and bootMode to: 724944ffaf9SJohnathan Mantey // bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular"; 725944ffaf9SJohnathan Mantey // bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Default"; 726944ffaf9SJohnathan Mantey // Only modify the bootSource/bootMode variable needed to achieve the 727944ffaf9SJohnathan Mantey // desired boot action. 728944ffaf9SJohnathan Mantey 729491d8ee7SSantosh Puranik if (rfSource == "None") 730491d8ee7SSantosh Puranik { 731944ffaf9SJohnathan Mantey return 0; 732491d8ee7SSantosh Puranik } 733491d8ee7SSantosh Puranik else if (rfSource == "Pxe") 734491d8ee7SSantosh Puranik { 735944ffaf9SJohnathan Mantey bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Network"; 736944ffaf9SJohnathan Mantey } 737944ffaf9SJohnathan Mantey else if (rfSource == "Hdd") 738944ffaf9SJohnathan Mantey { 739944ffaf9SJohnathan Mantey bootSource = "xyz.openbmc_project.Control.Boot.Source.Sources.Disk"; 740944ffaf9SJohnathan Mantey } 741944ffaf9SJohnathan Mantey else if (rfSource == "Diags") 742944ffaf9SJohnathan Mantey { 743944ffaf9SJohnathan Mantey bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Safe"; 744944ffaf9SJohnathan Mantey } 745944ffaf9SJohnathan Mantey else if (rfSource == "Cd") 746944ffaf9SJohnathan Mantey { 747944ffaf9SJohnathan Mantey bootSource = 748944ffaf9SJohnathan Mantey "xyz.openbmc_project.Control.Boot.Source.Sources.ExternalMedia"; 749944ffaf9SJohnathan Mantey } 750944ffaf9SJohnathan Mantey else if (rfSource == "BiosSetup") 751944ffaf9SJohnathan Mantey { 752944ffaf9SJohnathan Mantey bootMode = "xyz.openbmc_project.Control.Boot.Mode.Modes.Setup"; 753491d8ee7SSantosh Puranik } 7549f16b2c1SJennifer Lee else if (rfSource == "Usb") 7559f16b2c1SJennifer Lee { 756944ffaf9SJohnathan Mantey bootSource = 757944ffaf9SJohnathan Mantey "xyz.openbmc_project.Control.Boot.Source.Sources.RemovableMedia"; 7589f16b2c1SJennifer Lee } 759491d8ee7SSantosh Puranik else 760491d8ee7SSantosh Puranik { 761944ffaf9SJohnathan Mantey BMCWEB_LOG_DEBUG << "Invalid property value for " 762944ffaf9SJohnathan Mantey "BootSourceOverrideTarget: " 763944ffaf9SJohnathan Mantey << bootSource; 764944ffaf9SJohnathan Mantey messages::propertyValueNotInList(aResp->res, rfSource, 765944ffaf9SJohnathan Mantey "BootSourceTargetOverride"); 766944ffaf9SJohnathan Mantey return -1; 767491d8ee7SSantosh Puranik } 768944ffaf9SJohnathan Mantey return 0; 769491d8ee7SSantosh Puranik } 770491d8ee7SSantosh Puranik 771491d8ee7SSantosh Puranik /** 772491d8ee7SSantosh Puranik * @brief Retrieves boot mode over DBUS and fills out the response 773491d8ee7SSantosh Puranik * 774491d8ee7SSantosh Puranik * @param[in] aResp Shared pointer for generating response message. 775491d8ee7SSantosh Puranik * @param[in] bootDbusObj The dbus object to query for boot properties. 776491d8ee7SSantosh Puranik * 777491d8ee7SSantosh Puranik * @return None. 778491d8ee7SSantosh Puranik */ 779491d8ee7SSantosh Puranik static void getBootMode(std::shared_ptr<AsyncResp> aResp, 780491d8ee7SSantosh Puranik std::string bootDbusObj) 781491d8ee7SSantosh Puranik { 782491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 783491d8ee7SSantosh Puranik [aResp](const boost::system::error_code ec, 784491d8ee7SSantosh Puranik const std::variant<std::string> &bootMode) { 785491d8ee7SSantosh Puranik if (ec) 786491d8ee7SSantosh Puranik { 787491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 788491d8ee7SSantosh Puranik messages::internalError(aResp->res); 789491d8ee7SSantosh Puranik return; 790491d8ee7SSantosh Puranik } 791491d8ee7SSantosh Puranik 792491d8ee7SSantosh Puranik const std::string *bootModeStr = 793491d8ee7SSantosh Puranik std::get_if<std::string>(&bootMode); 794491d8ee7SSantosh Puranik 795491d8ee7SSantosh Puranik if (!bootModeStr) 796491d8ee7SSantosh Puranik { 797491d8ee7SSantosh Puranik messages::internalError(aResp->res); 798491d8ee7SSantosh Puranik return; 799491d8ee7SSantosh Puranik } 800491d8ee7SSantosh Puranik 801491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Boot mode: " << *bootModeStr; 802491d8ee7SSantosh Puranik 803491d8ee7SSantosh Puranik // TODO (Santosh): Do we need to support override mode? 804491d8ee7SSantosh Puranik aResp->res.jsonValue["Boot"]["BootSourceOverrideMode"] = "Legacy"; 805491d8ee7SSantosh Puranik aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget@Redfish." 806491d8ee7SSantosh Puranik "AllowableValues"] = { 807944ffaf9SJohnathan Mantey "None", "Pxe", "Hdd", "Cd", "Diags", "BiosSetup", "Usb"}; 808491d8ee7SSantosh Puranik 809491d8ee7SSantosh Puranik if (*bootModeStr != 810491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular") 811491d8ee7SSantosh Puranik { 812491d8ee7SSantosh Puranik auto rfMode = dbusToRfBootMode(*bootModeStr); 813491d8ee7SSantosh Puranik if (!rfMode.empty()) 814491d8ee7SSantosh Puranik { 815491d8ee7SSantosh Puranik aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] = 816491d8ee7SSantosh Puranik rfMode; 817491d8ee7SSantosh Puranik } 818491d8ee7SSantosh Puranik } 819491d8ee7SSantosh Puranik 820491d8ee7SSantosh Puranik // If the BootSourceOverrideTarget is still "None" at the end, 821491d8ee7SSantosh Puranik // reset the BootSourceOverrideEnabled to indicate that 822491d8ee7SSantosh Puranik // overrides are disabled 823491d8ee7SSantosh Puranik if (aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] == 824491d8ee7SSantosh Puranik "None") 825491d8ee7SSantosh Puranik { 826491d8ee7SSantosh Puranik aResp->res.jsonValue["Boot"]["BootSourceOverrideEnabled"] = 827491d8ee7SSantosh Puranik "Disabled"; 828491d8ee7SSantosh Puranik } 829491d8ee7SSantosh Puranik }, 830491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", bootDbusObj, 831491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Get", 832491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Mode", "BootMode"); 833491d8ee7SSantosh Puranik } 834491d8ee7SSantosh Puranik 835491d8ee7SSantosh Puranik /** 836491d8ee7SSantosh Puranik * @brief Retrieves boot source over DBUS 837491d8ee7SSantosh Puranik * 838491d8ee7SSantosh Puranik * @param[in] aResp Shared pointer for generating response message. 839491d8ee7SSantosh Puranik * @param[in] oneTimeEnable Boolean to indicate boot properties are one-time. 840491d8ee7SSantosh Puranik * 841491d8ee7SSantosh Puranik * @return None. 842491d8ee7SSantosh Puranik */ 843491d8ee7SSantosh Puranik static void getBootSource(std::shared_ptr<AsyncResp> aResp, bool oneTimeEnabled) 844491d8ee7SSantosh Puranik { 845491d8ee7SSantosh Puranik std::string bootDbusObj = 846491d8ee7SSantosh Puranik oneTimeEnabled ? "/xyz/openbmc_project/control/host0/boot/one_time" 847491d8ee7SSantosh Puranik : "/xyz/openbmc_project/control/host0/boot"; 848491d8ee7SSantosh Puranik 849491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Is one time: " << oneTimeEnabled; 850491d8ee7SSantosh Puranik aResp->res.jsonValue["Boot"]["BootSourceOverrideEnabled"] = 851491d8ee7SSantosh Puranik (oneTimeEnabled) ? "Once" : "Continuous"; 852491d8ee7SSantosh Puranik 853491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 854491d8ee7SSantosh Puranik [aResp, bootDbusObj](const boost::system::error_code ec, 855491d8ee7SSantosh Puranik const std::variant<std::string> &bootSource) { 856491d8ee7SSantosh Puranik if (ec) 857491d8ee7SSantosh Puranik { 858491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 859491d8ee7SSantosh Puranik messages::internalError(aResp->res); 860491d8ee7SSantosh Puranik return; 861491d8ee7SSantosh Puranik } 862491d8ee7SSantosh Puranik 863491d8ee7SSantosh Puranik const std::string *bootSourceStr = 864491d8ee7SSantosh Puranik std::get_if<std::string>(&bootSource); 865491d8ee7SSantosh Puranik 866491d8ee7SSantosh Puranik if (!bootSourceStr) 867491d8ee7SSantosh Puranik { 868491d8ee7SSantosh Puranik messages::internalError(aResp->res); 869491d8ee7SSantosh Puranik return; 870491d8ee7SSantosh Puranik } 871491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Boot source: " << *bootSourceStr; 872491d8ee7SSantosh Puranik 873491d8ee7SSantosh Puranik auto rfSource = dbusToRfBootSource(*bootSourceStr); 874491d8ee7SSantosh Puranik if (!rfSource.empty()) 875491d8ee7SSantosh Puranik { 876491d8ee7SSantosh Puranik aResp->res.jsonValue["Boot"]["BootSourceOverrideTarget"] = 877491d8ee7SSantosh Puranik rfSource; 878491d8ee7SSantosh Puranik } 879491d8ee7SSantosh Puranik }, 880491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", bootDbusObj, 881491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Get", 882491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Source", "BootSource"); 883491d8ee7SSantosh Puranik getBootMode(std::move(aResp), std::move(bootDbusObj)); 884491d8ee7SSantosh Puranik } 885491d8ee7SSantosh Puranik 886491d8ee7SSantosh Puranik /** 887491d8ee7SSantosh Puranik * @brief Retrieves "One time" enabled setting over DBUS and calls function to 888491d8ee7SSantosh Puranik * get boot source and boot mode. 889491d8ee7SSantosh Puranik * 890491d8ee7SSantosh Puranik * @param[in] aResp Shared pointer for generating response message. 891491d8ee7SSantosh Puranik * 892491d8ee7SSantosh Puranik * @return None. 893491d8ee7SSantosh Puranik */ 894491d8ee7SSantosh Puranik static void getBootProperties(std::shared_ptr<AsyncResp> aResp) 895491d8ee7SSantosh Puranik { 896491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Get boot information."; 897491d8ee7SSantosh Puranik 898491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 899c5d03ff4SJennifer Lee [aResp](const boost::system::error_code ec, 900491d8ee7SSantosh Puranik const sdbusplus::message::variant<bool> &oneTime) { 901491d8ee7SSantosh Puranik if (ec) 902491d8ee7SSantosh Puranik { 903491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 9042a833c77SJames Feist // not an error, don't have to have the interface 905491d8ee7SSantosh Puranik return; 906491d8ee7SSantosh Puranik } 907491d8ee7SSantosh Puranik 908491d8ee7SSantosh Puranik const bool *oneTimePtr = std::get_if<bool>(&oneTime); 909491d8ee7SSantosh Puranik 910491d8ee7SSantosh Puranik if (!oneTimePtr) 911491d8ee7SSantosh Puranik { 912491d8ee7SSantosh Puranik messages::internalError(aResp->res); 913491d8ee7SSantosh Puranik return; 914491d8ee7SSantosh Puranik } 915491d8ee7SSantosh Puranik getBootSource(aResp, *oneTimePtr); 916491d8ee7SSantosh Puranik }, 917491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", 918491d8ee7SSantosh Puranik "/xyz/openbmc_project/control/host0/boot/one_time", 919491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Get", 920491d8ee7SSantosh Puranik "xyz.openbmc_project.Object.Enable", "Enabled"); 921491d8ee7SSantosh Puranik } 922491d8ee7SSantosh Puranik 923491d8ee7SSantosh Puranik /** 924c6a620f2SGeorge Liu * @brief Retrieves power restore policy over DBUS. 925c6a620f2SGeorge Liu * 926c6a620f2SGeorge Liu * @param[in] aResp Shared pointer for generating response message. 927c6a620f2SGeorge Liu * 928c6a620f2SGeorge Liu * @return None. 929c6a620f2SGeorge Liu */ 930c6a620f2SGeorge Liu void getPowerRestorePolicy(std::shared_ptr<AsyncResp> aResp) 931c6a620f2SGeorge Liu { 932c6a620f2SGeorge Liu BMCWEB_LOG_DEBUG << "Get power restore policy"; 933c6a620f2SGeorge Liu 934c6a620f2SGeorge Liu crow::connections::systemBus->async_method_call( 935c6a620f2SGeorge Liu [aResp](const boost::system::error_code ec, 936c6a620f2SGeorge Liu sdbusplus::message::variant<std::string> &policy) { 937c6a620f2SGeorge Liu if (ec) 938c6a620f2SGeorge Liu { 939c6a620f2SGeorge Liu BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 940c6a620f2SGeorge Liu return; 941c6a620f2SGeorge Liu } 942c6a620f2SGeorge Liu 943c6a620f2SGeorge Liu const boost::container::flat_map<std::string, std::string> 944c6a620f2SGeorge Liu policyMaps = { 945c6a620f2SGeorge Liu {"xyz.openbmc_project.Control.Power.RestorePolicy.Policy." 946c6a620f2SGeorge Liu "AlwaysOn", 947c6a620f2SGeorge Liu "AlwaysOn"}, 948c6a620f2SGeorge Liu {"xyz.openbmc_project.Control.Power.RestorePolicy.Policy." 949c6a620f2SGeorge Liu "AlwaysOff", 950c6a620f2SGeorge Liu "AlwaysOff"}, 951c6a620f2SGeorge Liu {"xyz.openbmc_project.Control.Power.RestorePolicy.Policy." 952c6a620f2SGeorge Liu "LastState", 953c6a620f2SGeorge Liu "LastState"}}; 954c6a620f2SGeorge Liu 955c6a620f2SGeorge Liu const std::string *policyPtr = std::get_if<std::string>(&policy); 956c6a620f2SGeorge Liu 957c6a620f2SGeorge Liu if (!policyPtr) 958c6a620f2SGeorge Liu { 959c6a620f2SGeorge Liu messages::internalError(aResp->res); 960c6a620f2SGeorge Liu return; 961c6a620f2SGeorge Liu } 962c6a620f2SGeorge Liu 963c6a620f2SGeorge Liu auto policyMapsIt = policyMaps.find(*policyPtr); 964c6a620f2SGeorge Liu if (policyMapsIt == policyMaps.end()) 965c6a620f2SGeorge Liu { 966c6a620f2SGeorge Liu messages::internalError(aResp->res); 967c6a620f2SGeorge Liu return; 968c6a620f2SGeorge Liu } 969c6a620f2SGeorge Liu 970c6a620f2SGeorge Liu aResp->res.jsonValue["PowerRestorePolicy"] = policyMapsIt->second; 971c6a620f2SGeorge Liu }, 972c6a620f2SGeorge Liu "xyz.openbmc_project.Settings", 973c6a620f2SGeorge Liu "/xyz/openbmc_project/control/host0/power_restore_policy", 974c6a620f2SGeorge Liu "org.freedesktop.DBus.Properties", "Get", 975c6a620f2SGeorge Liu "xyz.openbmc_project.Control.Power.RestorePolicy", 976c6a620f2SGeorge Liu "PowerRestorePolicy"); 977c6a620f2SGeorge Liu } 978c6a620f2SGeorge Liu 979c6a620f2SGeorge Liu /** 980491d8ee7SSantosh Puranik * @brief Sets boot properties into DBUS object(s). 981491d8ee7SSantosh Puranik * 982491d8ee7SSantosh Puranik * @param[in] aResp Shared pointer for generating response message. 983491d8ee7SSantosh Puranik * @param[in] oneTimeEnabled Is "one-time" setting already enabled. 984491d8ee7SSantosh Puranik * @param[in] bootSource The boot source to set. 985491d8ee7SSantosh Puranik * @param[in] bootEnable The source override "enable" to set. 986491d8ee7SSantosh Puranik * 987265c1602SJohnathan Mantey * @return Integer error code. 988491d8ee7SSantosh Puranik */ 989491d8ee7SSantosh Puranik static void setBootModeOrSource(std::shared_ptr<AsyncResp> aResp, 990491d8ee7SSantosh Puranik bool oneTimeEnabled, 991491d8ee7SSantosh Puranik std::optional<std::string> bootSource, 992491d8ee7SSantosh Puranik std::optional<std::string> bootEnable) 993491d8ee7SSantosh Puranik { 994944ffaf9SJohnathan Mantey std::string bootSourceStr = 995944ffaf9SJohnathan Mantey "xyz.openbmc_project.Control.Boot.Source.Sources.Default"; 996944ffaf9SJohnathan Mantey std::string bootModeStr = 997944ffaf9SJohnathan Mantey "xyz.openbmc_project.Control.Boot.Mode.Modes.Regular"; 998491d8ee7SSantosh Puranik bool oneTimeSetting = oneTimeEnabled; 999944ffaf9SJohnathan Mantey bool useBootSource = true; 1000944ffaf9SJohnathan Mantey 1001491d8ee7SSantosh Puranik // Validate incoming parameters 1002491d8ee7SSantosh Puranik if (bootEnable) 1003491d8ee7SSantosh Puranik { 1004491d8ee7SSantosh Puranik if (*bootEnable == "Once") 1005491d8ee7SSantosh Puranik { 1006491d8ee7SSantosh Puranik oneTimeSetting = true; 1007491d8ee7SSantosh Puranik } 1008491d8ee7SSantosh Puranik else if (*bootEnable == "Continuous") 1009491d8ee7SSantosh Puranik { 1010491d8ee7SSantosh Puranik oneTimeSetting = false; 1011491d8ee7SSantosh Puranik } 1012491d8ee7SSantosh Puranik else if (*bootEnable == "Disabled") 1013491d8ee7SSantosh Puranik { 1014944ffaf9SJohnathan Mantey BMCWEB_LOG_DEBUG << "Boot source override will be disabled"; 1015491d8ee7SSantosh Puranik oneTimeSetting = false; 1016944ffaf9SJohnathan Mantey useBootSource = false; 1017491d8ee7SSantosh Puranik } 1018491d8ee7SSantosh Puranik else 1019491d8ee7SSantosh Puranik { 1020491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Unsupported value for " 1021491d8ee7SSantosh Puranik "BootSourceOverrideEnabled: " 1022491d8ee7SSantosh Puranik << *bootEnable; 1023491d8ee7SSantosh Puranik messages::propertyValueNotInList(aResp->res, *bootEnable, 1024491d8ee7SSantosh Puranik "BootSourceOverrideEnabled"); 1025491d8ee7SSantosh Puranik return; 1026491d8ee7SSantosh Puranik } 1027491d8ee7SSantosh Puranik } 1028491d8ee7SSantosh Puranik 1029944ffaf9SJohnathan Mantey if (bootSource && useBootSource) 1030491d8ee7SSantosh Puranik { 1031491d8ee7SSantosh Puranik // Source target specified 1032491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Boot source: " << *bootSource; 1033491d8ee7SSantosh Puranik // Figure out which DBUS interface and property to use 1034944ffaf9SJohnathan Mantey if (assignBootParameters(aResp, *bootSource, bootSourceStr, 1035944ffaf9SJohnathan Mantey bootModeStr)) 1036491d8ee7SSantosh Puranik { 1037944ffaf9SJohnathan Mantey BMCWEB_LOG_DEBUG 1038944ffaf9SJohnathan Mantey << "Invalid property value for BootSourceOverrideTarget: " 1039491d8ee7SSantosh Puranik << *bootSource; 1040491d8ee7SSantosh Puranik messages::propertyValueNotInList(aResp->res, *bootSource, 1041491d8ee7SSantosh Puranik "BootSourceTargetOverride"); 1042491d8ee7SSantosh Puranik return; 1043491d8ee7SSantosh Puranik } 1044944ffaf9SJohnathan Mantey } 1045491d8ee7SSantosh Puranik 1046944ffaf9SJohnathan Mantey // Act on validated parameters 1047944ffaf9SJohnathan Mantey BMCWEB_LOG_DEBUG << "DBUS boot source: " << bootSourceStr; 1048944ffaf9SJohnathan Mantey BMCWEB_LOG_DEBUG << "DBUS boot mode: " << bootModeStr; 1049944ffaf9SJohnathan Mantey const char *bootObj = 1050944ffaf9SJohnathan Mantey oneTimeSetting ? "/xyz/openbmc_project/control/host0/boot/one_time" 1051944ffaf9SJohnathan Mantey : "/xyz/openbmc_project/control/host0/boot"; 1052944ffaf9SJohnathan Mantey 1053491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 1054491d8ee7SSantosh Puranik [aResp](const boost::system::error_code ec) { 1055491d8ee7SSantosh Puranik if (ec) 1056491d8ee7SSantosh Puranik { 1057491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1058491d8ee7SSantosh Puranik messages::internalError(aResp->res); 1059491d8ee7SSantosh Puranik return; 1060491d8ee7SSantosh Puranik } 1061491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Boot source update done."; 1062491d8ee7SSantosh Puranik }, 1063491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", bootObj, 1064491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Set", 1065491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Source", "BootSource", 1066491d8ee7SSantosh Puranik std::variant<std::string>(bootSourceStr)); 1067944ffaf9SJohnathan Mantey 1068491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 1069491d8ee7SSantosh Puranik [aResp](const boost::system::error_code ec) { 1070491d8ee7SSantosh Puranik if (ec) 1071491d8ee7SSantosh Puranik { 1072491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1073491d8ee7SSantosh Puranik messages::internalError(aResp->res); 1074491d8ee7SSantosh Puranik return; 1075491d8ee7SSantosh Puranik } 1076491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Boot mode update done."; 1077491d8ee7SSantosh Puranik }, 1078491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", bootObj, 1079491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Set", 1080491d8ee7SSantosh Puranik "xyz.openbmc_project.Control.Boot.Mode", "BootMode", 1081491d8ee7SSantosh Puranik std::variant<std::string>(bootModeStr)); 1082944ffaf9SJohnathan Mantey 1083491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 1084491d8ee7SSantosh Puranik [aResp{std::move(aResp)}](const boost::system::error_code ec) { 1085491d8ee7SSantosh Puranik if (ec) 1086491d8ee7SSantosh Puranik { 1087491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1088491d8ee7SSantosh Puranik messages::internalError(aResp->res); 1089491d8ee7SSantosh Puranik return; 1090491d8ee7SSantosh Puranik } 1091491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Boot enable update done."; 1092491d8ee7SSantosh Puranik }, 1093491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", 1094491d8ee7SSantosh Puranik "/xyz/openbmc_project/control/host0/boot/one_time", 1095491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Set", 1096491d8ee7SSantosh Puranik "xyz.openbmc_project.Object.Enable", "Enabled", 1097491d8ee7SSantosh Puranik std::variant<bool>(oneTimeSetting)); 1098491d8ee7SSantosh Puranik } 1099491d8ee7SSantosh Puranik 1100491d8ee7SSantosh Puranik /** 1101491d8ee7SSantosh Puranik * @brief Retrieves "One time" enabled setting over DBUS and calls function to 1102491d8ee7SSantosh Puranik * set boot source/boot mode properties. 1103491d8ee7SSantosh Puranik * 1104491d8ee7SSantosh Puranik * @param[in] aResp Shared pointer for generating response message. 1105491d8ee7SSantosh Puranik * @param[in] bootSource The boot source from incoming RF request. 1106491d8ee7SSantosh Puranik * @param[in] bootEnable The boot override enable from incoming RF request. 1107491d8ee7SSantosh Puranik * 1108265c1602SJohnathan Mantey * @return Integer error code. 1109491d8ee7SSantosh Puranik */ 1110491d8ee7SSantosh Puranik static void setBootProperties(std::shared_ptr<AsyncResp> aResp, 1111491d8ee7SSantosh Puranik std::optional<std::string> bootSource, 1112491d8ee7SSantosh Puranik std::optional<std::string> bootEnable) 1113491d8ee7SSantosh Puranik { 1114491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Set boot information."; 1115491d8ee7SSantosh Puranik 1116491d8ee7SSantosh Puranik crow::connections::systemBus->async_method_call( 1117265c1602SJohnathan Mantey [aResp, bootSource{std::move(bootSource)}, 1118491d8ee7SSantosh Puranik bootEnable{std::move(bootEnable)}]( 1119491d8ee7SSantosh Puranik const boost::system::error_code ec, 1120491d8ee7SSantosh Puranik const sdbusplus::message::variant<bool> &oneTime) { 1121491d8ee7SSantosh Puranik if (ec) 1122491d8ee7SSantosh Puranik { 1123491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1124491d8ee7SSantosh Puranik messages::internalError(aResp->res); 1125491d8ee7SSantosh Puranik return; 1126491d8ee7SSantosh Puranik } 1127491d8ee7SSantosh Puranik 1128491d8ee7SSantosh Puranik const bool *oneTimePtr = std::get_if<bool>(&oneTime); 1129491d8ee7SSantosh Puranik 1130491d8ee7SSantosh Puranik if (!oneTimePtr) 1131491d8ee7SSantosh Puranik { 1132491d8ee7SSantosh Puranik messages::internalError(aResp->res); 1133491d8ee7SSantosh Puranik return; 1134491d8ee7SSantosh Puranik } 1135491d8ee7SSantosh Puranik 1136491d8ee7SSantosh Puranik BMCWEB_LOG_DEBUG << "Got one time: " << *oneTimePtr; 1137491d8ee7SSantosh Puranik 1138491d8ee7SSantosh Puranik setBootModeOrSource(aResp, *oneTimePtr, std::move(bootSource), 1139491d8ee7SSantosh Puranik std::move(bootEnable)); 1140491d8ee7SSantosh Puranik }, 1141491d8ee7SSantosh Puranik "xyz.openbmc_project.Settings", 1142491d8ee7SSantosh Puranik "/xyz/openbmc_project/control/host0/boot/one_time", 1143491d8ee7SSantosh Puranik "org.freedesktop.DBus.Properties", "Get", 1144491d8ee7SSantosh Puranik "xyz.openbmc_project.Object.Enable", "Enabled"); 1145491d8ee7SSantosh Puranik } 1146491d8ee7SSantosh Puranik 1147c6a620f2SGeorge Liu /** 1148c6a620f2SGeorge Liu * @brief Sets power restore policy properties. 1149c6a620f2SGeorge Liu * 1150c6a620f2SGeorge Liu * @param[in] aResp Shared pointer for generating response message. 1151c6a620f2SGeorge Liu * @param[in] policy power restore policy properties from request. 1152c6a620f2SGeorge Liu * 1153c6a620f2SGeorge Liu * @return None. 1154c6a620f2SGeorge Liu */ 1155c6a620f2SGeorge Liu static void setPowerRestorePolicy(std::shared_ptr<AsyncResp> aResp, 1156c6a620f2SGeorge Liu std::optional<std::string> policy) 1157c6a620f2SGeorge Liu { 1158c6a620f2SGeorge Liu BMCWEB_LOG_DEBUG << "Set power restore policy."; 1159c6a620f2SGeorge Liu 1160c6a620f2SGeorge Liu const boost::container::flat_map<std::string, std::string> policyMaps = { 1161c6a620f2SGeorge Liu {"AlwaysOn", "xyz.openbmc_project.Control.Power.RestorePolicy.Policy." 1162c6a620f2SGeorge Liu "AlwaysOn"}, 1163c6a620f2SGeorge Liu {"AlwaysOff", "xyz.openbmc_project.Control.Power.RestorePolicy.Policy." 1164c6a620f2SGeorge Liu "AlwaysOff"}, 1165c6a620f2SGeorge Liu {"LastState", "xyz.openbmc_project.Control.Power.RestorePolicy.Policy." 1166c6a620f2SGeorge Liu "LastState"}}; 1167c6a620f2SGeorge Liu 1168c6a620f2SGeorge Liu std::string powerRestorPolicy; 1169c6a620f2SGeorge Liu 1170c6a620f2SGeorge Liu auto policyMapsIt = policyMaps.find(*policy); 1171c6a620f2SGeorge Liu if (policyMapsIt == policyMaps.end()) 1172c6a620f2SGeorge Liu { 1173c6a620f2SGeorge Liu messages::internalError(aResp->res); 1174c6a620f2SGeorge Liu return; 1175c6a620f2SGeorge Liu } 1176c6a620f2SGeorge Liu 1177c6a620f2SGeorge Liu powerRestorPolicy = policyMapsIt->second; 1178c6a620f2SGeorge Liu 1179c6a620f2SGeorge Liu crow::connections::systemBus->async_method_call( 1180c6a620f2SGeorge Liu [aResp](const boost::system::error_code ec) { 1181c6a620f2SGeorge Liu if (ec) 1182c6a620f2SGeorge Liu { 1183c6a620f2SGeorge Liu messages::internalError(aResp->res); 1184c6a620f2SGeorge Liu return; 1185c6a620f2SGeorge Liu } 1186c6a620f2SGeorge Liu }, 1187c6a620f2SGeorge Liu "xyz.openbmc_project.Settings", 1188c6a620f2SGeorge Liu "/xyz/openbmc_project/control/host0/power_restore_policy", 1189c6a620f2SGeorge Liu "org.freedesktop.DBus.Properties", "Set", 1190c6a620f2SGeorge Liu "xyz.openbmc_project.Control.Power.RestorePolicy", "PowerRestorePolicy", 1191c6a620f2SGeorge Liu std::variant<std::string>(powerRestorPolicy)); 1192c6a620f2SGeorge Liu } 1193c6a620f2SGeorge Liu 1194a6349918SAppaRao Puli #ifdef BMCWEB_ENABLE_REDFISH_PROVISIONING_FEATURE 1195a6349918SAppaRao Puli /** 1196a6349918SAppaRao Puli * @brief Retrieves provisioning status 1197a6349918SAppaRao Puli * 1198a6349918SAppaRao Puli * @param[in] aResp Shared pointer for completing asynchronous calls. 1199a6349918SAppaRao Puli * 1200a6349918SAppaRao Puli * @return None. 1201a6349918SAppaRao Puli */ 1202a6349918SAppaRao Puli void getProvisioningStatus(std::shared_ptr<AsyncResp> aResp) 1203a6349918SAppaRao Puli { 1204a6349918SAppaRao Puli BMCWEB_LOG_DEBUG << "Get OEM information."; 1205a6349918SAppaRao Puli crow::connections::systemBus->async_method_call( 1206a6349918SAppaRao Puli [aResp](const boost::system::error_code ec, 1207a6349918SAppaRao Puli const std::vector<std::pair<std::string, VariantType>> 1208a6349918SAppaRao Puli &propertiesList) { 1209a6349918SAppaRao Puli if (ec) 1210a6349918SAppaRao Puli { 1211a6349918SAppaRao Puli BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1212a6349918SAppaRao Puli messages::internalError(aResp->res); 1213a6349918SAppaRao Puli return; 1214a6349918SAppaRao Puli } 1215a6349918SAppaRao Puli 1216a6349918SAppaRao Puli const bool *provState = nullptr; 1217a6349918SAppaRao Puli const bool *lockState = nullptr; 1218a6349918SAppaRao Puli for (const std::pair<std::string, VariantType> &property : 1219a6349918SAppaRao Puli propertiesList) 1220a6349918SAppaRao Puli { 1221a6349918SAppaRao Puli if (property.first == "UfmProvisioned") 1222a6349918SAppaRao Puli { 1223a6349918SAppaRao Puli provState = std::get_if<bool>(&property.second); 1224a6349918SAppaRao Puli } 1225a6349918SAppaRao Puli else if (property.first == "UfmLocked") 1226a6349918SAppaRao Puli { 1227a6349918SAppaRao Puli lockState = std::get_if<bool>(&property.second); 1228a6349918SAppaRao Puli } 1229a6349918SAppaRao Puli } 1230a6349918SAppaRao Puli 1231a6349918SAppaRao Puli if ((provState == nullptr) || (lockState == nullptr)) 1232a6349918SAppaRao Puli { 1233a6349918SAppaRao Puli BMCWEB_LOG_DEBUG << "Unable to get PFR attributes."; 1234a6349918SAppaRao Puli messages::internalError(aResp->res); 1235a6349918SAppaRao Puli return; 1236a6349918SAppaRao Puli } 1237a6349918SAppaRao Puli 1238a6349918SAppaRao Puli nlohmann::json &oemPFR = 1239a6349918SAppaRao Puli aResp->res.jsonValue["Oem"]["OpenBmc"]["FirmwareProvisioning"]; 1240a6349918SAppaRao Puli if (*provState == true) 1241a6349918SAppaRao Puli { 1242a6349918SAppaRao Puli if (*lockState == true) 1243a6349918SAppaRao Puli { 1244a6349918SAppaRao Puli oemPFR["ProvisioningStatus"] = "ProvisionedAndLocked"; 1245a6349918SAppaRao Puli } 1246a6349918SAppaRao Puli else 1247a6349918SAppaRao Puli { 1248a6349918SAppaRao Puli oemPFR["ProvisioningStatus"] = "ProvisionedButNotLocked"; 1249a6349918SAppaRao Puli } 1250a6349918SAppaRao Puli } 1251a6349918SAppaRao Puli else 1252a6349918SAppaRao Puli { 1253a6349918SAppaRao Puli oemPFR["ProvisioningStatus"] = "NotProvisioned"; 1254a6349918SAppaRao Puli } 1255a6349918SAppaRao Puli }, 1256a6349918SAppaRao Puli "xyz.openbmc_project.PFR.Manager", "/xyz/openbmc_project/pfr", 1257a6349918SAppaRao Puli "org.freedesktop.DBus.Properties", "GetAll", 1258a6349918SAppaRao Puli "xyz.openbmc_project.PFR.Attributes"); 1259a6349918SAppaRao Puli } 1260a6349918SAppaRao Puli #endif 1261a6349918SAppaRao Puli 1262491d8ee7SSantosh Puranik /** 126351709ffdSYong Li * @brief Translates watchdog timeout action DBUS property value to redfish. 126451709ffdSYong Li * 126551709ffdSYong Li * @param[in] dbusAction The watchdog timeout action in D-BUS. 126651709ffdSYong Li * 126751709ffdSYong Li * @return Returns as a string, the timeout action in Redfish terms. If 126851709ffdSYong Li * translation cannot be done, returns an empty string. 126951709ffdSYong Li */ 127051709ffdSYong Li static std::string dbusToRfWatchdogAction(const std::string &dbusAction) 127151709ffdSYong Li { 127251709ffdSYong Li if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.None") 127351709ffdSYong Li { 127451709ffdSYong Li return "None"; 127551709ffdSYong Li } 127651709ffdSYong Li else if (dbusAction == 127751709ffdSYong Li "xyz.openbmc_project.State.Watchdog.Action.HardReset") 127851709ffdSYong Li { 127951709ffdSYong Li return "ResetSystem"; 128051709ffdSYong Li } 128151709ffdSYong Li else if (dbusAction == "xyz.openbmc_project.State.Watchdog.Action.PowerOff") 128251709ffdSYong Li { 128351709ffdSYong Li return "PowerDown"; 128451709ffdSYong Li } 128551709ffdSYong Li else if (dbusAction == 128651709ffdSYong Li "xyz.openbmc_project.State.Watchdog.Action.PowerCycle") 128751709ffdSYong Li { 128851709ffdSYong Li return "PowerCycle"; 128951709ffdSYong Li } 129051709ffdSYong Li 129151709ffdSYong Li return ""; 129251709ffdSYong Li } 129351709ffdSYong Li 129451709ffdSYong Li /** 1295c45f0082SYong Li *@brief Translates timeout action from Redfish to DBUS property value. 1296c45f0082SYong Li * 1297c45f0082SYong Li *@param[in] rfAction The timeout action in Redfish. 1298c45f0082SYong Li * 1299c45f0082SYong Li *@return Returns as a string, the time_out action as expected by DBUS. 1300c45f0082SYong Li *If translation cannot be done, returns an empty string. 1301c45f0082SYong Li */ 1302c45f0082SYong Li 1303c45f0082SYong Li static std::string rfToDbusWDTTimeOutAct(const std::string &rfAction) 1304c45f0082SYong Li { 1305c45f0082SYong Li if (rfAction == "None") 1306c45f0082SYong Li { 1307c45f0082SYong Li return "xyz.openbmc_project.State.Watchdog.Action.None"; 1308c45f0082SYong Li } 1309c45f0082SYong Li else if (rfAction == "PowerCycle") 1310c45f0082SYong Li { 1311c45f0082SYong Li return "xyz.openbmc_project.State.Watchdog.Action.PowerCycle"; 1312c45f0082SYong Li } 1313c45f0082SYong Li else if (rfAction == "PowerDown") 1314c45f0082SYong Li { 1315c45f0082SYong Li return "xyz.openbmc_project.State.Watchdog.Action.PowerOff"; 1316c45f0082SYong Li } 1317c45f0082SYong Li else if (rfAction == "ResetSystem") 1318c45f0082SYong Li { 1319c45f0082SYong Li return "xyz.openbmc_project.State.Watchdog.Action.HardReset"; 1320c45f0082SYong Li } 1321c45f0082SYong Li 1322c45f0082SYong Li return ""; 1323c45f0082SYong Li } 1324c45f0082SYong Li 1325c45f0082SYong Li /** 132651709ffdSYong Li * @brief Retrieves host watchdog timer properties over DBUS 132751709ffdSYong Li * 132851709ffdSYong Li * @param[in] aResp Shared pointer for completing asynchronous calls. 132951709ffdSYong Li * 133051709ffdSYong Li * @return None. 133151709ffdSYong Li */ 133251709ffdSYong Li void getHostWatchdogTimer(std::shared_ptr<AsyncResp> aResp) 133351709ffdSYong Li { 133451709ffdSYong Li BMCWEB_LOG_DEBUG << "Get host watchodg"; 133551709ffdSYong Li crow::connections::systemBus->async_method_call( 133651709ffdSYong Li [aResp](const boost::system::error_code ec, 133751709ffdSYong Li PropertiesType &properties) { 133851709ffdSYong Li if (ec) 133951709ffdSYong Li { 134051709ffdSYong Li // watchdog service is stopped 134151709ffdSYong Li BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 134251709ffdSYong Li return; 134351709ffdSYong Li } 134451709ffdSYong Li 134551709ffdSYong Li BMCWEB_LOG_DEBUG << "Got " << properties.size() << " wdt prop."; 134651709ffdSYong Li 134751709ffdSYong Li nlohmann::json &hostWatchdogTimer = 134851709ffdSYong Li aResp->res.jsonValue["HostWatchdogTimer"]; 134951709ffdSYong Li 135051709ffdSYong Li // watchdog service is running/enabled 135151709ffdSYong Li hostWatchdogTimer["Status"]["State"] = "Enabled"; 135251709ffdSYong Li 135351709ffdSYong Li for (const auto &property : properties) 135451709ffdSYong Li { 135551709ffdSYong Li BMCWEB_LOG_DEBUG << "prop=" << property.first; 135651709ffdSYong Li if (property.first == "Enabled") 135751709ffdSYong Li { 135851709ffdSYong Li const bool *state = std::get_if<bool>(&property.second); 135951709ffdSYong Li 136051709ffdSYong Li if (!state) 136151709ffdSYong Li { 136251709ffdSYong Li messages::internalError(aResp->res); 136351709ffdSYong Li continue; 136451709ffdSYong Li } 136551709ffdSYong Li 136651709ffdSYong Li hostWatchdogTimer["FunctionEnabled"] = *state; 136751709ffdSYong Li } 136851709ffdSYong Li else if (property.first == "ExpireAction") 136951709ffdSYong Li { 137051709ffdSYong Li const std::string *s = 137151709ffdSYong Li std::get_if<std::string>(&property.second); 137251709ffdSYong Li if (!s) 137351709ffdSYong Li { 137451709ffdSYong Li messages::internalError(aResp->res); 137551709ffdSYong Li continue; 137651709ffdSYong Li } 137751709ffdSYong Li 137851709ffdSYong Li std::string action = dbusToRfWatchdogAction(*s); 137951709ffdSYong Li if (action.empty()) 138051709ffdSYong Li { 138151709ffdSYong Li messages::internalError(aResp->res); 138251709ffdSYong Li continue; 138351709ffdSYong Li } 138451709ffdSYong Li hostWatchdogTimer["TimeoutAction"] = action; 138551709ffdSYong Li } 138651709ffdSYong Li } 138751709ffdSYong Li }, 138851709ffdSYong Li "xyz.openbmc_project.Watchdog", "/xyz/openbmc_project/watchdog/host0", 138951709ffdSYong Li "org.freedesktop.DBus.Properties", "GetAll", 139051709ffdSYong Li "xyz.openbmc_project.State.Watchdog"); 139151709ffdSYong Li } 139251709ffdSYong Li 139351709ffdSYong Li /** 1394c45f0082SYong Li * @brief Sets Host WatchDog Timer properties. 1395c45f0082SYong Li * 1396c45f0082SYong Li * @param[in] aResp Shared pointer for generating response message. 1397c45f0082SYong Li * @param[in] wdtEnable The WDTimer Enable value (true/false) from incoming 1398c45f0082SYong Li * RF request. 1399c45f0082SYong Li * @param[in] wdtTimeOutAction The WDT Timeout action, from incoming RF request. 1400c45f0082SYong Li * 1401c45f0082SYong Li * @return None. 1402c45f0082SYong Li */ 1403c45f0082SYong Li static void setWDTProperties(std::shared_ptr<AsyncResp> aResp, 1404c45f0082SYong Li const std::optional<bool> wdtEnable, 1405c45f0082SYong Li const std::optional<std::string> &wdtTimeOutAction) 1406c45f0082SYong Li { 1407c45f0082SYong Li BMCWEB_LOG_DEBUG << "Set host watchdog"; 1408c45f0082SYong Li 1409c45f0082SYong Li if (wdtTimeOutAction) 1410c45f0082SYong Li { 1411c45f0082SYong Li std::string wdtTimeOutActStr = rfToDbusWDTTimeOutAct(*wdtTimeOutAction); 1412c45f0082SYong Li // check if TimeOut Action is Valid 1413c45f0082SYong Li if (wdtTimeOutActStr.empty()) 1414c45f0082SYong Li { 1415c45f0082SYong Li BMCWEB_LOG_DEBUG << "Unsupported value for TimeoutAction: " 1416c45f0082SYong Li << *wdtTimeOutAction; 1417c45f0082SYong Li messages::propertyValueNotInList(aResp->res, *wdtTimeOutAction, 1418c45f0082SYong Li "TimeoutAction"); 1419c45f0082SYong Li return; 1420c45f0082SYong Li } 1421c45f0082SYong Li 1422c45f0082SYong Li crow::connections::systemBus->async_method_call( 1423c45f0082SYong Li [aResp](const boost::system::error_code ec) { 1424c45f0082SYong Li if (ec) 1425c45f0082SYong Li { 1426c45f0082SYong Li BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1427c45f0082SYong Li messages::internalError(aResp->res); 1428c45f0082SYong Li return; 1429c45f0082SYong Li } 1430c45f0082SYong Li }, 1431c45f0082SYong Li "xyz.openbmc_project.Watchdog", 1432c45f0082SYong Li "/xyz/openbmc_project/watchdog/host0", 1433c45f0082SYong Li "org.freedesktop.DBus.Properties", "Set", 1434c45f0082SYong Li "xyz.openbmc_project.State.Watchdog", "ExpireAction", 1435c45f0082SYong Li std::variant<std::string>(wdtTimeOutActStr)); 1436c45f0082SYong Li } 1437c45f0082SYong Li 1438c45f0082SYong Li if (wdtEnable) 1439c45f0082SYong Li { 1440c45f0082SYong Li crow::connections::systemBus->async_method_call( 1441c45f0082SYong Li [aResp](const boost::system::error_code ec) { 1442c45f0082SYong Li if (ec) 1443c45f0082SYong Li { 1444c45f0082SYong Li BMCWEB_LOG_DEBUG << "DBUS response error " << ec; 1445c45f0082SYong Li messages::internalError(aResp->res); 1446c45f0082SYong Li return; 1447c45f0082SYong Li } 1448c45f0082SYong Li }, 1449c45f0082SYong Li "xyz.openbmc_project.Watchdog", 1450c45f0082SYong Li "/xyz/openbmc_project/watchdog/host0", 1451c45f0082SYong Li "org.freedesktop.DBus.Properties", "Set", 1452c45f0082SYong Li "xyz.openbmc_project.State.Watchdog", "Enabled", 1453c45f0082SYong Li std::variant<bool>(*wdtEnable)); 1454c45f0082SYong Li } 1455c45f0082SYong Li } 1456c45f0082SYong Li 1457c45f0082SYong Li /** 1458c5b2abe0SLewanczyk, Dawid * SystemsCollection derived class for delivering ComputerSystems Collection 1459c5b2abe0SLewanczyk, Dawid * Schema 1460c5b2abe0SLewanczyk, Dawid */ 14611abe55efSEd Tanous class SystemsCollection : public Node 14621abe55efSEd Tanous { 1463c5b2abe0SLewanczyk, Dawid public: 14641abe55efSEd Tanous SystemsCollection(CrowApp &app) : Node(app, "/redfish/v1/Systems/") 14651abe55efSEd Tanous { 1466c5b2abe0SLewanczyk, Dawid entityPrivileges = { 1467c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::get, {{"Login"}}}, 1468c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::head, {{"Login"}}}, 1469c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::patch, {{"ConfigureComponents"}}}, 1470c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::put, {{"ConfigureComponents"}}}, 1471c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}}, 1472c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::post, {{"ConfigureComponents"}}}}; 1473c5b2abe0SLewanczyk, Dawid } 1474c5b2abe0SLewanczyk, Dawid 1475c5b2abe0SLewanczyk, Dawid private: 147655c7b7a2SEd Tanous void doGet(crow::Response &res, const crow::Request &req, 14771abe55efSEd Tanous const std::vector<std::string> ¶ms) override 14781abe55efSEd Tanous { 1479462023adSSunitha Harish std::shared_ptr<AsyncResp> asyncResp = std::make_shared<AsyncResp>(res); 14800f74e643SEd Tanous res.jsonValue["@odata.type"] = 14810f74e643SEd Tanous "#ComputerSystemCollection.ComputerSystemCollection"; 14820f74e643SEd Tanous res.jsonValue["@odata.id"] = "/redfish/v1/Systems"; 14830f74e643SEd Tanous res.jsonValue["Name"] = "Computer System Collection"; 1484462023adSSunitha Harish 1485462023adSSunitha Harish crow::connections::systemBus->async_method_call( 1486462023adSSunitha Harish [asyncResp](const boost::system::error_code ec, 1487462023adSSunitha Harish const std::variant<std::string> &hostName) { 1488462023adSSunitha Harish nlohmann::json &iface_array = 1489462023adSSunitha Harish asyncResp->res.jsonValue["Members"]; 1490462023adSSunitha Harish iface_array = nlohmann::json::array(); 1491462023adSSunitha Harish auto &count = asyncResp->res.jsonValue["Members@odata.count"]; 1492462023adSSunitha Harish count = 0; 1493462023adSSunitha Harish if (ec) 1494462023adSSunitha Harish { 1495462023adSSunitha Harish iface_array.push_back( 1496462023adSSunitha Harish {{"@odata.id", "/redfish/v1/Systems/system"}}); 1497462023adSSunitha Harish count = iface_array.size(); 1498462023adSSunitha Harish return; 1499462023adSSunitha Harish } 1500462023adSSunitha Harish BMCWEB_LOG_DEBUG << "Hypervisor is available"; 1501462023adSSunitha Harish iface_array.push_back( 1502462023adSSunitha Harish {{"@odata.id", "/redfish/v1/Systems/system"}}); 1503462023adSSunitha Harish iface_array.push_back( 1504462023adSSunitha Harish {{"@odata.id", "/redfish/v1/Systems/hypervisor"}}); 1505462023adSSunitha Harish count = iface_array.size(); 1506462023adSSunitha Harish }, 1507462023adSSunitha Harish "xyz.openbmc_project.Settings", "/xyz/openbmc_project/network/vmi", 1508462023adSSunitha Harish "org.freedesktop.DBus.Properties", "Get", 1509462023adSSunitha Harish "xyz.openbmc_project.Network.SystemConfiguration", "HostName"); 1510c5b2abe0SLewanczyk, Dawid } 1511c5b2abe0SLewanczyk, Dawid }; 1512c5b2abe0SLewanczyk, Dawid 1513c5b2abe0SLewanczyk, Dawid /** 1514cc340dd9SEd Tanous * SystemActionsReset class supports handle POST method for Reset action. 1515cc340dd9SEd Tanous * The class retrieves and sends data directly to D-Bus. 1516cc340dd9SEd Tanous */ 1517cc340dd9SEd Tanous class SystemActionsReset : public Node 1518cc340dd9SEd Tanous { 1519cc340dd9SEd Tanous public: 1520cc340dd9SEd Tanous SystemActionsReset(CrowApp &app) : 1521029573d4SEd Tanous Node(app, "/redfish/v1/Systems/system/Actions/ComputerSystem.Reset/") 1522cc340dd9SEd Tanous { 1523cc340dd9SEd Tanous entityPrivileges = { 1524cc340dd9SEd Tanous {boost::beast::http::verb::post, {{"ConfigureComponents"}}}}; 1525cc340dd9SEd Tanous } 1526cc340dd9SEd Tanous 1527cc340dd9SEd Tanous private: 1528cc340dd9SEd Tanous /** 1529cc340dd9SEd Tanous * Function handles POST method request. 1530cc340dd9SEd Tanous * Analyzes POST body message before sends Reset request data to D-Bus. 1531cc340dd9SEd Tanous */ 1532cc340dd9SEd Tanous void doPost(crow::Response &res, const crow::Request &req, 1533cc340dd9SEd Tanous const std::vector<std::string> ¶ms) override 1534cc340dd9SEd Tanous { 1535cc340dd9SEd Tanous auto asyncResp = std::make_shared<AsyncResp>(res); 1536cc340dd9SEd Tanous 15379712f8acSEd Tanous std::string resetType; 15389712f8acSEd Tanous if (!json_util::readJson(req, res, "ResetType", resetType)) 1539cc340dd9SEd Tanous { 1540cc340dd9SEd Tanous return; 1541cc340dd9SEd Tanous } 1542cc340dd9SEd Tanous 1543d22c8396SJason M. Bills // Get the command and host vs. chassis 1544cc340dd9SEd Tanous std::string command; 1545d22c8396SJason M. Bills bool hostCommand; 15469712f8acSEd Tanous if (resetType == "On") 1547cc340dd9SEd Tanous { 1548cc340dd9SEd Tanous command = "xyz.openbmc_project.State.Host.Transition.On"; 1549d22c8396SJason M. Bills hostCommand = true; 1550d22c8396SJason M. Bills } 1551d22c8396SJason M. Bills else if (resetType == "ForceOff") 1552d22c8396SJason M. Bills { 1553d22c8396SJason M. Bills command = "xyz.openbmc_project.State.Chassis.Transition.Off"; 1554d22c8396SJason M. Bills hostCommand = false; 1555d22c8396SJason M. Bills } 1556d22c8396SJason M. Bills else if (resetType == "ForceOn") 1557d22c8396SJason M. Bills { 1558d22c8396SJason M. Bills command = "xyz.openbmc_project.State.Host.Transition.On"; 1559d22c8396SJason M. Bills hostCommand = true; 1560d22c8396SJason M. Bills } 1561d22c8396SJason M. Bills else if (resetType == "ForceRestart") 1562d22c8396SJason M. Bills { 156386a0851aSJason M. Bills command = 156486a0851aSJason M. Bills "xyz.openbmc_project.State.Host.Transition.ForceWarmReboot"; 156586a0851aSJason M. Bills hostCommand = true; 1566cc340dd9SEd Tanous } 15679712f8acSEd Tanous else if (resetType == "GracefulShutdown") 1568cc340dd9SEd Tanous { 1569cc340dd9SEd Tanous command = "xyz.openbmc_project.State.Host.Transition.Off"; 1570d22c8396SJason M. Bills hostCommand = true; 1571cc340dd9SEd Tanous } 15729712f8acSEd Tanous else if (resetType == "GracefulRestart") 1573cc340dd9SEd Tanous { 157486a0851aSJason M. Bills command = 157586a0851aSJason M. Bills "xyz.openbmc_project.State.Host.Transition.GracefulWarmReboot"; 1576d22c8396SJason M. Bills hostCommand = true; 1577d22c8396SJason M. Bills } 1578d22c8396SJason M. Bills else if (resetType == "PowerCycle") 1579d22c8396SJason M. Bills { 158086a0851aSJason M. Bills command = "xyz.openbmc_project.State.Host.Transition.Reboot"; 158186a0851aSJason M. Bills hostCommand = true; 1582cc340dd9SEd Tanous } 1583bfd5b826SLakshminarayana R. Kammath else if (resetType == "Nmi") 1584bfd5b826SLakshminarayana R. Kammath { 1585bfd5b826SLakshminarayana R. Kammath doNMI(asyncResp); 1586bfd5b826SLakshminarayana R. Kammath return; 1587bfd5b826SLakshminarayana R. Kammath } 1588cc340dd9SEd Tanous else 1589cc340dd9SEd Tanous { 1590f12894f8SJason M. Bills messages::actionParameterUnknown(res, "Reset", resetType); 1591cc340dd9SEd Tanous return; 1592cc340dd9SEd Tanous } 1593cc340dd9SEd Tanous 1594d22c8396SJason M. Bills if (hostCommand) 1595d22c8396SJason M. Bills { 1596cc340dd9SEd Tanous crow::connections::systemBus->async_method_call( 1597d22c8396SJason M. Bills [asyncResp, resetType](const boost::system::error_code ec) { 1598cc340dd9SEd Tanous if (ec) 1599cc340dd9SEd Tanous { 1600cc340dd9SEd Tanous BMCWEB_LOG_ERROR << "D-Bus responses error: " << ec; 1601d22c8396SJason M. Bills if (ec.value() == boost::asio::error::invalid_argument) 1602d22c8396SJason M. Bills { 1603d22c8396SJason M. Bills messages::actionParameterNotSupported( 1604d22c8396SJason M. Bills asyncResp->res, resetType, "Reset"); 1605d22c8396SJason M. Bills } 1606d22c8396SJason M. Bills else 1607d22c8396SJason M. Bills { 1608f12894f8SJason M. Bills messages::internalError(asyncResp->res); 1609d22c8396SJason M. Bills } 1610cc340dd9SEd Tanous return; 1611cc340dd9SEd Tanous } 1612f12894f8SJason M. Bills messages::success(asyncResp->res); 1613cc340dd9SEd Tanous }, 1614cc340dd9SEd Tanous "xyz.openbmc_project.State.Host", 1615cc340dd9SEd Tanous "/xyz/openbmc_project/state/host0", 1616cc340dd9SEd Tanous "org.freedesktop.DBus.Properties", "Set", 16179712f8acSEd Tanous "xyz.openbmc_project.State.Host", "RequestedHostTransition", 1618abf2add6SEd Tanous std::variant<std::string>{command}); 1619cc340dd9SEd Tanous } 1620d22c8396SJason M. Bills else 1621d22c8396SJason M. Bills { 1622d22c8396SJason M. Bills crow::connections::systemBus->async_method_call( 1623d22c8396SJason M. Bills [asyncResp, resetType](const boost::system::error_code ec) { 1624d22c8396SJason M. Bills if (ec) 1625d22c8396SJason M. Bills { 1626d22c8396SJason M. Bills BMCWEB_LOG_ERROR << "D-Bus responses error: " << ec; 1627d22c8396SJason M. Bills if (ec.value() == boost::asio::error::invalid_argument) 1628d22c8396SJason M. Bills { 1629d22c8396SJason M. Bills messages::actionParameterNotSupported( 1630d22c8396SJason M. Bills asyncResp->res, resetType, "Reset"); 1631d22c8396SJason M. Bills } 1632d22c8396SJason M. Bills else 1633d22c8396SJason M. Bills { 1634d22c8396SJason M. Bills messages::internalError(asyncResp->res); 1635d22c8396SJason M. Bills } 1636d22c8396SJason M. Bills return; 1637d22c8396SJason M. Bills } 1638d22c8396SJason M. Bills messages::success(asyncResp->res); 1639d22c8396SJason M. Bills }, 1640d22c8396SJason M. Bills "xyz.openbmc_project.State.Chassis", 1641d22c8396SJason M. Bills "/xyz/openbmc_project/state/chassis0", 1642d22c8396SJason M. Bills "org.freedesktop.DBus.Properties", "Set", 1643d22c8396SJason M. Bills "xyz.openbmc_project.State.Chassis", "RequestedPowerTransition", 1644d22c8396SJason M. Bills std::variant<std::string>{command}); 1645d22c8396SJason M. Bills } 1646d22c8396SJason M. Bills } 1647bfd5b826SLakshminarayana R. Kammath /** 1648bfd5b826SLakshminarayana R. Kammath * Function transceives data with dbus directly. 1649bfd5b826SLakshminarayana R. Kammath */ 1650bfd5b826SLakshminarayana R. Kammath void doNMI(const std::shared_ptr<AsyncResp> &asyncResp) 1651bfd5b826SLakshminarayana R. Kammath { 1652bfd5b826SLakshminarayana R. Kammath constexpr char const *serviceName = 1653bfd5b826SLakshminarayana R. Kammath "xyz.openbmc_project.Control.Host.NMI"; 1654bfd5b826SLakshminarayana R. Kammath constexpr char const *objectPath = 1655bfd5b826SLakshminarayana R. Kammath "/xyz/openbmc_project/control/host0/nmi"; 1656bfd5b826SLakshminarayana R. Kammath constexpr char const *interfaceName = 1657bfd5b826SLakshminarayana R. Kammath "xyz.openbmc_project.Control.Host.NMI"; 1658bfd5b826SLakshminarayana R. Kammath constexpr char const *method = "NMI"; 1659bfd5b826SLakshminarayana R. Kammath 1660bfd5b826SLakshminarayana R. Kammath crow::connections::systemBus->async_method_call( 1661bfd5b826SLakshminarayana R. Kammath [asyncResp](const boost::system::error_code ec) { 1662bfd5b826SLakshminarayana R. Kammath if (ec) 1663bfd5b826SLakshminarayana R. Kammath { 1664bfd5b826SLakshminarayana R. Kammath BMCWEB_LOG_ERROR << " Bad D-Bus request error: " << ec; 1665bfd5b826SLakshminarayana R. Kammath messages::internalError(asyncResp->res); 1666bfd5b826SLakshminarayana R. Kammath return; 1667bfd5b826SLakshminarayana R. Kammath } 1668bfd5b826SLakshminarayana R. Kammath messages::success(asyncResp->res); 1669bfd5b826SLakshminarayana R. Kammath }, 1670bfd5b826SLakshminarayana R. Kammath serviceName, objectPath, interfaceName, method); 1671bfd5b826SLakshminarayana R. Kammath } 1672cc340dd9SEd Tanous }; 1673cc340dd9SEd Tanous 1674cc340dd9SEd Tanous /** 16756617338dSEd Tanous * Systems derived class for delivering Computer Systems Schema. 1676c5b2abe0SLewanczyk, Dawid */ 16771abe55efSEd Tanous class Systems : public Node 16781abe55efSEd Tanous { 1679c5b2abe0SLewanczyk, Dawid public: 1680c5b2abe0SLewanczyk, Dawid /* 1681c5b2abe0SLewanczyk, Dawid * Default Constructor 1682c5b2abe0SLewanczyk, Dawid */ 1683029573d4SEd Tanous Systems(CrowApp &app) : Node(app, "/redfish/v1/Systems/system/") 16841abe55efSEd Tanous { 1685c5b2abe0SLewanczyk, Dawid entityPrivileges = { 1686c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::get, {{"Login"}}}, 1687c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::head, {{"Login"}}}, 1688c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::patch, {{"ConfigureComponents"}}}, 1689c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::put, {{"ConfigureComponents"}}}, 1690c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::delete_, {{"ConfigureComponents"}}}, 1691c5b2abe0SLewanczyk, Dawid {boost::beast::http::verb::post, {{"ConfigureComponents"}}}}; 1692c5b2abe0SLewanczyk, Dawid } 1693c5b2abe0SLewanczyk, Dawid 1694c5b2abe0SLewanczyk, Dawid private: 1695c5b2abe0SLewanczyk, Dawid /** 1696c5b2abe0SLewanczyk, Dawid * Functions triggers appropriate requests on DBus 1697c5b2abe0SLewanczyk, Dawid */ 169855c7b7a2SEd Tanous void doGet(crow::Response &res, const crow::Request &req, 16991abe55efSEd Tanous const std::vector<std::string> ¶ms) override 17001abe55efSEd Tanous { 1701491d8ee7SSantosh Puranik res.jsonValue["@odata.type"] = "#ComputerSystem.v1_6_0.ComputerSystem"; 1702450a25cbSGunnar Mills res.jsonValue["Name"] = "system"; 1703029573d4SEd Tanous res.jsonValue["Id"] = "system"; 17040f74e643SEd Tanous res.jsonValue["SystemType"] = "Physical"; 17050f74e643SEd Tanous res.jsonValue["Description"] = "Computer System"; 17060f74e643SEd Tanous res.jsonValue["ProcessorSummary"]["Count"] = 0; 17070f74e643SEd Tanous res.jsonValue["ProcessorSummary"]["Status"]["State"] = "Disabled"; 17085fd7ba65SCheng C Yang res.jsonValue["MemorySummary"]["TotalSystemMemoryGiB"] = uint64_t(0); 17090f74e643SEd Tanous res.jsonValue["MemorySummary"]["Status"]["State"] = "Disabled"; 1710029573d4SEd Tanous res.jsonValue["@odata.id"] = "/redfish/v1/Systems/system"; 171104a258f4SEd Tanous 1712443c2934SRapkiewicz, Pawel res.jsonValue["Processors"] = { 1713029573d4SEd Tanous {"@odata.id", "/redfish/v1/Systems/system/Processors"}}; 1714443c2934SRapkiewicz, Pawel res.jsonValue["Memory"] = { 1715029573d4SEd Tanous {"@odata.id", "/redfish/v1/Systems/system/Memory"}}; 1716a25aeccfSNikhil Potade res.jsonValue["Storage"] = { 1717a25aeccfSNikhil Potade {"@odata.id", "/redfish/v1/Systems/system/Storage"}}; 1718029573d4SEd Tanous 1719cc340dd9SEd Tanous // TODO Need to support ForceRestart. 1720cc340dd9SEd Tanous res.jsonValue["Actions"]["#ComputerSystem.Reset"] = { 1721cc340dd9SEd Tanous {"target", 1722029573d4SEd Tanous "/redfish/v1/Systems/system/Actions/ComputerSystem.Reset"}, 1723cc340dd9SEd Tanous {"ResetType@Redfish.AllowableValues", 1724d22c8396SJason M. Bills {"On", "ForceOff", "ForceOn", "ForceRestart", "GracefulRestart", 1725bfd5b826SLakshminarayana R. Kammath "GracefulShutdown", "PowerCycle", "Nmi"}}}; 1726c5b2abe0SLewanczyk, Dawid 1727c4bf6374SJason M. Bills res.jsonValue["LogServices"] = { 1728029573d4SEd Tanous {"@odata.id", "/redfish/v1/Systems/system/LogServices"}}; 1729c4bf6374SJason M. Bills 1730d82a3acdSCarol Wang res.jsonValue["Bios"] = { 1731d82a3acdSCarol Wang {"@odata.id", "/redfish/v1/Systems/system/Bios"}}; 1732d82a3acdSCarol Wang 1733c5d03ff4SJennifer Lee res.jsonValue["Links"]["ManagedBy"] = { 1734c5d03ff4SJennifer Lee {{"@odata.id", "/redfish/v1/Managers/bmc"}}}; 1735c5d03ff4SJennifer Lee 1736c5d03ff4SJennifer Lee res.jsonValue["Status"] = { 1737c5d03ff4SJennifer Lee {"Health", "OK"}, 1738c5d03ff4SJennifer Lee {"State", "Enabled"}, 1739c5d03ff4SJennifer Lee }; 1740a0803efaSEd Tanous auto asyncResp = std::make_shared<AsyncResp>(res); 1741c5b2abe0SLewanczyk, Dawid 1742e284a7c1SJames Feist constexpr const std::array<const char *, 4> inventoryForSystems = { 1743b49ac873SJames Feist "xyz.openbmc_project.Inventory.Item.Dimm", 17442ad9c2f6SJames Feist "xyz.openbmc_project.Inventory.Item.Cpu", 1745e284a7c1SJames Feist "xyz.openbmc_project.Inventory.Item.Drive", 1746e284a7c1SJames Feist "xyz.openbmc_project.Inventory.Item.StorageController"}; 1747b49ac873SJames Feist 1748b49ac873SJames Feist auto health = std::make_shared<HealthPopulate>(asyncResp); 1749b49ac873SJames Feist crow::connections::systemBus->async_method_call( 1750b49ac873SJames Feist [health](const boost::system::error_code ec, 1751b49ac873SJames Feist std::vector<std::string> &resp) { 1752b49ac873SJames Feist if (ec) 1753b49ac873SJames Feist { 1754b49ac873SJames Feist // no inventory 1755b49ac873SJames Feist return; 1756b49ac873SJames Feist } 1757b49ac873SJames Feist 1758b49ac873SJames Feist health->inventory = std::move(resp); 1759b49ac873SJames Feist }, 1760b49ac873SJames Feist "xyz.openbmc_project.ObjectMapper", 1761b49ac873SJames Feist "/xyz/openbmc_project/object_mapper", 1762b49ac873SJames Feist "xyz.openbmc_project.ObjectMapper", "GetSubTreePaths", "/", 1763b49ac873SJames Feist int32_t(0), inventoryForSystems); 1764b49ac873SJames Feist 1765b49ac873SJames Feist health->populate(); 1766b49ac873SJames Feist 1767c5d03ff4SJennifer Lee getMainChassisId(asyncResp, [](const std::string &chassisId, 1768c5d03ff4SJennifer Lee std::shared_ptr<AsyncResp> aRsp) { 1769c5d03ff4SJennifer Lee aRsp->res.jsonValue["Links"]["Chassis"] = { 1770c5d03ff4SJennifer Lee {{"@odata.id", "/redfish/v1/Chassis/" + chassisId}}}; 1771c5d03ff4SJennifer Lee }); 1772a3002228SAppaRao Puli 1773a3002228SAppaRao Puli getIndicatorLedState(asyncResp); 17745bc2dc8eSJames Feist getComputerSystem(asyncResp, health); 17756c34de48SEd Tanous getHostState(asyncResp); 1776491d8ee7SSantosh Puranik getBootProperties(asyncResp); 1777adbe192aSJason M. Bills getPCIeDeviceList(asyncResp, "PCIeDevices"); 177851709ffdSYong Li getHostWatchdogTimer(asyncResp); 1779c6a620f2SGeorge Liu getPowerRestorePolicy(asyncResp); 1780a6349918SAppaRao Puli #ifdef BMCWEB_ENABLE_REDFISH_PROVISIONING_FEATURE 1781a6349918SAppaRao Puli getProvisioningStatus(asyncResp); 1782a6349918SAppaRao Puli #endif 1783c5b2abe0SLewanczyk, Dawid } 1784c5b2abe0SLewanczyk, Dawid 178555c7b7a2SEd Tanous void doPatch(crow::Response &res, const crow::Request &req, 17861abe55efSEd Tanous const std::vector<std::string> ¶ms) override 17871abe55efSEd Tanous { 1788cde19e5fSSantosh Puranik std::optional<std::string> indicatorLed; 1789491d8ee7SSantosh Puranik std::optional<nlohmann::json> bootProps; 1790c45f0082SYong Li std::optional<nlohmann::json> wdtTimerProps; 1791c6a620f2SGeorge Liu std::optional<std::string> powerRestorePolicy; 179241352c24SSantosh Puranik auto asyncResp = std::make_shared<AsyncResp>(res); 179341352c24SSantosh Puranik 1794944ffaf9SJohnathan Mantey if (!json_util::readJson(req, res, "IndicatorLED", indicatorLed, "Boot", 1795c6a620f2SGeorge Liu bootProps, "WatchdogTimer", wdtTimerProps, 1796c6a620f2SGeorge Liu "PowerRestorePolicy", powerRestorePolicy)) 17976617338dSEd Tanous { 17986617338dSEd Tanous return; 17996617338dSEd Tanous } 1800491d8ee7SSantosh Puranik 1801944ffaf9SJohnathan Mantey res.result(boost::beast::http::status::no_content); 1802c45f0082SYong Li 1803c45f0082SYong Li if (wdtTimerProps) 1804c45f0082SYong Li { 1805c45f0082SYong Li std::optional<bool> wdtEnable; 1806c45f0082SYong Li std::optional<std::string> wdtTimeOutAction; 1807c45f0082SYong Li 1808c45f0082SYong Li if (!json_util::readJson(*wdtTimerProps, asyncResp->res, 1809c45f0082SYong Li "FunctionEnabled", wdtEnable, 1810c45f0082SYong Li "TimeoutAction", wdtTimeOutAction)) 1811c45f0082SYong Li { 1812c45f0082SYong Li return; 1813c45f0082SYong Li } 1814c45f0082SYong Li setWDTProperties(asyncResp, std::move(wdtEnable), 1815c45f0082SYong Li std::move(wdtTimeOutAction)); 1816c45f0082SYong Li } 1817c45f0082SYong Li 1818491d8ee7SSantosh Puranik if (bootProps) 1819491d8ee7SSantosh Puranik { 1820491d8ee7SSantosh Puranik std::optional<std::string> bootSource; 1821491d8ee7SSantosh Puranik std::optional<std::string> bootEnable; 1822491d8ee7SSantosh Puranik 1823491d8ee7SSantosh Puranik if (!json_util::readJson(*bootProps, asyncResp->res, 1824491d8ee7SSantosh Puranik "BootSourceOverrideTarget", bootSource, 1825491d8ee7SSantosh Puranik "BootSourceOverrideEnabled", bootEnable)) 1826491d8ee7SSantosh Puranik { 1827491d8ee7SSantosh Puranik return; 1828491d8ee7SSantosh Puranik } 1829491d8ee7SSantosh Puranik setBootProperties(asyncResp, std::move(bootSource), 1830491d8ee7SSantosh Puranik std::move(bootEnable)); 1831491d8ee7SSantosh Puranik } 1832265c1602SJohnathan Mantey 18339712f8acSEd Tanous if (indicatorLed) 18346617338dSEd Tanous { 1835a3002228SAppaRao Puli setIndicatorLedState(asyncResp, std::move(*indicatorLed)); 18366617338dSEd Tanous } 1837c6a620f2SGeorge Liu 1838c6a620f2SGeorge Liu if (powerRestorePolicy) 1839c6a620f2SGeorge Liu { 1840c6a620f2SGeorge Liu setPowerRestorePolicy(asyncResp, std::move(*powerRestorePolicy)); 1841c6a620f2SGeorge Liu } 1842c5b2abe0SLewanczyk, Dawid } 1843c5b2abe0SLewanczyk, Dawid }; 1844c5b2abe0SLewanczyk, Dawid } // namespace redfish 1845