Service Root
Change-Id: Ibf9d463802d77014852a92ecfcb8096324f3670f
Signed-off-by: Borawski.Lukasz <lukasz.borawski@intel.com>
diff --git a/redfish-core/include/node.hpp b/redfish-core/include/node.hpp
index 46b37d9..70b85222 100644
--- a/redfish-core/include/node.hpp
+++ b/redfish-core/include/node.hpp
@@ -15,9 +15,9 @@
*/
#pragma once
-#include "crow.h"
#include "privileges.hpp"
#include "token_authorization_middleware.hpp"
+#include "crow.h"
namespace redfish {
@@ -31,7 +31,6 @@
Node(CrowApp& app, PrivilegeProvider& provider, std::string odataType,
std::string odataId, Params... params)
: odataType(odataType), odataId(odataId) {
-
// privileges for the node as defined in the privileges_registry.json
entityPrivileges = provider.getPrivileges(odataId, odataType);
@@ -111,5 +110,24 @@
EntityPrivileges entityPrivileges;
};
+template <typename CrowApp>
+void getRedfishSubRoutes(CrowApp& app, const std::string& url,
+ nlohmann::json& j) {
+ std::vector<const std::string*> routes = app.get_routes(url);
+
+ for (auto route : routes) {
+ auto redfishSubRoute =
+ route->substr(url.size(), route->size() - url.size() - 1);
+
+ // Exclude: - exact matches,
+ // - metadata urls starting with "$",
+ // - urls at the same level
+ if (!redfishSubRoute.empty() && redfishSubRoute[0] != '$' &&
+ redfishSubRoute.find('/') == std::string::npos) {
+ j[redfishSubRoute] = nlohmann::json{{"@odata.id", *route}};
+ }
+ }
+}
+
} // namespace redfish
diff --git a/redfish-core/include/privileges.hpp b/redfish-core/include/privileges.hpp
index 43c48c2..290c0eb 100644
--- a/redfish-core/include/privileges.hpp
+++ b/redfish-core/include/privileges.hpp
@@ -54,8 +54,8 @@
// load privilege_registry.json to memory
}
- EntityPrivileges getPrivileges(const std::string &entity_url,
- const std::string &entity_type) const {
+ EntityPrivileges getPrivileges(const std::string& entity_url,
+ const std::string& entity_type) const {
// return an entity privilege object based on the privilege_registry.json,
// currently returning default constructed object
return EntityPrivileges();
diff --git a/redfish-core/include/redfish.hpp b/redfish-core/include/redfish.hpp
new file mode 100644
index 0000000..c4b765c
--- /dev/null
+++ b/redfish-core/include/redfish.hpp
@@ -0,0 +1,43 @@
+/*
+// 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 "../lib/service_root.hpp"
+
+namespace redfish {
+/*
+ * @brief Top level class installing and providing Redfish services
+ */
+class RedfishService {
+ public:
+ /*
+ * @brief Redfish service constructor
+ *
+ * Loads Redfish configuration and installs schema resources
+ *
+ * @param[in] app Crow app on which Redfish will initialize
+ */
+ template <typename CrowApp>
+ RedfishService(CrowApp& app) {
+ auto privilegeProvider = PrivilegeProvider();
+ serviceRootPtr = std::make_unique<ServiceRoot>(app, privilegeProvider);
+ }
+
+ private:
+ std::unique_ptr<ServiceRoot> serviceRootPtr;
+};
+
+} // namespace redfish