2020-06-12 12:46:11 +02:00
|
|
|
import {Injectable} from '@angular/core';
|
|
|
|
import {ActivatedRouteSnapshot, CanActivate, CanLoad, Route, Router, RouterStateSnapshot} from '@angular/router';
|
|
|
|
import {Observable} from 'rxjs/Observable';
|
|
|
|
|
2020-10-30 12:33:51 +01:00
|
|
|
import {filter, map, mergeMap} from "rxjs/operators";
|
2020-06-12 12:46:11 +02:00
|
|
|
import {UserManagementService} from "../openaireLibrary/services/user-management.service";
|
|
|
|
import {LoginErrorCodes} from "../openaireLibrary/login/utils/guardHelper.class";
|
|
|
|
import {Session} from "../openaireLibrary/login/utils/helper.class";
|
2020-06-26 12:52:58 +02:00
|
|
|
import {properties} from "../../environments/environment";
|
2020-10-30 12:33:51 +01:00
|
|
|
import {StakeholderService} from "../openaireLibrary/monitor/services/stakeholder.service";
|
|
|
|
import {of} from "rxjs";
|
2020-06-12 12:46:11 +02:00
|
|
|
|
|
|
|
@Injectable()
|
2020-10-30 12:33:51 +01:00
|
|
|
export class AdminDashboardGuard implements CanActivate {
|
2020-06-12 12:46:11 +02:00
|
|
|
|
|
|
|
constructor(private router: Router,
|
2020-10-30 12:33:51 +01:00
|
|
|
private stakeholderService: StakeholderService,
|
2020-06-12 12:46:11 +02:00
|
|
|
private userManagementService: UserManagementService) {
|
|
|
|
}
|
|
|
|
|
2020-10-30 12:33:51 +01:00
|
|
|
check(path: string, alias: string): Observable<boolean> | boolean {
|
2020-06-12 12:46:11 +02:00
|
|
|
if (Session.isLoggedIn()) {
|
|
|
|
const obs = this.userManagementService.getUserInfo(false).pipe(map(user => {
|
2020-10-30 12:33:51 +01:00
|
|
|
if(user) {
|
|
|
|
return this.stakeholderService.getStakeholder(alias).pipe(map(stakeholder => {
|
|
|
|
if(stakeholder) {
|
2020-11-03 10:42:47 +01:00
|
|
|
return (Session.isPortalAdministrator(user) ||
|
|
|
|
Session.isCurator(stakeholder.type, user) || Session.isManager(stakeholder.type, stakeholder.alias, user));
|
2020-10-30 12:33:51 +01:00
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
} else {
|
|
|
|
return of(false);
|
|
|
|
}
|
|
|
|
}), mergeMap( authorized => {
|
|
|
|
return authorized;
|
2020-06-12 12:46:11 +02:00
|
|
|
}));
|
2020-10-30 12:33:51 +01:00
|
|
|
obs.pipe(filter(isManager => !isManager)).subscribe(() => {
|
2020-09-21 14:51:37 +02:00
|
|
|
this.router.navigate(['/user-info'], {queryParams: {'errorCode': LoginErrorCodes.NOT_ADMIN, 'redirectUrl':path}});
|
2020-06-12 12:46:11 +02:00
|
|
|
});
|
|
|
|
return obs;
|
|
|
|
} else {
|
2020-09-21 14:51:37 +02:00
|
|
|
this.router.navigate(['/user-info'], {queryParams: {'errorCode': LoginErrorCodes.NOT_LOGIN, 'redirectUrl':path}});
|
2020-06-12 12:46:11 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean> | boolean {
|
2020-10-30 12:33:51 +01:00
|
|
|
return this.check(state.url, route.params.stakeholder);
|
2020-06-12 12:46:11 +02:00
|
|
|
}
|
|
|
|
}
|