| /* |
| // Copyright (c) 2018 Intel Corporation |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| */ |
| #pragma once |
| |
| #include "sensors.hpp" |
| |
| #include <app.hpp> |
| #include <query.hpp> |
| #include <registries/privilege_registry.hpp> |
| |
| namespace redfish |
| { |
| |
| inline void requestRoutesThermal(App& app) |
| { |
| BMCWEB_ROUTE(app, "/redfish/v1/Chassis/<str>/Thermal/") |
| .privileges(redfish::privileges::getThermal) |
| .methods(boost::beast::http::verb::get)( |
| [&app](const crow::Request& req, |
| const std::shared_ptr<bmcweb::AsyncResp>& asyncResp, |
| const std::string& chassisName) { |
| if (!redfish::setUpRedfishRoute(app, req, asyncResp->res)) |
| { |
| return; |
| } |
| |
| auto thermalPaths = |
| sensors::dbus::paths.find(sensors::node::thermal); |
| if (thermalPaths == sensors::dbus::paths.end()) |
| { |
| messages::internalError(asyncResp->res); |
| return; |
| } |
| |
| auto sensorAsyncResp = std::make_shared<SensorsAsyncResp>( |
| asyncResp, chassisName, thermalPaths->second, |
| sensors::node::thermal); |
| |
| // TODO Need to get Chassis Redundancy information. |
| getChassisData(sensorAsyncResp); |
| }); |
| |
| BMCWEB_ROUTE(app, "/redfish/v1/Chassis/<str>/Thermal/") |
| .privileges(redfish::privileges::patchThermal) |
| .methods(boost::beast::http::verb::patch)( |
| [&app](const crow::Request& req, |
| const std::shared_ptr<bmcweb::AsyncResp>& asyncResp, |
| const std::string& chassisName) { |
| if (!redfish::setUpRedfishRoute(app, req, asyncResp->res)) |
| { |
| return; |
| } |
| |
| auto thermalPaths = |
| sensors::dbus::paths.find(sensors::node::thermal); |
| if (thermalPaths == sensors::dbus::paths.end()) |
| { |
| messages::internalError(asyncResp->res); |
| return; |
| } |
| |
| std::optional<std::vector<nlohmann::json>> |
| temperatureCollections; |
| std::optional<std::vector<nlohmann::json>> fanCollections; |
| std::unordered_map<std::string, std::vector<nlohmann::json>> |
| allCollections; |
| |
| auto sensorsAsyncResp = std::make_shared<SensorsAsyncResp>( |
| asyncResp, chassisName, thermalPaths->second, |
| sensors::node::thermal); |
| |
| if (!json_util::readJsonPatch( |
| req, sensorsAsyncResp->asyncResp->res, "Temperatures", |
| temperatureCollections, "Fans", fanCollections)) |
| { |
| return; |
| } |
| if (!temperatureCollections && !fanCollections) |
| { |
| messages::resourceNotFound(sensorsAsyncResp->asyncResp->res, |
| "Thermal", |
| "Temperatures / Voltages"); |
| return; |
| } |
| if (temperatureCollections) |
| { |
| allCollections.emplace("Temperatures", |
| *std::move(temperatureCollections)); |
| } |
| if (fanCollections) |
| { |
| allCollections.emplace("Fans", *std::move(fanCollections)); |
| } |
| setSensorsOverride(sensorsAsyncResp, allCollections); |
| }); |
| } |
| |
| } // namespace redfish |