[Library | Trunk]: Get properties from enviroment

git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-services-library/trunk/ng-openaire-library/src/app@58888 d315682c-612b-4755-9ff5-7f18f6832af3
This commit is contained in:
k.triantafyllou 2020-06-11 16:13:47 +00:00
parent 7a42282e45
commit 76af144f41
1 changed files with 3 additions and 51 deletions

View File

@ -1,4 +1,4 @@
import {Inject, Injectable, Optional, PLATFORM_ID} from '@angular/core'; import {Inject, Injectable, Optional} from '@angular/core';
import {HttpClient} from "@angular/common/http"; import {HttpClient} from "@angular/common/http";
import {BehaviorSubject, of} from 'rxjs'; import {BehaviorSubject, of} from 'rxjs';
@ -6,11 +6,8 @@ import {Request} from 'express';
import {REQUEST} from '@nguniversal/express-engine/tokens'; import {REQUEST} from '@nguniversal/express-engine/tokens';
import {EnvProperties} from './env-properties'; import {EnvProperties} from './env-properties';
import {map} from "rxjs/operators";
import {properties} from "../../../../environments/environment"; import {properties} from "../../../../environments/environment";
//export const REQUEST_TOKEN = new InjectionToken<Request>('request');
@Injectable() @Injectable()
export class EnvironmentSpecificService { export class EnvironmentSpecificService {
@ -24,63 +21,21 @@ export class EnvironmentSpecificService {
} }
public loadEnvironment() { public loadEnvironment() {
// Only want to do this once - if root page is revisited, it calls this again.
if (this.envSpecific === null || this.envSpecific === undefined) {
var domain = this.getDomain();
var location = this.getFullUrl();
// console.log('loadEnvironment: Loading '+ location);
return this.http.get<EnvProperties>(location)
.pipe(map((data) => {
var properties:EnvProperties=data;//.json();
properties.domain = domain;
this.envSpecific = properties;
return properties;
}))
.toPromise<EnvProperties>();
}
// console.log('loadEnvironment: already loaded ');
return Promise.resolve(this.envSpecific); return Promise.resolve(this.envSpecific);
} }
public subscribeEnvironment() { public subscribeEnvironment() {
// Only want to do this once - if root page is revisited, it calls this again. // Only want to do this once - if root page is revisited, it calls this again.
if (this.envSpecific === null || this.envSpecific === undefined) { if (this.envSpecific === null || this.envSpecific === undefined) {
var domain = this.getDomain(); this.envSpecific = properties;
var location = this.getFullUrl();
// console.log('subscribeEnvironment: Loading '+ location);
return this.http.get<EnvProperties>(location)
.pipe(map((data) => {
var properties:EnvProperties=data;//.json();
properties.domain = domain;
this.envSpecific = properties;
return properties;
}))
} }
// console.log('subscribeEnvironment: already loaded '); // console.log('subscribeEnvironment: already loaded ');
return of(this.envSpecific); return of(this.envSpecific);
} }
getFullUrl(){
var location ="";
var domain = "";
if (typeof document == 'undefined') {
//let req = this.injector.get('request');
//let req: Request = this.injector.get(REQUEST_TOKEN);
domain = this.request.get('host').split(":")[0];
location = (domain.indexOf(".openaire.eu")!=-1?"https://":"http://")+ this.request.get('host') + this.propertiesPath;
}else{
let baseUrl = (document && document.getElementsByTagName('base'))?document.getElementsByTagName('base')[0].href.split(document.location.host)[1]:"/";
location = document.location.protocol +"//" + document.location.host + baseUrl + this.propertiesPath;
domain = document.location.hostname;
}
return location;
}
getDomain(){ getDomain(){
var domain = ""; var domain = "";
if (typeof document == 'undefined') { if (typeof document == 'undefined') {
//let req = this.injector.get('request');
//let req: Request = this.injector.get(REQUEST_TOKEN);
domain = this.request.get('host').split(":")[0]; domain = this.request.get('host').split(":")[0];
}else{ }else{
domain = document.location.hostname; domain = document.location.hostname;
@ -93,10 +48,7 @@ export class EnvironmentSpecificService {
if (es === null || es === undefined) { if (es === null || es === undefined) {
return; return;
} }
this.envSpecific = es; this.envSpecific = es;
//console.log(this.envSpecific);
if (this.envSpecificSubject) { if (this.envSpecificSubject) {
this.envSpecificSubject.next(this.envSpecific); this.envSpecificSubject.next(this.envSpecific);
} }