summaryrefslogtreecommitdiff
path: root/redfish-core/src/utils
diff options
context:
space:
mode:
authorKowalski, Kamil <kamil.kowalski@intel.com>2018-04-03 11:15:14 +0300
committerEd Tanous <ed.tanous@intel.com>2018-06-29 21:15:10 +0300
commit77dd8813e9a1f2baec63d959de15af39a8cd12d0 (patch)
tree0c64aedd324dae34203829ac323d8bc7a0806750 /redfish-core/src/utils
parentdaf36e2e50a6a9c72c94d97e5754a8aa19c9d95b (diff)
downloadbmcweb-77dd8813e9a1f2baec63d959de15af39a8cd12d0.tar.xz
Added JSON utilities to allow easy exception-less usage of nlohmann JSON.
These functions are not yet used, but will be required by at least two upcoming patchsets. This functionality has been cut out from Configuration patchset for easier merge without having to wait for that commit. Change-Id: Ibe5d5cefd874d4a2d896b42a2b7cfc17480f3c5a Signed-off-by: Kowalski, Kamil <kamil.kowalski@intel.com>
Diffstat (limited to 'redfish-core/src/utils')
-rw-r--r--redfish-core/src/utils/json_utils.cpp454
1 files changed, 454 insertions, 0 deletions
diff --git a/redfish-core/src/utils/json_utils.cpp b/redfish-core/src/utils/json_utils.cpp
new file mode 100644
index 0000000000..b4bdba6d35
--- /dev/null
+++ b/redfish-core/src/utils/json_utils.cpp
@@ -0,0 +1,454 @@
+/*
+// 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.
+*/
+#include "utils/json_utils.hpp"
+#include <error_messages.hpp>
+#include <crow/http_codes.h>
+
+namespace redfish {
+
+namespace json_util {
+
+Result getString(const char* fieldName, const nlohmann::json& json,
+ const std::string*& output) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ output = fieldIt->get_ptr<const std::string*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (output == nullptr) {
+ return Result::WRONG_TYPE;
+ }
+
+ return Result::SUCCESS;
+}
+
+Result getObject(const char* fieldName, const nlohmann::json& json,
+ nlohmann::json* output) {
+ // Verify input pointer
+ if (output == nullptr) {
+ return Result::NULL_POINTER;
+ }
+
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ // Verify type
+ if (!fieldIt->is_object()) {
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ *output = *fieldIt;
+
+ return Result::SUCCESS;
+}
+
+Result getArray(const char* fieldName, const nlohmann::json& json,
+ nlohmann::json* output) {
+ // Verify input pointer
+ if (output == nullptr) {
+ return Result::NULL_POINTER;
+ }
+
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ // Verify type
+ if (!fieldIt->is_array()) {
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ *output = *fieldIt;
+
+ return Result::SUCCESS;
+}
+
+Result getInt(const char* fieldName, const nlohmann::json& json,
+ int64_t& output) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ const int64_t* retVal = fieldIt->get_ptr<const int64_t*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getUnsigned(const char* fieldName, const nlohmann::json& json,
+ uint64_t& output) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ const uint64_t* retVal = fieldIt->get_ptr<const uint64_t*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getBool(const char* fieldName, const nlohmann::json& json,
+ bool& output) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ const bool* retVal = fieldIt->get_ptr<const bool*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getDouble(const char* fieldName, const nlohmann::json& json,
+ double& output) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ return Result::NOT_EXIST;
+ }
+
+ const double* retVal = fieldIt->get_ptr<const double*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getString(const char* fieldName, const nlohmann::json& json,
+ const std::string*& output, uint8_t msgCfgMap,
+ nlohmann::json& msgJson, const std::string&& fieldPath) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ output = fieldIt->get_ptr<const std::string*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (output == nullptr) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ return Result::SUCCESS;
+}
+
+Result getObject(const char* fieldName, const nlohmann::json& json,
+ nlohmann::json* output, uint8_t msgCfgMap,
+ nlohmann::json& msgJson, const std::string&& fieldPath) {
+ // Verify input pointer
+ if (output == nullptr) {
+ return Result::NULL_POINTER;
+ }
+
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ // Verify type
+ if (!fieldIt->is_object()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ *output = *fieldIt;
+
+ return Result::SUCCESS;
+}
+
+Result getArray(const char* fieldName, const nlohmann::json& json,
+ nlohmann::json* output, uint8_t msgCfgMap,
+ nlohmann::json& msgJson, const std::string&& fieldPath) {
+ // Verify input pointer
+ if (output == nullptr) {
+ return Result::NULL_POINTER;
+ }
+
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ // Verify type
+ if (!fieldIt->is_array()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ *output = *fieldIt;
+
+ return Result::SUCCESS;
+}
+
+Result getInt(const char* fieldName, const nlohmann::json& json,
+ int64_t& output, uint8_t msgCfgMap, nlohmann::json& msgJson,
+ const std::string&& fieldPath) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ const int64_t* retVal = fieldIt->get_ptr<const int64_t*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getUnsigned(const char* fieldName, const nlohmann::json& json,
+ uint64_t& output, uint8_t msgCfgMap, nlohmann::json& msgJson,
+ const std::string&& fieldPath) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ const uint64_t* retVal = fieldIt->get_ptr<const uint64_t*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getBool(const char* fieldName, const nlohmann::json& json, bool& output,
+ uint8_t msgCfgMap, nlohmann::json& msgJson,
+ const std::string&& fieldPath) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ const bool* retVal = fieldIt->get_ptr<const bool*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+Result getDouble(const char* fieldName, const nlohmann::json& json,
+ double& output, uint8_t msgCfgMap, nlohmann::json& msgJson,
+ const std::string&& fieldPath) {
+ // Find field
+ auto fieldIt = json.find(fieldName);
+
+ // Verify existence
+ if (fieldIt == json.end()) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::MISSING)) {
+ messages::addMessageToJson(msgJson, messages::propertyMissing(fieldName),
+ fieldPath);
+ }
+
+ return Result::NOT_EXIST;
+ }
+
+ const double* retVal = fieldIt->get_ptr<const double*>();
+
+ // Verify type - we know that it exists, so nullptr means wrong type
+ if (retVal == nullptr) {
+ if (msgCfgMap & static_cast<int>(MessageSetting::TYPE_ERROR)) {
+ messages::addMessageToJson(
+ msgJson, messages::propertyValueTypeError(fieldIt->dump(), fieldName),
+ fieldPath);
+ }
+
+ return Result::WRONG_TYPE;
+ }
+
+ // Extract value
+ output = *retVal;
+
+ return Result::SUCCESS;
+}
+
+bool processJsonFromRequest(crow::response& res, const crow::request& req,
+ nlohmann::json& reqJson) {
+ reqJson = nlohmann::json::parse(req.body, nullptr, false);
+
+ if (reqJson.is_discarded()) {
+ messages::addMessageToErrorJson(res.json_value, messages::malformedJSON());
+
+ res.code = static_cast<int>(HttpRespCode::BAD_REQUEST);
+ res.end();
+
+ return false;
+ }
+
+ return true;
+}
+
+} // namespace json_util
+
+} // namespace redfish