added svcapi ui and camunda code
[it/otf.git] / otf-frontend / client / src / app / shared / guard / admin.guard.ts
diff --git a/otf-frontend/client/src/app/shared/guard/admin.guard.ts b/otf-frontend/client/src/app/shared/guard/admin.guard.ts
new file mode 100644 (file)
index 0000000..12e2cc9
--- /dev/null
@@ -0,0 +1,48 @@
+/*  Copyright (c) 2019 AT&T Intellectual Property.                             #\r
+#                                                                              #\r
+#   Licensed under the Apache License, Version 2.0 (the "License");            #\r
+#   you may not use this file except in compliance with the License.           #\r
+#   You may obtain a copy of the License at                                    #\r
+#                                                                              #\r
+#       http://www.apache.org/licenses/LICENSE-2.0                             #\r
+#                                                                              #\r
+#   Unless required by applicable law or agreed to in writing, software        #\r
+#   distributed under the License is distributed on an "AS IS" BASIS,          #\r
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #\r
+#   See the License for the specific language governing permissions and        #\r
+#   limitations under the License.                                             #\r
+##############################################################################*/\r
+\r
+\r
+import { Injectable } from '@angular/core';\r
+import { Router, CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';\r
+import { HttpClient, HttpHandler, HttpHeaders } from '@angular/common/http';\r
+import { AppGlobals } from 'app/app.global';\r
+import { UserService } from '../services/user.service';\r
+import { CookieService } from 'ngx-cookie-service';\r
+\r
+@Injectable()\r
+export class AdminGuard implements CanActivate {\r
+\r
+    constructor(private router: Router, private http: HttpClient, private cookie: CookieService) { }\r
+\r
+    async canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {\r
+\r
+        if (this.cookie.get('access_token') && this.cookie.get('currentUser')) {\r
+            let currentUser = JSON.parse(this.cookie.get('currentUser'));\r
+            if(currentUser['permissions'].indexOf('admin') >= 0){\r
+                return true;\r
+            }\r
+            else{\r
+                this.router.navigate(['/dashboard'], { queryParams: { returnUrl: state.url }});\r
+                return false;\r
+            }\r
+        }\r
+        // not logged in so redirect to login page with the return url\r
+        this.router.navigate(['/dashboard'], { queryParams: { returnUrl: state.url }});\r
+        return false;\r
+\r
+\r
+\r
+    }\r
+}\r