Angular2: launching existing route guards - logout action

I use JWT to authenticate users. Some of the routes in my angular2 application are protected by CanActivate Guard, which will be redirected to the login page if the user is not logged in. Now I am implementing the exit button and want to redirect to the login page. I want to redirect only if the current route should not be visible to unregistered users (for example, the account page). If the user, for example, on the home page, I do not want to redirect to the login page.

It would be ideal if I could just check if the current route has security and call this guard, if one exists. It can be done?

Guard:

public canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
    if (this.loginService.getCurrentUserName()) {
        // logged in 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 }});
    return false;
}
+6
1

(, '/account/..', , .

public canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
    this.checkRouteNaviation(this.route.url);
}

public checkRouteNaviation(url) {
    if(url.includes('account') && !this.loginService.getCurrentUserName()) {
        // when url is of guard url and not logged in, redirect to login page with the return url
        this.router.navigate(['/login'], { queryParams: { returnUrl: state.url }});
        return false;
    }
    return true;
}

,

+2

Source: https://habr.com/ru/post/1015756/


All Articles