I have an auth class set up like this:
export class AuthService {
user = new Subject<string>();
login(name: string) {
this.user.next(name);
}
}
I have an auth guard set up to check to see if my user subject has a value like this:
export class AuthGuard implements CanActivate {
constructor(private authService: AuthService, private router: Router) { }
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
return this.authService.user
.pipe(
map(user => {
const isAuth = !!user;
if (isAuth) {
return true;
}
return this.router.createUrlTree(['/login']);
})
);
}
}
I put print statements in the return and they never get called. The page never loads and it never re-directs either. If I just return true or false it works but by returning my authService.user nothing seems to happen.