blob: c52f395686a51f8bfa335111b957dd663a9e49c5 [file] [log] [blame]
#pragma once
#include "app.hpp"
#include "logging.hpp"
#include "query.hpp"
#include "registries/privilege_registry.hpp"
#include "utils/chassis_utils.hpp"
#include "utils/json_utils.hpp"
#include <boost/url/format.hpp>
#include <optional>
#include <string>
namespace redfish
{
inline void doThermalSubsystemCollection(
const std::shared_ptr<bmcweb::AsyncResp>& asyncResp,
const std::string& chassisId,
const std::optional<std::string>& validChassisPath)
{
if (!validChassisPath)
{
BMCWEB_LOG_WARNING("Not a valid chassis ID{}", chassisId);
messages::resourceNotFound(asyncResp->res, "Chassis", chassisId);
return;
}
asyncResp->res.addHeader(
boost::beast::http::field::link,
"</redfish/v1/JsonSchemas/ThermalSubsystem/ThermalSubsystem.json>; rel=describedby");
asyncResp->res.jsonValue["@odata.type"] =
"#ThermalSubsystem.v1_0_0.ThermalSubsystem";
asyncResp->res.jsonValue["Name"] = "Thermal Subsystem";
asyncResp->res.jsonValue["Id"] = "ThermalSubsystem";
asyncResp->res.jsonValue["@odata.id"] = boost::urls::format(
"/redfish/v1/Chassis/{}/ThermalSubsystem", chassisId);
asyncResp->res.jsonValue["Fans"]["@odata.id"] = boost::urls::format(
"/redfish/v1/Chassis/{}/ThermalSubsystem/Fans", chassisId);
asyncResp->res.jsonValue["ThermalMetrics"]["@odata.id"] =
boost::urls::format(
"/redfish/v1/Chassis/{}/ThermalSubsystem/ThermalMetrics",
chassisId);
asyncResp->res.jsonValue["Status"]["State"] = "Enabled";
asyncResp->res.jsonValue["Status"]["Health"] = "OK";
}
inline void handleThermalSubsystemCollectionHead(
App& app, const crow::Request& req,
const std::shared_ptr<bmcweb::AsyncResp>& asyncResp,
const std::string& chassisId)
{
if (!redfish::setUpRedfishRoute(app, req, asyncResp))
{
return;
}
auto respHandler = [asyncResp, chassisId](
const std::optional<std::string>& validChassisPath) {
if (!validChassisPath)
{
messages::resourceNotFound(asyncResp->res, "Chassis", chassisId);
return;
}
asyncResp->res.addHeader(
boost::beast::http::field::link,
"</redfish/v1/JsonSchemas/ThermalSubsystem/ThermalSubsystem.json>; rel=describedby");
};
redfish::chassis_utils::getValidChassisPath(asyncResp, chassisId,
std::bind_front(respHandler));
}
inline void handleThermalSubsystemCollectionGet(
App& app, const crow::Request& req,
const std::shared_ptr<bmcweb::AsyncResp>& asyncResp,
const std::string& chassisId)
{
if (!redfish::setUpRedfishRoute(app, req, asyncResp))
{
return;
}
redfish::chassis_utils::getValidChassisPath(
asyncResp, chassisId,
std::bind_front(doThermalSubsystemCollection, asyncResp, chassisId));
}
inline void requestRoutesThermalSubsystem(App& app)
{
BMCWEB_ROUTE(app, "/redfish/v1/Chassis/<str>/ThermalSubsystem/")
.privileges(redfish::privileges::headThermalSubsystem)
.methods(boost::beast::http::verb::head)(std::bind_front(
handleThermalSubsystemCollectionHead, std::ref(app)));
BMCWEB_ROUTE(app, "/redfish/v1/Chassis/<str>/ThermalSubsystem/")
.privileges(redfish::privileges::getThermalSubsystem)
.methods(boost::beast::http::verb::get)(std::bind_front(
handleThermalSubsystemCollectionGet, std::ref(app)));
}
} // namespace redfish