mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-10-22 15:11:57 +00:00
* refator login page * refator login page * remove obsolete classes and move what is needed in the test pck * fix const * revert modify * remove duplicate browser property * fix build * fix * fix * fix lint * move drop action in testing remove not necessary space js-api centralize content * first refactor use js-api * fix protractor * refactor test config * simplify properties fix namings * ps cloud simplify remove unused js files * id fix * fix search test simplify environment var step 1 * fix lint * first user iteration fix * fix model * unify use of apiService * first step automatic user creation Identity * refactor creation user content-services * refactor creation user search * refactor creation user core * process service refactoring 1 * process service refactoring 1 * process service refactoring 2 * fix process * appconfig * fix process util * fix gallery * fix "this" reference issues * fix incorrect import paths * fix core * some fixes * allign * fix some test remove structure folder and move in actions * fixes * move folders in the right place * fix * fix rebase * solve build issue * fix e2e * change init aae * order api and some fixes * fix possible not valid password * fix some ps test * replace host port also in objects * Update app-config.service.ts * fix process * fix process test * process service cloud fix * fiexs * modify init script * fix two test * remove unused property * host issue * not use npx * fix ps cloud test Co-authored-by: Denys Vuika <denys.vuika@gmail.com>
187 lines
5.8 KiB
TypeScript
187 lines
5.8 KiB
TypeScript
/*!
|
|
* @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 { HttpClient } from '@angular/common/http';
|
|
import { Injectable } from '@angular/core';
|
|
import { ObjectUtils } from '../utils/object-utils';
|
|
import { Observable, Subject } from 'rxjs';
|
|
import { map, distinctUntilChanged } from 'rxjs/operators';
|
|
|
|
/* spellchecker: disable */
|
|
export enum AppConfigValues {
|
|
APP_CONFIG_LANGUAGES_KEY = 'languages',
|
|
PROVIDERS = 'providers',
|
|
OAUTHCONFIG = 'oauth2',
|
|
ECMHOST = 'ecmHost',
|
|
BASESHAREURL = 'baseShareUrl',
|
|
BPMHOST = 'bpmHost',
|
|
IDENTITY_HOST = 'identityHost',
|
|
AUTHTYPE = 'authType',
|
|
CONTEXTROOTECM = 'contextRootEcm',
|
|
CONTEXTROOTBPM = 'contextRootBpm',
|
|
ALFRESCO_REPOSITORY_NAME = 'alfrescoRepositoryName',
|
|
LOG_LEVEL = 'logLevel',
|
|
LOGIN_ROUTE = 'loginRoute',
|
|
DISABLECSRF = 'disableCSRF',
|
|
AUTH_WITH_CREDENTIALS = 'auth.withCredentials',
|
|
APPLICATION = 'application',
|
|
STORAGE_PREFIX = 'application.storagePrefix',
|
|
NOTIFY_DURATION = 'notificationDefaultDuration'
|
|
}
|
|
|
|
export enum Status {
|
|
INIT = 'init',
|
|
LOADING = 'loading',
|
|
LOADED = 'loaded'
|
|
}
|
|
|
|
/* spellchecker: enable */
|
|
|
|
@Injectable({
|
|
providedIn: 'root'
|
|
})
|
|
export class AppConfigService {
|
|
|
|
config: any = {
|
|
application: {
|
|
name: 'Alfresco ADF Application'
|
|
},
|
|
ecmHost: 'http://{hostname}{:port}/ecm',
|
|
bpmHost: 'http://{hostname}{:port}/bpm',
|
|
logLevel: 'silent'
|
|
};
|
|
|
|
status: Status = Status.INIT;
|
|
protected onLoadSubject: Subject<any>;
|
|
onLoad: Observable<any>;
|
|
|
|
constructor(private http: HttpClient) {
|
|
this.onLoadSubject = new Subject();
|
|
this.onLoad = this.onLoadSubject.asObservable();
|
|
}
|
|
|
|
/**
|
|
* Requests notification of a property value when it is loaded.
|
|
* @param property The desired property value
|
|
* @returns Property value, when loaded
|
|
*/
|
|
select(property: string): Observable<any> {
|
|
return this.onLoadSubject
|
|
.pipe(
|
|
map((config) => config[property]),
|
|
distinctUntilChanged()
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Gets the value of a named property.
|
|
* @param key Name of the property
|
|
* @param defaultValue Value to return if the key is not found
|
|
* @returns Value of the property
|
|
*/
|
|
get<T>(key: string, defaultValue?: T): T {
|
|
let result: any = ObjectUtils.getValue(this.config, key);
|
|
if (typeof result === 'string') {
|
|
const keywords = new Map<string, string>();
|
|
keywords.set('hostname', this.getLocationHostname());
|
|
keywords.set(':port', this.getLocationPort(':'));
|
|
keywords.set('port', this.getLocationPort());
|
|
keywords.set('protocol', this.getLocationProtocol());
|
|
result = this.formatString(result, keywords);
|
|
}
|
|
|
|
if (typeof result === 'object') {
|
|
result = JSON.parse(JSON.stringify(result).replace('{hostname}', this.getLocationHostname()));
|
|
result = JSON.parse(JSON.stringify(result).replace('{:port}', this.getLocationPort(':')));
|
|
result = JSON.parse(JSON.stringify(result).replace('{protocol}', this.getLocationProtocol()));
|
|
}
|
|
|
|
if (result === undefined) {
|
|
return defaultValue;
|
|
}
|
|
|
|
return <T> result;
|
|
}
|
|
|
|
/**
|
|
* Gets the location.protocol value.
|
|
* @returns The location.protocol string
|
|
*/
|
|
getLocationProtocol(): string {
|
|
return location.protocol;
|
|
}
|
|
|
|
/**
|
|
* Gets the location.hostname property.
|
|
* @returns Value of the property
|
|
*/
|
|
getLocationHostname(): string {
|
|
return location.hostname;
|
|
}
|
|
|
|
/**
|
|
* Gets the location.port property.
|
|
* @param prefix Text added before port value
|
|
* @returns Port with prefix
|
|
*/
|
|
getLocationPort(prefix: string = ''): string {
|
|
return location.port ? prefix + location.port : '';
|
|
}
|
|
|
|
/**
|
|
* Loads the config file.
|
|
* @returns Notification when loading is complete
|
|
*/
|
|
load(): Promise<any> {
|
|
return new Promise(async (resolve) => {
|
|
const configUrl = `app.config.json?v=${Date.now()}`;
|
|
|
|
if (this.status === Status.INIT) {
|
|
this.status = Status.LOADING;
|
|
await this.http.get(configUrl).subscribe(
|
|
(data: any) => {
|
|
this.status = Status.LOADED;
|
|
this.config = Object.assign({}, this.config, data || {});
|
|
this.onLoadSubject.next(this.config);
|
|
resolve(this.config);
|
|
},
|
|
() => {
|
|
resolve(this.config);
|
|
}
|
|
);
|
|
} else if (this.status === Status.LOADED) {
|
|
resolve(this.config);
|
|
} else if (this.status === Status.LOADING) {
|
|
this.onLoad.subscribe(() => {
|
|
resolve(this.config);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
private formatString(str: string, keywords: Map<string, string>): string {
|
|
let result = str;
|
|
|
|
keywords.forEach((value, key) => {
|
|
const expr = new RegExp('{' + key + '}', 'gm');
|
|
result = result.replace(expr, value);
|
|
});
|
|
|
|
return result;
|
|
}
|
|
}
|