Before every request I want to be sure that there is a user profile available. I use a canActivateChild guard to do this.
According to the documentation of angular2 it is possible to return an observable: https://angular.io/api/router/CanActivateChild
app.routes.ts
export const routes: Routes = [
  {
    path: '',
    canActivateChild: [ProfileGuard],
    children: [
      {
        path: 'home',
        component: HomeComponent,
        canActivate: [AuthGuard]
      },
      {
        path: 'login',
        component: LoginComponent,
        canActivate: [GuestGuard]
      },
 }
];
The canActivatedChild is executed before the child route canActivate
profile.guard.ts:
export class ProfileGuard implements CanActivateChild {
  constructor(private profileService: ProfileService, private snackbar: MdSnackBar) { }
  canActivateChild(childRoute: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean | Observable<boolean>  {
    if (this.profileService.user == null && localStorage.getItem('__token') != null) {
      return this.profileService.loadProfile().map((user) => {
        console.log('profile loaded');
        this.profileService.user = <UserModel>user.data;
        return true;
      });
    }
    return true;
  }
}
Load profile function:
  public loadProfile(): Observable<any> {
    console.log('load');
    return this.http.get('/profile').map(res => res.json());
  }
When I navigate through the menu (<a> with routeLink) the console.log('profile loaded') works. But if I reload the page with f5 or through the browser, it never gets there..
The console.log('load') is always executed.
EDIT:
If I in canActivateChild return:
return Observable.of(true).map(() => {
  console.log('Test');
  return true;
});
It works fine... I get the console.log('test')
 
                        
I was running on a RC of
@angular/router. After i updated this it worked like expected.