/*! * @license * Copyright 2019 Alfresco Software, Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { Router, CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, CanActivateChild } from '@angular/router'; import { Observable } from 'rxjs'; import { AuthenticationService } from './authentication.service'; import { AppConfigService, AppConfigValues } from '../app-config/app-config.service'; import { OauthConfigModel } from '../models/oauth-config.model'; import { MatDialog } from '@angular/material'; export abstract class AuthGuardBase implements CanActivate, CanActivateChild { abstract checkLogin( activeRoute: ActivatedRouteSnapshot, redirectUrl: string ): Observable | Promise | boolean; protected get withCredentials(): boolean { return this.appConfigService.get( 'auth.withCredentials', false ); } constructor( protected authenticationService: AuthenticationService, protected router: Router, protected appConfigService: AppConfigService, protected dialog: MatDialog ) {} canActivate( route: ActivatedRouteSnapshot, state: RouterStateSnapshot ): Observable | Promise | boolean { const checkLogin = this.checkLogin(route, state.url); if (!checkLogin) { this.dialog.closeAll(); } return checkLogin; } canActivateChild( route: ActivatedRouteSnapshot, state: RouterStateSnapshot ): Observable | Promise | boolean { return this.canActivate(route, state); } protected redirectToUrl(provider: string, url: string) { if (!this.isSilentLogin()) { this.authenticationService.setRedirect({ provider, url }); const pathToLogin = this.getLoginRoute(); const urlToRedirect = `/${pathToLogin}?redirectUrl=${url}`; this.dialog.closeAll(); this.router.navigateByUrl(urlToRedirect); } } protected getLoginRoute(): string { return ( this.appConfigService && this.appConfigService.get( AppConfigValues.LOGIN_ROUTE, 'login' ) ); } protected isOAuthWithoutSilentLogin(): boolean { const oauth = this.appConfigService.get( AppConfigValues.OAUTHCONFIG, null ); return ( this.authenticationService.isOauth() && !!oauth && !oauth.silentLogin ); } protected isSilentLogin(): boolean { const oauth = this.appConfigService.get( AppConfigValues.OAUTHCONFIG, null ); return this.authenticationService.isOauth() && oauth && oauth.silentLogin; } }