X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=webapp-frontend%2Fsrc%2Fapp%2Fservices%2Fac-xapp%2Fac-xapp.service.ts;h=47b54401d6675877375477a395d80417c1c73447;hb=749749f288de7ef42e3d1507c7f07a4453a774b4;hp=740fcbcb5dfaa3dc28199dd59c468e9af0b9352f;hpb=21f98d01948dabb1d6a89b60f5694969e42c9e63;p=portal%2Fric-dashboard.git diff --git a/webapp-frontend/src/app/services/ac-xapp/ac-xapp.service.ts b/webapp-frontend/src/app/services/ac-xapp/ac-xapp.service.ts index 740fcbcb..47b54401 100644 --- a/webapp-frontend/src/app/services/ac-xapp/ac-xapp.service.ts +++ b/webapp-frontend/src/app/services/ac-xapp/ac-xapp.service.ts @@ -21,36 +21,63 @@ import { Injectable } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { Observable } from 'rxjs'; + import { map } from 'rxjs/operators'; import { ACAdmissionIntervalControl, ACAdmissionIntervalControlAck } from '../../interfaces/ac-xapp.types'; import { DashboardSuccessTransport } from '../../interfaces/dashboard.types'; +/** + * Services for calling the Dashboard's A1 endpoints to get/put AC policies. + */ @Injectable({ providedIn: 'root' }) -export class AcXappService { +export class ACXappService { + + private basePath = 'api/a1-p'; + private policyPath = 'policies'; + private acPolicyName = 'admission_control_policy'; - private basePath = 'api/xapp/ac/'; + private buildPath(...args: any[]) { + let result = this.basePath; + args.forEach(part => { + result = result + '/' + part; + }); + return result; + } constructor(private httpClient: HttpClient) { // injects to variable httpClient } /** - * Gets A1 Mediator client version details - * @returns Observable that should yield a SuccessTransport object + * Gets version details + * @returns Observable that should yield a String + */ + getVersion(): Observable { + const url = this.buildPath('version'); + return this.httpClient.get(url).pipe( + // Extract the string here + map(res => res['data']) + ); + } + + /** + * Gets admission control policy. + * @returns Observable that should yield an ACAdmissionIntervalControl */ - getVersion() { - // Remember that AC traffic goes via A1! - return this.httpClient.get(this.basePath + 'version'); + getPolicy(): Observable { + const url = this.buildPath(this.policyPath, this.acPolicyName); + return this.httpClient.get(url); } /** - * Puts control admission time parameters to AC via A1 + * Puts admission control policy. * @param policy an instance of ACAdmissionIntervalControl - * @returns Observable that should yield an ACAdmissionIntervalControlAck + * @returns Observable that should yield a response code, no data */ - putCaTime(policy: ACAdmissionIntervalControl): Observable { - return this.httpClient.put(this.basePath + 'catime', policy); + putPolicy(policy: ACAdmissionIntervalControl): Observable { + const url = this.buildPath(this.policyPath, this.acPolicyName); + return this.httpClient.put(url, policy, { observe: 'response' }); } }