X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=webapp-frontend%2Fsrc%2Fapp%2Fservices%2Fe2-mgr%2Fe2-mgr.service.ts;h=45d7b5849e646b06b06ed333e871746696749b61;hb=9cf5b95a5bc9810d739d14d324dd7d80cbdb4a7d;hp=e40ee6070a4f4e9ac64b989e8d5ac43345a23a4c;hpb=42c6891f45dce060347b3637e72daac370fbce29;p=portal%2Fric-dashboard.git diff --git a/webapp-frontend/src/app/services/e2-mgr/e2-mgr.service.ts b/webapp-frontend/src/app/services/e2-mgr/e2-mgr.service.ts index e40ee607..45d7b584 100644 --- a/webapp-frontend/src/app/services/e2-mgr/e2-mgr.service.ts +++ b/webapp-frontend/src/app/services/e2-mgr/e2-mgr.service.ts @@ -2,14 +2,14 @@ * ========================LICENSE_START================================= * O-RAN-SC * %% - * Copyright (C) 2019 AT&T Intellectual Property and Nokia + * Copyright (C) 2019 AT&T Intellectual Property * %% * 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. @@ -17,12 +17,13 @@ * limitations under the License. * ========================LICENSE_END=================================== */ -import { Injectable } from '@angular/core'; import { HttpClient, HttpResponse } from '@angular/common/http'; +import { Injectable } from '@angular/core'; import { Observable } from 'rxjs'; import { map } from 'rxjs/operators'; -import { E2RanDetails, E2SetupRequest } from '../../interfaces/e2-mgr.types'; import { DashboardSuccessTransport } from '../../interfaces/dashboard.types'; +import { E2RanDetails, E2SetupRequest } from '../../interfaces/e2-mgr.types'; +import { DashboardService } from '../dashboard/dashboard.service'; @Injectable({ providedIn: 'root' @@ -30,19 +31,21 @@ import { DashboardSuccessTransport } from '../../interfaces/dashboard.types'; export class E2ManagerService { - private basePath = 'api/e2mgr/'; + private component = 'e2mgr'; + private nodebPath = 'nodeb'; - constructor(private httpClient: HttpClient) { - // injects to variable httpClient + constructor( + private dashboardSvc: DashboardService, + private httpClient: HttpClient) { } /** * Gets E2 client version details - * @returns Observable that should yield a String + * @returns Observable that yields a String */ - getVersion(): Observable { - const url = this.basePath + 'version'; - return this.httpClient.get(url).pipe( + getVersion(instanceKey: string): Observable { + const path = this.dashboardSvc.buildPath(this.component, null, 'version'); + return this.httpClient.get(path).pipe( // Extract the string here map(res => res['data']) ); @@ -50,34 +53,38 @@ export class E2ManagerService { /** * Gets RAN details - * @returns Observable that should yield an array of objects + * @returns Observable that yields an array of E2RanDetails objects */ - getRan(): Observable> { - return this.httpClient.get>(this.basePath + 'ran'); + getRan(instanceKey: string): Observable> { + const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'ran'); + return this.httpClient.get>(path); } /** * Sends a request to setup an ENDC/gNodeB connection * @returns Observable. On success there is no data, only a code. */ - endcSetup(req: E2SetupRequest): Observable> { - return this.httpClient.post(this.basePath + 'endcSetup', req, { observe: 'response' }); + endcSetup(instanceKey: string, req: E2SetupRequest): Observable> { + const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'endc-setup'); + return this.httpClient.post(path, req, { observe: 'response' }); } /** * Sends a request to setup an X2/eNodeB connection * @returns Observable. On success there is no data, only a code. */ - x2Setup(req: E2SetupRequest): Observable> { - return this.httpClient.post(this.basePath + 'x2Setup', req, { observe: 'response' }); + x2Setup(instanceKey: string, req: E2SetupRequest): Observable> { + const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'x2-setup'); + return this.httpClient.post(path, req, { observe: 'response' }); } /** * Sends a request to drop all RAN connections * @returns Observable with body. */ - nodebPut(): Observable { - return this.httpClient.put((this.basePath + 'nodebShutdownPut'), { observe: 'body' }); + nodebPut(instanceKey: string): Observable { + const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'shutdown'); + return this.httpClient.put(path, { observe: 'body' }); } }