1
|
import { Injectable } from '@angular/core';
|
2
|
import {Router, CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, CanLoad, Route} from '@angular/router';
|
3
|
import {Observable} from 'rxjs/Observable';
|
4
|
import {Session} from './utils/helper.class';
|
5
|
import {LoginErrorCodes} from './utils/guardHelper.class';
|
6
|
|
7
|
@Injectable()
|
8
|
export class ClaimsCuratorGuard implements CanActivate, CanLoad {
|
9
|
|
10
|
constructor(private router: Router) {}
|
11
|
|
12
|
check(path: string) : boolean{
|
13
|
//var user;
|
14
|
//var role = route.data['role']
|
15
|
let loggedIn = false;
|
16
|
let isAuthorized = false;
|
17
|
let errorCode = LoginErrorCodes.NOT_LOGIN;
|
18
|
|
19
|
if(Session.isLoggedIn()){
|
20
|
loggedIn = true;
|
21
|
if(Session.isClaimsCurator() || Session.isPortalAdministrator()){
|
22
|
isAuthorized = true;
|
23
|
}
|
24
|
else {
|
25
|
errorCode = LoginErrorCodes.NOT_ADMIN;
|
26
|
}
|
27
|
}
|
28
|
if(!loggedIn || !isAuthorized){
|
29
|
// this.guardHelper.redirect("/user-info",errorCode,state.url);
|
30
|
this.router.navigate(['/user-info'], {queryParams: {"errorCode": errorCode, "redirectUrl": path}});
|
31
|
}
|
32
|
return loggedIn && isAuthorized;
|
33
|
}
|
34
|
|
35
|
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | boolean {
|
36
|
return this.check(state.url);
|
37
|
}
|
38
|
|
39
|
canLoad(route: Route): Observable<boolean> | Promise<boolean> | boolean {
|
40
|
return this.check('/' + route.path);
|
41
|
}
|
42
|
}
|