opt-cc/static/src/app/login/login.guard.ts

87 lines
2.5 KiB
TypeScript
Raw Normal View History

2017-07-14 23:33:17 +02:00
import {Injectable} from '@angular/core';
2017-09-03 12:49:59 +02:00
import {ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot} from '@angular/router';
2017-05-10 11:04:06 +02:00
@Injectable()
2017-06-08 16:58:28 +02:00
export class LoginGuardSQL implements CanActivate {
2017-05-10 11:04:06 +02:00
2017-07-14 23:33:17 +02:00
constructor(private router: Router) {
}
2017-05-10 11:04:06 +02:00
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
if (localStorage.getItem('currentUser')) {
2017-06-08 16:58:28 +02:00
let currentUser = JSON.parse(localStorage.getItem('currentUser'));
if (currentUser.permission === 1) {
// logged and correct permission so return true
return true;
}
}
// not logged in so redirect to login page with the return url
2017-07-14 23:33:17 +02:00
this.router.navigate(['/login'], {queryParams: {returnUrl: state.url}});
2017-06-08 16:58:28 +02:00
return false;
}
}
@Injectable()
export class LoginGuardHL implements CanActivate {
2017-07-14 23:33:17 +02:00
constructor(private router: Router) {
}
2017-06-08 16:58:28 +02:00
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
if (localStorage.getItem('currentUser')) {
let currentUser = JSON.parse(localStorage.getItem('currentUser'));
if (currentUser.permission >= 2) {
// logged and correct permission so return true
return true;
}
}
// not logged in so redirect to login page with the return url
2017-07-14 23:33:17 +02:00
this.router.navigate(['/login'], {queryParams: {returnUrl: state.url}});
return false;
}
}
@Injectable()
export class LoginGuardMT implements CanActivate {
constructor(private router: Router) {
}
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
if (localStorage.getItem('currentUser')) {
let currentUser = JSON.parse(localStorage.getItem('currentUser'));
if (currentUser.permission >= 3) {
// logged and correct permission so return true
return true;
}
}
// not logged in so redirect to login page with the return url
this.router.navigate(['/login'], {queryParams: {returnUrl: state.url}});
2017-06-08 16:58:28 +02:00
return false;
}
}
@Injectable()
export class LoginGuardAdmin implements CanActivate {
2017-07-14 23:33:17 +02:00
constructor(private router: Router) {
}
2017-06-08 16:58:28 +02:00
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
if (localStorage.getItem('currentUser')) {
let currentUser = JSON.parse(localStorage.getItem('currentUser'));
if (currentUser.permission === 4) {
// logged and correct permission so return true
return true;
}
2017-05-10 11:04:06 +02:00
}
// not logged in so redirect to login page with the return url
2017-07-14 23:33:17 +02:00
this.router.navigate(['/login'], {queryParams: {returnUrl: state.url}});
2017-05-10 11:04:06 +02:00
return false;
}
}