2 * ========================LICENSE_START=================================
5 * Copyright (C) 2019 Nordix Foundation
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ========================LICENSE_END===================================
21 import { Injectable } from '@angular/core';
22 import { HttpClient } from '@angular/common/http';
23 import { Observable } from 'rxjs';
24 import { map } from 'rxjs/operators';
25 import { PolicyInstance, PolicyInstanceAck, PolicyInstances, PolicyStatus, PolicyType, PolicyTypes } from '../../interfaces/policy.types';
26 import { ControlpanelSuccessTransport } from '../../interfaces/controlpanel.types';
29 * Services for calling the policy endpoints.
34 export class PolicyService {
36 private apiVersion2 = '/v2'
37 private basePath = '/a1-policy';
38 policyTypesPath = 'policy-types';
39 policyPath = 'policies';
41 private buildPath(...args: any[]) {
42 let result = this.basePath + this.apiVersion2;
43 args.forEach(part => {
44 result = result + '/' + part;
49 constructor(private httpClient: HttpClient) {
50 // injects to variable httpClient
53 getPolicyTypes(): Observable<PolicyTypes> {
54 const url = this.buildPath(this.policyTypesPath);
55 return this.httpClient.get<PolicyTypes>(url);
58 getPolicyType(policyTypeId: string): Observable<PolicyType> {
59 const url = this.buildPath(this.policyTypesPath + '/' + policyTypeId);
60 return this.httpClient.get<PolicyType>(url);
63 getPolicyInstancesByType(policyTypeId: string): Observable<PolicyInstances> {
64 const url = this.buildPath(this.policyPath + '?' + 'policytype_id=' + policyTypeId);
65 return this.httpClient.get<PolicyInstances>(url);
68 getPolicyInstance(policyId: string): Observable<PolicyInstance> {
69 const url = this.buildPath(this.policyPath) + '/' + policyId;
70 return this.httpClient.get<PolicyInstance>(url);
73 getPolicyStatus(policyId: string): Observable<PolicyStatus> {
74 const url = this.buildPath(this.policyPath) + '/' + policyId + '/status';
75 return this.httpClient.get<PolicyStatus>(url);
79 * Gets policy parameters.
80 * @returns Observable that should yield a policy instance
82 getPolicy(policyTypeId: string, policyInstanceId: string): Observable<any> {
83 const url = this.buildPath(this.policyPath, policyInstanceId) + '?type=' + policyTypeId;
84 return this.httpClient.get<any>(url);
88 * Creates or replaces policy instance.
89 * @param policyTypeId ID of the policy type that the instance will have
90 * @param policyInstanceId ID of the instance
91 * @param policyJson Json with the policy content
92 * @returns Observable that should yield a response code, no data
94 putPolicy(policyTypeId: string, policyInstanceId: string, policyJson: string, ric: string): Observable<any> {
95 const url = this.buildPath(this.policyPath, policyInstanceId) + '?ric=' + ric + '&type=' + policyTypeId;
96 return this.httpClient.put<PolicyInstanceAck>(url, policyJson, { observe: 'response' });
100 * Deletes a policy instance.
101 * @param policyTypeId ID of the policy type that the instance belong to
102 * @param policyInstanceId ID of the instance
103 * @returns Observable that should yield a response code, no data
105 deletePolicy(policyTypeId: string, policyInstanceId: string): Observable<any> {
106 const url = this.buildPath(this.policyPath, policyInstanceId) + '?type=' + policyTypeId;
107 return this.httpClient.delete(url, { observe: 'response' });
111 getRics(policyTypeId: string): Observable<string[]> {
112 const url = this.buildPath('rics') + '?policyType=' + policyTypeId;
113 return this.httpClient.get<any>(url);