import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';
-import { map } from 'rxjs/operators';
-import { PolicyType, PolicyInstance, PolicyInstanceAck } from '../../interfaces/policy.types';
-import { ControlpanelSuccessTransport } from '../../interfaces/controlpanel.types';
+import { CreatePolicyInstance, PolicyInstance, PolicyInstanceAck, PolicyInstances, PolicyStatus, PolicyType, PolicyTypes } from '../../interfaces/policy.types';
+import { Rics } from 'src/app/interfaces/ric';
/**
* Services for calling the policy endpoints.
})
export class PolicyService {
- private basePath = 'api/policy';
- policyTypePath = 'policytypes';
+ private apiVersion2 = '/v2'
+ private basePath = '/a1-policy';
+ policyTypesPath = 'policy-types';
policyPath = 'policies';
private buildPath(...args: any[]) {
- let result = this.basePath;
+ let result = this.basePath + this.apiVersion2;
args.forEach(part => {
result = result + '/' + part;
});
// injects to variable httpClient
}
- /**
- * Gets version details
- * @returns Observable that should yield a String
- */
- getVersion(): Observable<string> {
- const url = this.buildPath('version');
- return this.httpClient.get<ControlpanelSuccessTransport>(url).pipe(
- // Extract the string here
- map(res => res['data'])
- );
+ getPolicyTypes(): Observable<PolicyTypes> {
+ const url = this.buildPath(this.policyTypesPath);
+ return this.httpClient.get<PolicyTypes>(url);
+ }
+
+ getPolicyType(policyTypeId: string): Observable<PolicyType> {
+ const url = this.buildPath(this.policyTypesPath + '/' + policyTypeId);
+ return this.httpClient.get<PolicyType>(url);
}
- getPolicyTypes(): Observable<PolicyType[]> {
- const url = this.buildPath(this.policyTypePath);
- return this.httpClient.get<PolicyType[]>(url);
+ getPolicyInstancesByType(policyTypeId: string): Observable<PolicyInstances> {
+ const url = this.buildPath(this.policyPath + '?' + 'policytype_id=' + policyTypeId);
+ return this.httpClient.get<PolicyInstances>(url);
}
- getPolicyInstances(policyTypeId: string): Observable<PolicyInstance[]> {
- const url = this.buildPath(this.policyPath) + '?type=' + policyTypeId;
- return this.httpClient.get<PolicyInstance[]>(url);
+ getPolicyInstance(policyId: string): Observable<PolicyInstance> {
+ const url = this.buildPath(this.policyPath) + '/' + policyId;
+ return this.httpClient.get<PolicyInstance>(url);
+ }
+
+ getPolicyStatus(policyId: string): Observable<PolicyStatus> {
+ const url = this.buildPath(this.policyPath) + '/' + policyId + '/status';
+ return this.httpClient.get<PolicyStatus>(url);
}
/**
* @param policyJson Json with the policy content
* @returns Observable that should yield a response code, no data
*/
- putPolicy(policyTypeId: string, policyInstanceId: string, policyJson: string, ric: string): Observable<any> {
- const url = this.buildPath(this.policyPath, policyInstanceId) + '?ric=' + ric + '&type=' + policyTypeId;
- return this.httpClient.put<PolicyInstanceAck>(url, policyJson, { observe: 'response' });
+ putPolicy(createPolicyInstance: CreatePolicyInstance): Observable<any> {
+ const url = this.buildPath(this.policyPath);
+ return this.httpClient.put<PolicyInstanceAck>(url, createPolicyInstance, { observe: 'response' });
}
/**
* @param policyInstanceId ID of the instance
* @returns Observable that should yield a response code, no data
*/
- deletePolicy(policyTypeId: string, policyInstanceId: string): Observable<any> {
- const url = this.buildPath(this.policyPath, policyInstanceId) + '?type=' + policyTypeId;
+ deletePolicy(policyInstanceId: string): Observable<any> {
+ const url = this.buildPath(this.policyPath, policyInstanceId);
return this.httpClient.delete(url, { observe: 'response' });
}
- getRics(policyTypeId: string): Observable<string[]> {
- const url = this.buildPath('rics') + '?policyType=' + policyTypeId;
+ getRics(policyTypeId: string): Observable<Rics> {
+ const url = this.buildPath('rics') + '?policytype_id=' + policyTypeId;
return this.httpClient.get<any>(url);
}
}