Project

General

Profile

1
import {Injectable} from '@angular/core';
2
import {
3
  ActivatedRouteSnapshot,
4
  CanActivate,
5
  CanActivateChild,
6
  Router,
7
  RouterStateSnapshot,
8
  UrlTree
9
} from '@angular/router';
10
import {map, take, tap} from "rxjs/operators";
11
import {UserManagementService} from "../openaireLibrary/services/user-management.service";
12
import {LoginErrorCodes} from "../openaireLibrary/login/utils/guardHelper.class";
13
import {Session} from "../openaireLibrary/login/utils/helper.class";
14
import {StakeholderService} from "../openaireLibrary/monitor/services/stakeholder.service";
15
import {Observable, zip} from "rxjs";
16

    
17

    
18
@Injectable()
19
export class AdminDashboardGuard implements CanActivate, CanActivateChild {
20

    
21
  constructor(private router: Router,
22
              private stakeholderService: StakeholderService,
23
              private userManagementService: UserManagementService) {
24
  }
25

    
26
  check(path: string, alias: string): Observable<boolean> | boolean {
27
    if (Session.isLoggedIn()) {
28
      return zip(
29
        this.userManagementService.getUserInfo(false)
30
        ,this.stakeholderService.getStakeholder(alias)
31
      ).pipe(take(1),map(res =>{
32
        return res[0] && res[1] && (Session.isPortalAdministrator(res[0]) ||
33
          Session.isCurator(res[1].type, res[0]) || Session.isManager(res[1].type, res[1].alias, res[0]));
34
      }),tap(authorized => {
35
        if(!authorized){
36
          this.router.navigate(['/user-info'], {queryParams: {'errorCode': LoginErrorCodes.NOT_ADMIN, 'redirectUrl':path}});
37
        }
38
      }));
39

    
40
    } else {
41
      this.router.navigate(['/user-info'], {queryParams: {'errorCode': LoginErrorCodes.NOT_LOGIN, 'redirectUrl':path}});
42
      return false;
43
    }
44
  }
45

    
46
  canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree {
47
    return this.check(state.url, route.params.stakeholder);
48
  }
49
  
50
  canActivateChild(childRoute: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree {
51
    return this.check(state.url, childRoute.params.stakeholder);
52
  }
53
}
(1-1/2)