2020-02-03 16:53:25 +01:00
|
|
|
import { Injectable } from '@angular/core';
|
|
|
|
import { ActivatedRouteSnapshot, CanActivate, CanLoad, Route, Router, RouterStateSnapshot } from '@angular/router';
|
|
|
|
import { AuthService } from './services/auth/auth.service';
|
|
|
|
import { AppRole } from './common/enum/app-role';
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class AdminAuthGuard implements CanActivate, CanLoad {
|
|
|
|
constructor(private auth: AuthService, private router: Router) {
|
|
|
|
}
|
|
|
|
|
|
|
|
isAdmin(): boolean {
|
2023-10-11 16:53:12 +02:00
|
|
|
if (!this.auth.currentAccountIsAuthenticated()) { return false; }
|
|
|
|
return this.auth.hasRole(AppRole.Admin);
|
2020-02-03 16:53:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
|
|
|
|
const url: string = state.url;
|
|
|
|
if (!this.isAdmin()) {
|
|
|
|
this.router.navigate(['/unauthorized'], { queryParams: { returnUrl: url } });
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
canLoad(route: Route): boolean {
|
|
|
|
const url = `/${route.path}`;
|
|
|
|
if (!this.isAdmin()) {
|
|
|
|
this.router.navigate(['/unauthorized'], { queryParams: { returnUrl: url } });
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|