* ========================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.
* limitations under the License.
* ========================LICENSE_END===================================
*/
+import { HttpClient, HttpResponse } from '@angular/common/http';
import { Injectable } from '@angular/core';
-import { HttpClient } from '@angular/common/http';
-import { E2SetupRequest } from '../../interfaces/e2-mgr.types';
+import { Observable } from 'rxjs';
+import { map } from 'rxjs/operators';
+import { DashboardSuccessTransport } from '../../interfaces/dashboard.types';
+import { E2RanDetails, E2SetupRequest } from '../../interfaces/e2-mgr.types';
+import { DashboardService } from '../dashboard/dashboard.service';
+
+@Injectable({
+ providedIn: 'root'
+})
-@Injectable()
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 manager client version details
- * @returns Observable that should yield a DashboardSuccessTransport object
+ * Gets E2 client version details
+ * @returns Observable that yields a String
*/
- getE2ManagerVersion() {
- return this.httpClient.get(this.basePath + 'version');
+ getVersion(instanceKey: string): Observable<string> {
+ const path = this.dashboardSvc.buildPath(this.component, null, 'version');
+ return this.httpClient.get<DashboardSuccessTransport>(path).pipe(
+ // Extract the string here
+ map(res => res['data'])
+ );
}
/**
- * Gets setup request history
- * @returns Observable that should yield an array of objects
+ * Gets RAN details
+ * @returns Observable that yields an array of E2RanDetails objects
*/
- getAll() {
- return this.httpClient.get(this.basePath + 'setup');
+ getRan(instanceKey: string): Observable<Array<E2RanDetails>> {
+ const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'ran');
+ return this.httpClient.get<Array<E2RanDetails>>(path);
}
/**
* Sends a request to setup an ENDC/gNodeB connection
- * @returns Observable
+ * @returns Observable. On success there is no data, only a code.
*/
- endcSetup(req: E2SetupRequest) {
- return this.httpClient.post(this.basePath + 'endcSetup', req);
+ endcSetup(instanceKey: string, req: E2SetupRequest): Observable<HttpResponse<Object>> {
+ 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
+ * @returns Observable. On success there is no data, only a code.
*/
- x2Setup(req: E2SetupRequest) {
- return this.httpClient.post(this.basePath + 'x2Setup', req);
+ x2Setup(instanceKey: string, req: E2SetupRequest): Observable<HttpResponse<Object>> {
+ const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'x2-setup');
+ return this.httpClient.post(path, req, { observe: 'response' });
}
- disconnectAllRAN() {
- return this.httpClient.delete((this.basePath + 'disconnectAllRAN'), { observe: 'response' });
+ /**
+ * Sends a request to drop all RAN connections
+ * @returns Observable with body.
+ */
+ nodebPut(instanceKey: string): Observable<any> {
+ const path = this.dashboardSvc.buildPath(this.component, instanceKey, this.nodebPath, 'shutdown');
+ return this.httpClient.put(path, { observe: 'body' });
}
}