| /* |
| // 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 "node.hpp" |
| |
| namespace redfish { |
| |
| static OperationMap roleOpMap = { |
| {crow::HTTPMethod::GET, {{"Login"}}}, |
| {crow::HTTPMethod::HEAD, {{"Login"}}}, |
| {crow::HTTPMethod::PATCH, {{"ConfigureManager"}}}, |
| {crow::HTTPMethod::PUT, {{"ConfigureManager"}}}, |
| {crow::HTTPMethod::DELETE, {{"ConfigureManager"}}}, |
| {crow::HTTPMethod::POST, {{"ConfigureManager"}}}}; |
| |
| static OperationMap roleCollectionOpMap = { |
| {crow::HTTPMethod::GET, {{"Login"}}}, |
| {crow::HTTPMethod::HEAD, {{"Login"}}}, |
| {crow::HTTPMethod::PATCH, {{"ConfigureManager"}}}, |
| {crow::HTTPMethod::PUT, {{"ConfigureManager"}}}, |
| {crow::HTTPMethod::DELETE, {{"ConfigureManager"}}}, |
| {crow::HTTPMethod::POST, {{"ConfigureManager"}}}}; |
| |
| class Roles : public Node { |
| public: |
| Roles(CrowApp& app) |
| : Node(app, EntityPrivileges(std::move(roleOpMap)), |
| "/redfish/v1/AccountService/Roles/Administrator/") { |
| Node::json["@odata.id"] = "/redfish/v1/AccountService/Roles/Administrator"; |
| Node::json["@odata.type"] = "#Role.v1_0_2.Role"; |
| Node::json["@odata.context"] = "/redfish/v1/$metadata#Role.Role"; |
| Node::json["Id"] = "Administrator"; |
| Node::json["Name"] = "User Role"; |
| Node::json["Description"] = "Administrator User Role"; |
| Node::json["IsPredefined"] = true; |
| Node::json["AssignedPrivileges"] = {"Login", "ConfigureManager", |
| "ConfigureUsers", "ConfigureSelf", |
| "ConfigureComponents"}; |
| Node::json["OemPrivileges"] = nlohmann::json::array(); |
| } |
| |
| private: |
| void doGet(crow::response& res, const crow::request& req, |
| const std::vector<std::string>& params) override { |
| res.json_value = Node::json; |
| res.end(); |
| } |
| }; |
| |
| class RoleCollection : public Node { |
| public: |
| RoleCollection(CrowApp& app) |
| : Node(app, EntityPrivileges(std::move(roleCollectionOpMap)), |
| "/redfish/v1/AccountService/Roles/") { |
| Node::json["@odata.id"] = "/redfish/v1/AccountService/Roles"; |
| Node::json["@odata.type"] = "#RoleCollection.RoleCollection"; |
| Node::json["@odata.context"] = |
| "/redfish/v1/$metadata#RoleCollection.RoleCollection"; |
| Node::json["Name"] = "Roles Collection"; |
| Node::json["Description"] = "BMC User Roles"; |
| Node::json["Members@odata.count"] = 1; |
| Node::json["Members"] = { |
| {"@odata.id", "/redfish/v1/AccountService/Roles/Administrator"}}; |
| } |
| |
| private: |
| void doGet(crow::response& res, const crow::request& req, |
| const std::vector<std::string>& params) override { |
| res.json_value = Node::json; |
| res.end(); |
| } |
| }; |
| |
| } // namespace redfish |