mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-05-12 17:04:46 +00:00
* shared project scaffold * rules package * move evaluators to shared lib * add rxjs peer dependency * use dedicated material namespaces * create store package, move actions * move selectors to shared library * move generic effects to shared lib * move routing extensions * minor code reorg * fix unit tests * move content-api service * move permission service * update tests * update plint config * move page layout * css variables * use dedicated css property * move generic error component to shared lib * fix test
65 lines
2.2 KiB
TypeScript
65 lines
2.2 KiB
TypeScript
/*!
|
|
* @license
|
|
* Alfresco Example Content Application
|
|
*
|
|
* Copyright (C) 2005 - 2019 Alfresco Software Limited
|
|
*
|
|
* This file is part of the Alfresco Example Content Application.
|
|
* If the software was purchased under a paid Alfresco license, the terms of
|
|
* the paid license agreement will prevail. Otherwise, the software is
|
|
* provided under the following open source license terms:
|
|
*
|
|
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { Injectable, Inject } from '@angular/core';
|
|
import { AuthenticationService, AppConfigService } from '@alfresco/adf-core';
|
|
import { Observable, BehaviorSubject } from 'rxjs';
|
|
import { RouteReuseStrategy } from '@angular/router';
|
|
import { AppRouteReuseStrategy } from '../routing/app.routes.strategy';
|
|
|
|
@Injectable({
|
|
providedIn: 'root'
|
|
})
|
|
export class AppService {
|
|
private ready: BehaviorSubject<boolean>;
|
|
ready$: Observable<boolean>;
|
|
|
|
/**
|
|
* Whether `withCredentials` mode is enabled.
|
|
* Usually means that `Kerberos` mode is used.
|
|
*/
|
|
get withCredentials(): boolean {
|
|
return this.config.get<boolean>('auth.withCredentials', false);
|
|
}
|
|
|
|
constructor(
|
|
auth: AuthenticationService,
|
|
private config: AppConfigService,
|
|
@Inject(RouteReuseStrategy) routeStrategy: AppRouteReuseStrategy
|
|
) {
|
|
this.ready = new BehaviorSubject(auth.isLoggedIn() || this.withCredentials);
|
|
this.ready$ = this.ready.asObservable();
|
|
|
|
auth.onLogin.subscribe(() => {
|
|
routeStrategy.resetCache();
|
|
this.ready.next(true);
|
|
});
|
|
|
|
auth.onLogout.subscribe(() => {
|
|
routeStrategy.resetCache();
|
|
});
|
|
}
|
|
}
|