blob: 4f20ec960e7358d2851c77c1bf3442b819e59e3c [file] [log] [blame]
Ratan Gupta453fed02019-12-14 09:39:47 +05301#pragma once
2#include <app.h>
3#include <tinyxml2.h>
4
5#include <async_resp.hpp>
Sunitha Harish97b0e432019-11-21 04:59:29 -06006#include <boost/algorithm/string.hpp>
7#include <boost/container/flat_set.hpp>
8#include <filesystem>
9#include <fstream>
manojkiraneda0b631ae2019-12-03 17:54:28 +053010#include <ibm/locks.hpp>
11#include <nlohmann/json.hpp>
Sunitha Harish97b0e432019-11-21 04:59:29 -060012#include <regex>
13#include <sdbusplus/message/types.hpp>
manojkiraneda0b631ae2019-12-03 17:54:28 +053014#include <utils/json_utils.hpp>
Sunitha Harish97b0e432019-11-21 04:59:29 -060015
Ratan Guptae46946a2020-05-11 13:22:59 +053016// Allow save area file size to 500KB
17#define MAX_SAVE_AREA_FILESIZE 500000
18
manojkiraneda0b631ae2019-12-03 17:54:28 +053019using SType = std::string;
20using SegmentFlags = std::vector<std::pair<std::string, uint32_t>>;
21using LockRequest = std::tuple<SType, SType, SType, uint64_t, SegmentFlags>;
22using LockRequests = std::vector<LockRequest>;
23using Rc = std::pair<bool, std::variant<uint32_t, LockRequest>>;
manojkiraneda402b5712019-12-13 17:07:09 +053024using RcGetLockList =
25 std::variant<std::string, std::vector<std::pair<uint32_t, LockRequests>>>;
26using ListOfSessionIds = std::vector<std::string>;
Ratan Gupta453fed02019-12-14 09:39:47 +053027namespace crow
28{
29namespace ibm_mc
30{
Sunitha Harish97b0e432019-11-21 04:59:29 -060031constexpr const char *methodNotAllowedMsg = "Method Not Allowed";
32constexpr const char *resourceNotFoundMsg = "Resource Not Found";
33constexpr const char *contentNotAcceptableMsg = "Content Not Acceptable";
34constexpr const char *internalServerError = "Internal Server Error";
35
36bool createSaveAreaPath(crow::Response &res)
37{
38 // The path /var/lib/obmc will be created by initrdscripts
39 // Create the directories for the save-area files, when we get
40 // first file upload request
41 std::error_code ec;
42 if (!std::filesystem::is_directory("/var/lib/obmc/bmc-console-mgmt", ec))
43 {
44 std::filesystem::create_directory("/var/lib/obmc/bmc-console-mgmt", ec);
45 }
46 if (ec)
47 {
48 res.result(boost::beast::http::status::internal_server_error);
49 res.jsonValue["Description"] = internalServerError;
50 BMCWEB_LOG_DEBUG
51 << "handleIbmPost: Failed to prepare save-area directory. ec : "
52 << ec;
53 return false;
54 }
55
56 if (!std::filesystem::is_directory(
57 "/var/lib/obmc/bmc-console-mgmt/save-area", ec))
58 {
59 std::filesystem::create_directory(
60 "/var/lib/obmc/bmc-console-mgmt/save-area", ec);
61 }
62 if (ec)
63 {
64 res.result(boost::beast::http::status::internal_server_error);
65 res.jsonValue["Description"] = internalServerError;
66 BMCWEB_LOG_DEBUG
67 << "handleIbmPost: Failed to prepare save-area directory. ec : "
68 << ec;
69 return false;
70 }
71 return true;
72}
73void handleFilePut(const crow::Request &req, crow::Response &res,
asmithakarun1c7b07c2019-09-09 03:42:59 -050074 const std::string &fileID)
Sunitha Harish97b0e432019-11-21 04:59:29 -060075{
76 // Check the content-type of the request
77 std::string_view contentType = req.getHeaderValue("content-type");
78 if (boost::starts_with(contentType, "multipart/form-data"))
79 {
80 BMCWEB_LOG_DEBUG
81 << "This is multipart/form-data. Invalid content for PUT";
82
83 res.result(boost::beast::http::status::not_acceptable);
84 res.jsonValue["Description"] = contentNotAcceptableMsg;
85 return;
86 }
87 else
88 {
89 BMCWEB_LOG_DEBUG << "Not a multipart/form-data. Continue..";
90 }
asmithakarun1c7b07c2019-09-09 03:42:59 -050091
92 BMCWEB_LOG_DEBUG
93 << "handleIbmPut: Request to create/update the save-area file";
94 if (!createSaveAreaPath(res))
Sunitha Harish97b0e432019-11-21 04:59:29 -060095 {
asmithakarun1c7b07c2019-09-09 03:42:59 -050096 res.result(boost::beast::http::status::not_found);
97 res.jsonValue["Description"] = resourceNotFoundMsg;
98 return;
99 }
100 // Create the file
101 std::ofstream file;
102 std::filesystem::path loc("/var/lib/obmc/bmc-console-mgmt/save-area");
103 loc /= fileID;
Sunitha Harish97b0e432019-11-21 04:59:29 -0600104
asmithakarun1c7b07c2019-09-09 03:42:59 -0500105 std::string data = std::move(req.body);
106 BMCWEB_LOG_DEBUG << "data capaticty : " << data.capacity();
107 if (data.capacity() > MAX_SAVE_AREA_FILESIZE)
108 {
109 res.result(boost::beast::http::status::bad_request);
110 res.jsonValue["Description"] =
Ratan Guptae46946a2020-05-11 13:22:59 +0530111 "File size exceeds maximum allowed size[500KB]";
asmithakarun1c7b07c2019-09-09 03:42:59 -0500112 return;
113 }
asmithakarun1c7b07c2019-09-09 03:42:59 -0500114 BMCWEB_LOG_DEBUG << "Creating file " << loc;
115 file.open(loc, std::ofstream::out);
116 if (file.fail())
117 {
118 BMCWEB_LOG_DEBUG << "Error while opening the file for writing";
119 res.result(boost::beast::http::status::internal_server_error);
120 res.jsonValue["Description"] = "Error while creating the file";
121 return;
Sunitha Harish97b0e432019-11-21 04:59:29 -0600122 }
123 else
124 {
asmithakarun1c7b07c2019-09-09 03:42:59 -0500125 file << data;
126 BMCWEB_LOG_DEBUG << "save-area file is created";
127 res.jsonValue["Description"] = "File Created";
128 }
Ratan Guptad3630cb2019-12-14 11:21:35 +0530129}
asmithakarun1c7b07c2019-09-09 03:42:59 -0500130
Ratan Guptad3630cb2019-12-14 11:21:35 +0530131void handleConfigFileList(crow::Response &res)
132{
133 std::vector<std::string> pathObjList;
134 std::filesystem::path loc("/var/lib/obmc/bmc-console-mgmt/save-area");
135 if (std::filesystem::exists(loc) && std::filesystem::is_directory(loc))
136 {
137 for (const auto &file : std::filesystem::directory_iterator(loc))
138 {
139 std::filesystem::path pathObj(file.path());
140 pathObjList.push_back("/ibm/v1/Host/ConfigFiles/" +
141 pathObj.filename().string());
142 }
143 }
144 res.jsonValue["@odata.type"] = "#FileCollection.v1_0_0.FileCollection";
145 res.jsonValue["@odata.id"] = "/ibm/v1/Host/ConfigFiles/";
146 res.jsonValue["Id"] = "ConfigFiles";
147 res.jsonValue["Name"] = "ConfigFiles";
148
149 res.jsonValue["Members"] = std::move(pathObjList);
150 res.jsonValue["Actions"]["#FileCollection.DeleteAll"] = {
151 {"target",
152 "/ibm/v1/Host/ConfigFiles/Actions/FileCollection.DeleteAll"}};
153 res.end();
154}
155
156void deleteConfigFiles(crow::Response &res)
157{
158 std::vector<std::string> pathObjList;
159 std::error_code ec;
160 std::filesystem::path loc("/var/lib/obmc/bmc-console-mgmt/save-area");
161 if (std::filesystem::exists(loc) && std::filesystem::is_directory(loc))
162 {
163 std::filesystem::remove_all(loc, ec);
164 if (ec)
165 {
166 res.result(boost::beast::http::status::internal_server_error);
167 res.jsonValue["Description"] = internalServerError;
168 BMCWEB_LOG_DEBUG << "deleteConfigFiles: Failed to delete the "
169 "config files directory. ec : "
170 << ec;
171 }
172 }
173 res.end();
asmithakarun1c7b07c2019-09-09 03:42:59 -0500174}
175
Ratan Gupta734a1c32019-12-14 11:53:48 +0530176void getLockServiceData(crow::Response &res)
177{
178 res.jsonValue["@odata.type"] = "#LockService.v1_0_0.LockService";
179 res.jsonValue["@odata.id"] = "/ibm/v1/HMC/LockService/";
180 res.jsonValue["Id"] = "LockService";
181 res.jsonValue["Name"] = "LockService";
182
183 res.jsonValue["Actions"]["#LockService.AcquireLock"] = {
184 {"target", "/ibm/v1/HMC/LockService/Actions/LockService.AcquireLock"}};
185 res.jsonValue["Actions"]["#LockService.ReleaseLock"] = {
186 {"target", "/ibm/v1/HMC/LockService/Actions/LockService.ReleaseLock"}};
187 res.jsonValue["Actions"]["#LockService.GetLockList"] = {
188 {"target", "/ibm/v1/HMC/LockService/Actions/LockService.GetLockList"}};
189 res.end();
190}
191
asmithakarun1c7b07c2019-09-09 03:42:59 -0500192void handleFileGet(crow::Response &res, const std::string &fileID)
193{
194 BMCWEB_LOG_DEBUG << "HandleGet on SaveArea files on path: " << fileID;
195 std::filesystem::path loc("/var/lib/obmc/bmc-console-mgmt/save-area/" +
196 fileID);
197 if (!std::filesystem::exists(loc))
198 {
199 BMCWEB_LOG_ERROR << loc << "Not found";
200 res.result(boost::beast::http::status::not_found);
201 res.jsonValue["Description"] = resourceNotFoundMsg;
202 return;
203 }
204
205 std::ifstream readfile(loc.string());
206 if (!readfile)
207 {
208 BMCWEB_LOG_ERROR << loc.string() << "Not found";
209 res.result(boost::beast::http::status::not_found);
210 res.jsonValue["Description"] = resourceNotFoundMsg;
211 return;
212 }
213
214 std::string contentDispositionParam =
215 "attachment; filename=\"" + fileID + "\"";
216 res.addHeader("Content-Disposition", contentDispositionParam);
217 std::string fileData;
218 fileData = {std::istreambuf_iterator<char>(readfile),
219 std::istreambuf_iterator<char>()};
220 res.jsonValue["Data"] = fileData;
221 return;
222}
223
224void handleFileDelete(crow::Response &res, const std::string &fileID)
225{
226 std::string filePath("/var/lib/obmc/bmc-console-mgmt/save-area/" + fileID);
227 BMCWEB_LOG_DEBUG << "Removing the file : " << filePath << "\n";
228
229 std::ifstream file_open(filePath.c_str());
230 if (static_cast<bool>(file_open))
231 if (remove(filePath.c_str()) == 0)
232 {
233 BMCWEB_LOG_DEBUG << "File removed!\n";
234 res.jsonValue["Description"] = "File Deleted";
235 }
236 else
237 {
238 BMCWEB_LOG_ERROR << "File not removed!\n";
239 res.result(boost::beast::http::status::internal_server_error);
240 res.jsonValue["Description"] = internalServerError;
241 }
242 else
243 {
244 BMCWEB_LOG_ERROR << "File not found!\n";
Sunitha Harish97b0e432019-11-21 04:59:29 -0600245 res.result(boost::beast::http::status::not_found);
246 res.jsonValue["Description"] = resourceNotFoundMsg;
247 }
248 return;
249}
250
251inline void handleFileUrl(const crow::Request &req, crow::Response &res,
asmithakarun1c7b07c2019-09-09 03:42:59 -0500252 const std::string &fileID)
Sunitha Harish97b0e432019-11-21 04:59:29 -0600253{
Sunitha Harish97b0e432019-11-21 04:59:29 -0600254 if (req.method() == "PUT"_method)
255 {
asmithakarun1c7b07c2019-09-09 03:42:59 -0500256 handleFilePut(req, res, fileID);
Sunitha Harish97b0e432019-11-21 04:59:29 -0600257 res.end();
258 return;
259 }
asmithakarun1c7b07c2019-09-09 03:42:59 -0500260 if (req.method() == "GET"_method)
261 {
262 handleFileGet(res, fileID);
263 res.end();
264 return;
265 }
266 if (req.method() == "DELETE"_method)
267 {
268 handleFileDelete(res, fileID);
269 res.end();
270 return;
271 }
Sunitha Harish97b0e432019-11-21 04:59:29 -0600272}
Ratan Gupta453fed02019-12-14 09:39:47 +0530273
manojkiraneda0b631ae2019-12-03 17:54:28 +0530274void handleAcquireLockAPI(const crow::Request &req, crow::Response &res,
275 std::vector<nlohmann::json> body)
276{
277 LockRequests lockRequestStructure;
278 for (auto &element : body)
279 {
280 std::string lockType;
281 uint64_t resourceId;
282
283 SegmentFlags segInfo;
284 std::vector<nlohmann::json> segmentFlags;
285
286 if (!redfish::json_util::readJson(element, res, "LockType", lockType,
287 "ResourceID", resourceId,
288 "SegmentFlags", segmentFlags))
289 {
290 BMCWEB_LOG_DEBUG << "Not a Valid JSON";
291 res.result(boost::beast::http::status::bad_request);
292 res.end();
293 return;
294 }
295 BMCWEB_LOG_DEBUG << lockType;
296 BMCWEB_LOG_DEBUG << resourceId;
297
298 BMCWEB_LOG_DEBUG << "Segment Flags are present";
299
300 for (auto &e : segmentFlags)
301 {
302 std::string lockFlags;
303 uint32_t segmentLength;
304
305 if (!redfish::json_util::readJson(e, res, "LockFlag", lockFlags,
306 "SegmentLength", segmentLength))
307 {
308 res.result(boost::beast::http::status::bad_request);
309 res.end();
310 return;
311 }
312
313 BMCWEB_LOG_DEBUG << "Lockflag : " << lockFlags;
314 BMCWEB_LOG_DEBUG << "SegmentLength : " << segmentLength;
315
316 segInfo.push_back(std::make_pair(lockFlags, segmentLength));
317 }
318 lockRequestStructure.push_back(make_tuple(
319 req.session->uniqueId, "hmc-id", lockType, resourceId, segInfo));
320 }
321
322 // print lock request into journal
323
324 for (uint32_t i = 0; i < lockRequestStructure.size(); i++)
325 {
326 BMCWEB_LOG_DEBUG << std::get<0>(lockRequestStructure[i]);
327 BMCWEB_LOG_DEBUG << std::get<1>(lockRequestStructure[i]);
328 BMCWEB_LOG_DEBUG << std::get<2>(lockRequestStructure[i]);
329 BMCWEB_LOG_DEBUG << std::get<3>(lockRequestStructure[i]);
330
331 for (const auto &p : std::get<4>(lockRequestStructure[i]))
332 {
333 BMCWEB_LOG_DEBUG << p.first << ", " << p.second;
334 }
335 }
336
337 const LockRequests &t = lockRequestStructure;
338
339 auto varAcquireLock = crow::ibm_mc_lock::lockObject.acquireLock(t);
340
341 if (varAcquireLock.first)
342 {
343 // Either validity failure of there is a conflict with itself
344
345 auto validityStatus =
346 std::get<std::pair<bool, int>>(varAcquireLock.second);
347
348 if ((!validityStatus.first) && (validityStatus.second == 0))
349 {
350 BMCWEB_LOG_DEBUG << "Not a Valid record";
351 BMCWEB_LOG_DEBUG << "Bad json in request";
352 res.result(boost::beast::http::status::bad_request);
353 res.end();
354 return;
355 }
356 if (validityStatus.first && (validityStatus.second == 1))
357 {
358 BMCWEB_LOG_DEBUG << "There is a conflict within itself";
359 res.result(boost::beast::http::status::bad_request);
360 res.end();
361 return;
362 }
363 }
364 else
365 {
366 auto conflictStatus =
367 std::get<crow::ibm_mc_lock::Rc>(varAcquireLock.second);
368 if (!conflictStatus.first)
369 {
370 BMCWEB_LOG_DEBUG << "There is no conflict with the locktable";
371 res.result(boost::beast::http::status::ok);
372
373 auto var = std::get<uint32_t>(conflictStatus.second);
374 nlohmann::json returnJson;
375 returnJson["id"] = var;
376 res.jsonValue["TransactionID"] = var;
377 res.end();
378 return;
379 }
380 else
381 {
382 BMCWEB_LOG_DEBUG << "There is a conflict with the lock table";
383 res.result(boost::beast::http::status::conflict);
384 auto var = std::get<std::pair<uint32_t, LockRequest>>(
385 conflictStatus.second);
386 nlohmann::json returnJson, segments;
387 nlohmann::json myarray = nlohmann::json::array();
388 returnJson["TransactionID"] = var.first;
389 returnJson["SessionID"] = std::get<0>(var.second);
390 returnJson["HMCID"] = std::get<1>(var.second);
391 returnJson["LockType"] = std::get<2>(var.second);
392 returnJson["ResourceID"] = std::get<3>(var.second);
393
394 for (uint32_t i = 0; i < std::get<4>(var.second).size(); i++)
395 {
396 segments["LockFlag"] = std::get<4>(var.second)[i].first;
397 segments["SegmentLength"] = std::get<4>(var.second)[i].second;
398 myarray.push_back(segments);
399 }
400
401 returnJson["SegmentFlags"] = myarray;
402
403 res.jsonValue["Record"] = returnJson;
404 res.end();
405 return;
406 }
407 }
408}
409
manojkiraneda3b6dea62019-12-13 17:05:36 +0530410void handleReleaseLockAPI(const crow::Request &req, crow::Response &res,
411 const std::vector<uint32_t> &listTransactionIds)
412{
413 BMCWEB_LOG_DEBUG << listTransactionIds.size();
414 BMCWEB_LOG_DEBUG << "Data is present";
415 for (uint32_t i = 0; i < listTransactionIds.size(); i++)
416 {
417 BMCWEB_LOG_DEBUG << listTransactionIds[i];
418 }
419
420 std::string clientId = "hmc-id";
421 std::string sessionId = req.session->uniqueId;
422
423 // validate the request ids
424
425 auto varReleaselock = crow::ibm_mc_lock::lockObject.releaseLock(
426 listTransactionIds, std::make_pair(clientId, sessionId));
427
428 if (!varReleaselock.first)
429 {
430 // validation Failed
431 res.result(boost::beast::http::status::bad_request);
432 res.end();
433 return;
434 }
435 else
436 {
437 auto statusRelease =
438 std::get<crow::ibm_mc_lock::RcRelaseLock>(varReleaselock.second);
439 if (statusRelease.first)
440 {
441 // The current hmc owns all the locks, so we already released
442 // them
443 res.result(boost::beast::http::status::ok);
444 res.end();
445 return;
446 }
447
448 else
449 {
450 // valid rid, but the current hmc does not own all the locks
451 BMCWEB_LOG_DEBUG << "Current HMC does not own all the locks";
452 res.result(boost::beast::http::status::unauthorized);
453
454 auto var = statusRelease.second;
455 nlohmann::json returnJson, segments;
456 nlohmann::json myArray = nlohmann::json::array();
457 returnJson["TransactionID"] = var.first;
458 returnJson["SessionID"] = std::get<0>(var.second);
459 returnJson["HMCID"] = std::get<1>(var.second);
460 returnJson["LockType"] = std::get<2>(var.second);
461 returnJson["ResourceID"] = std::get<3>(var.second);
462
463 for (uint32_t i = 0; i < std::get<4>(var.second).size(); i++)
464 {
465 segments["LockFlag"] = std::get<4>(var.second)[i].first;
466 segments["SegmentLength"] = std::get<4>(var.second)[i].second;
467 myArray.push_back(segments);
468 }
469
470 returnJson["SegmentFlags"] = myArray;
471 res.jsonValue["Record"] = returnJson;
472 res.end();
473 return;
474 }
475 }
476}
477
manojkiraneda402b5712019-12-13 17:07:09 +0530478void handleGetLockListAPI(const crow::Request &req, crow::Response &res,
479 const ListOfSessionIds &listSessionIds)
480{
481 BMCWEB_LOG_DEBUG << listSessionIds.size();
482
483 auto status = crow::ibm_mc_lock::lockObject.getLockList(listSessionIds);
484 auto var = std::get<std::vector<std::pair<uint32_t, LockRequests>>>(status);
485
486 nlohmann::json lockRecords = nlohmann::json::array();
487
488 for (const auto &transactionId : var)
489 {
490 for (const auto &lockRecord : transactionId.second)
491 {
492 nlohmann::json returnJson;
493
494 returnJson["TransactionID"] = transactionId.first;
495 returnJson["SessionID"] = std::get<0>(lockRecord);
496 returnJson["HMCID"] = std::get<1>(lockRecord);
497 returnJson["LockType"] = std::get<2>(lockRecord);
498 returnJson["ResourceID"] = std::get<3>(lockRecord);
499
500 nlohmann::json segments;
501 nlohmann::json segmentInfoArray = nlohmann::json::array();
502
503 for (const auto &segment : std::get<4>(lockRecord))
504 {
505 segments["LockFlag"] = segment.first;
506 segments["SegmentLength"] = segment.second;
507 segmentInfoArray.push_back(segments);
508 }
509
510 returnJson["SegmentFlags"] = segmentInfoArray;
511 lockRecords.push_back(returnJson);
512 }
513 }
514 res.result(boost::beast::http::status::ok);
515 res.jsonValue["Records"] = lockRecords;
516 res.end();
517}
518
Ratan Gupta453fed02019-12-14 09:39:47 +0530519template <typename... Middlewares> void requestRoutes(Crow<Middlewares...> &app)
520{
521
522 // allowed only for admin
523 BMCWEB_ROUTE(app, "/ibm/v1/")
524 .requires({"ConfigureComponents", "ConfigureManager"})
525 .methods("GET"_method)(
526 [](const crow::Request &req, crow::Response &res) {
527 res.jsonValue["@odata.type"] =
528 "#ibmServiceRoot.v1_0_0.ibmServiceRoot";
529 res.jsonValue["@odata.id"] = "/ibm/v1/";
530 res.jsonValue["Id"] = "IBM Rest RootService";
531 res.jsonValue["Name"] = "IBM Service Root";
532 res.jsonValue["ConfigFiles"] = {
533 {"@odata.id", "/ibm/v1/Host/ConfigFiles"}};
534 res.jsonValue["LockService"] = {
535 {"@odata.id", "/ibm/v1/HMC/LockService"}};
536 res.end();
537 });
Sunitha Harish97b0e432019-11-21 04:59:29 -0600538
Ratan Guptad3630cb2019-12-14 11:21:35 +0530539 BMCWEB_ROUTE(app, "/ibm/v1/Host/ConfigFiles")
540 .requires({"ConfigureComponents", "ConfigureManager"})
541 .methods("GET"_method)(
542 [](const crow::Request &req, crow::Response &res) {
543 handleConfigFileList(res);
544 });
545
546 BMCWEB_ROUTE(app,
547 "/ibm/v1/Host/ConfigFiles/Actions/FileCollection.DeleteAll")
548 .requires({"ConfigureComponents", "ConfigureManager"})
549 .methods("POST"_method)(
550 [](const crow::Request &req, crow::Response &res) {
551 deleteConfigFiles(res);
552 });
553
asmithakarun1c7b07c2019-09-09 03:42:59 -0500554 BMCWEB_ROUTE(app, "/ibm/v1/Host/ConfigFiles/<path>")
Sunitha Harish97b0e432019-11-21 04:59:29 -0600555 .requires({"ConfigureComponents", "ConfigureManager"})
asmithakarun1c7b07c2019-09-09 03:42:59 -0500556 .methods("PUT"_method, "GET"_method, "DELETE"_method)(
557 [](const crow::Request &req, crow::Response &res,
558 const std::string &path) { handleFileUrl(req, res, path); });
Ratan Gupta734a1c32019-12-14 11:53:48 +0530559
560 BMCWEB_ROUTE(app, "/ibm/v1/HMC/LockService")
561 .requires({"ConfigureComponents", "ConfigureManager"})
562 .methods("GET"_method)(
563 [](const crow::Request &req, crow::Response &res) {
564 getLockServiceData(res);
565 });
manojkiraneda0b631ae2019-12-03 17:54:28 +0530566
567 BMCWEB_ROUTE(app, "/ibm/v1/HMC/LockService/Actions/LockService.AcquireLock")
568 .requires({"ConfigureComponents", "ConfigureManager"})
569 .methods("POST"_method)(
570 [](const crow::Request &req, crow::Response &res) {
571 std::vector<nlohmann::json> body;
572
573 if (!redfish::json_util::readJson(req, res, "Request", body))
574 {
575 BMCWEB_LOG_DEBUG << "Not a Valid JSON";
576 res.result(boost::beast::http::status::bad_request);
577 res.end();
578 return;
579 }
580 handleAcquireLockAPI(req, res, body);
581 });
manojkiraneda3b6dea62019-12-13 17:05:36 +0530582
583 BMCWEB_ROUTE(app, "/ibm/v1/HMC/LockService/Actions/LockService.ReleaseLock")
584 .requires({"ConfigureComponents", "ConfigureManager"})
585 .methods("POST"_method)(
586 [](const crow::Request &req, crow::Response &res) {
587 std::vector<uint32_t> listTransactionIds;
588
589 if (!redfish::json_util::readJson(req, res, "TransactionIDs",
590 listTransactionIds))
591 {
592 res.result(boost::beast::http::status::bad_request);
593 res.end();
594 return;
595 }
596
597 handleReleaseLockAPI(req, res, listTransactionIds);
598 });
manojkiraneda402b5712019-12-13 17:07:09 +0530599 BMCWEB_ROUTE(app, "/ibm/v1/HMC/LockService/Actions/LockService.GetLockList")
600 .requires({"ConfigureComponents", "ConfigureManager"})
601 .methods("POST"_method)(
602 [](const crow::Request &req, crow::Response &res) {
603 ListOfSessionIds listSessionIds;
604
605 if (!redfish::json_util::readJson(req, res, "SessionIDs",
606 listSessionIds))
607 {
608 res.result(boost::beast::http::status::bad_request);
609 res.end();
610 return;
611 }
612
613 handleGetLockListAPI(req, res, listSessionIds);
614 });
Ratan Gupta453fed02019-12-14 09:39:47 +0530615}
616
617} // namespace ibm_mc
618} // namespace crow