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