Add Redfish into the web-ui

Currently only GET is supported, but to add PATCH
in the future for redfish, support should be moved from
being hosted directly by bmcweb into the webui.

Tested-by:
Navigated to http://localhost:8080/#/redfish/v1/ with
bmc attached and was able to view all of redfish. Also
tested on platform.

Change-Id: I1dc3936b6b48835a1f69698fcb4fd6fcdb6d91ac
Signed-off-by: James Feist <james.feist@linux.intel.com>
diff --git a/app/redfish/controllers/redfish-controller.html b/app/redfish/controllers/redfish-controller.html
new file mode 100644
index 0000000..eff1f8a
--- /dev/null
+++ b/app/redfish/controllers/redfish-controller.html
@@ -0,0 +1,47 @@
+<loader loading="loading"></loader>
+<div id="redfish">
+	<div class="row column">
+		<div style="max-width: 400px;margin:0">
+			<img src="../../assets/images/DMTF_Redfish_logo_2017.svg">
+		</div>
+	</div>
+	<div class="row column">
+		{
+		<ul style="list-style: none;">
+			<li ng-repeat="(key, value) in redfishData" ng-include="'recurse'"> </li>
+		</ul>
+		}
+	</div>
+</div>
+<script type="text/ng-template" id="recurse">
+"<b>{{key}}</b>":
+<span ng-if="isObject(value) && !isArray(value)">
+{
+	<ul style="list-style: none;">
+		<li ng-repeat="(key, value) in value" ng-include="'recurse'"> </li>
+	</ul>
+},</br>
+</span>
+
+<span ng-if="isArray(value)">
+[
+	<div ng-repeat="val in value" style="margin-left: 2em;">
+		<span ng-if="isObject(val) && !isArray(val)">
+			{
+			<ul style="list-style: none;">
+				<li ng-repeat="(key, value) in val" ng-include="'recurse'"> </li>
+			</ul>
+			},</br>
+		</span>
+		<span ng-if="!isObject(val) && !isArray(val)">
+		{{val}}
+		</span>
+	</div>
+]
+</span>
+
+<span ng-if="!isObject(value) && !isArray(value)">
+<a ng-if="key.indexOf('@odata.id') != -1" ng-href="#{{value}}">"{{value}}"</a>
+<span ng-if="key.indexOf('@odata.id') == -1" ng-href="#{{value}}">{{value | json}}</span>,
+</span>
+</script>
diff --git a/app/redfish/controllers/redfish-controller.js b/app/redfish/controllers/redfish-controller.js
new file mode 100644
index 0000000..dcfa6d7
--- /dev/null
+++ b/app/redfish/controllers/redfish-controller.js
@@ -0,0 +1,39 @@
+/**
+ * Controller for Redfish
+ *
+ * @module app/redfish
+ * @exports redfishController
+ * @name redfishController
+ * @version 0.1.0
+ */
+
+window.angular && (function(angular) {
+  'use strict';
+
+  angular.module('app.redfish').controller('redfishController', [
+    '$scope', '$http', 'dataService', '$routeParams',
+    function($scope, $http, DataService, $routeParams) {
+      $scope.redfishData = {};
+      $scope.isObject = angular.isObject;
+      $scope.isArray = angular.isArray;
+      $scope.loading = true;
+      $http({
+        method: 'GET',
+        url: DataService.getHost() + '/redfish/' + $routeParams.path,
+        withCredentials: true
+      })
+          .then(
+              function(response) {
+                $scope.redfishData = response.data;
+              },
+              function(error) {
+                $scope.display_error = true;
+                console.log(error);
+              })
+          .finally(function() {
+            $scope.loading = false;
+          });
+    }
+
+  ]);
+})(angular);
diff --git a/app/redfish/index.js b/app/redfish/index.js
new file mode 100644
index 0000000..61eb762
--- /dev/null
+++ b/app/redfish/index.js
@@ -0,0 +1,24 @@
+/**
+ * A module for redfish
+ *
+ * @module app/redfish/index
+ * @exports app/redfish/index
+ */
+
+window.angular && (function(angular) {
+  'use strict';
+
+  angular
+      .module('app.redfish', ['ngRoute', 'app.redfish'])
+      // Route configuration
+      .config([
+        '$routeProvider',
+        function($routeProvider) {
+          $routeProvider.when('/redfish/:path*/', {
+            'template': require('./controllers/redfish-controller.html'),
+            'controller': 'redfishController',
+            authenticated: true
+          });
+        }
+      ]);
+})(window.angular);