summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--holmes-actions/src/main/java/org/onap/holmes/common/aai/AaiQuery4Ccvpn.java38
-rw-r--r--holmes-actions/src/test/java/org/onap/holmes/common/aai/AaiQuery4CcvpnTest.java10
2 files changed, 37 insertions, 11 deletions
diff --git a/holmes-actions/src/main/java/org/onap/holmes/common/aai/AaiQuery4Ccvpn.java b/holmes-actions/src/main/java/org/onap/holmes/common/aai/AaiQuery4Ccvpn.java
index 42b7bd7..0e28ff9 100644
--- a/holmes-actions/src/main/java/org/onap/holmes/common/aai/AaiQuery4Ccvpn.java
+++ b/holmes-actions/src/main/java/org/onap/holmes/common/aai/AaiQuery4Ccvpn.java
@@ -47,6 +47,17 @@ public class AaiQuery4Ccvpn {
headers.add("Accept", "application/json");
}
+ /**
+ * Query the logic link information for AAI. This method is based on the API:
+ * https://<AAI host>:<AAI port>/aai/v14/network/network-resources/network-resource/{networkId}/pnfs/pnf/{pnfName}/p-interfaces?interface-name={ifName}&operational-status={status}
+ * provided by AAI.
+ *
+ * @param networkId
+ * @param pnfName
+ * @param ifName
+ * @param status
+ * @return the ID of the logic link
+ */
public String getLogicLink(String networkId, String pnfName, String ifName, String status) {
Map<String, String> params = new HashMap<>();
params.put("networkId", networkId);
@@ -63,6 +74,19 @@ public class AaiQuery4Ccvpn {
return extractValueFromJsonArray(linkInfo.getJSONArray("relationship-data"), "logical-link.link-name");
}
+ /**
+ * Query all the instances related to a terminal point. This method is mainly based on the API:
+ * https://<AAI host>:<AAI port>/aai/v14/network/connectivities?connectivity-id={connectivityId}
+ * and
+ * https://<AAI host>:<AAI port>/aai/v14/business/customers/customer/{global-customer-id}/service-subscriptions/service-subscription/{service-type}
+ * provided by AAI. The path for getting the required instance information is: p-interface → vpn-vpnbinding → connectivity → service instance
+ *
+ * @param networkId
+ * @param pnfName
+ * @param ifName
+ * @param status
+ * @return all related service instances in JSONArray format
+ */
public JSONArray getServiceInstances(String networkId, String pnfName, String ifName, String status) {
try {
JSONObject vpnBindingInfo = getVpnBindingInfo(networkId, pnfName, ifName, status);
@@ -108,8 +132,8 @@ public class AaiQuery4Ccvpn {
}
}
- public JSONObject getVpnBindingInfo(String networkId, String pnfName,
- String ifName, String status) throws CorrelationException {
+ private JSONObject getVpnBindingInfo(String networkId, String pnfName,
+ String ifName, String status) throws CorrelationException {
Map<String, String> params = new HashMap();
params.put("networkId", networkId);
params.put("pnfName", pnfName);
@@ -123,7 +147,7 @@ public class AaiQuery4Ccvpn {
return getInfo(JSONObject.toJSONString(response.getEntity()), "p-interface", "vpn-binding");
}
- public JSONObject getConnectivityInfo(String vpnId) throws CorrelationException {
+ private JSONObject getConnectivityInfo(String vpnId) throws CorrelationException {
Response response = get(getHostAddr(), getPath(AaiConfig.MsbConsts.AAI_CONN_ADDR, "vpnId", vpnId));
if (response.getStatusInfo().getFamily() != Response.Status.Family.SUCCESSFUL) {
throw new CorrelationException("Failed to connect to AAI. Cause: "
@@ -132,7 +156,7 @@ public class AaiQuery4Ccvpn {
return getInfo(JSONObject.toJSONString(response.getEntity()), "vpn-binding", "connectivity");
}
- public JSONObject getServiceInstanceByConn(String connectivityId) throws CorrelationException {
+ private JSONObject getServiceInstanceByConn(String connectivityId) throws CorrelationException {
Response response = get(getHostAddr(), getPath(AaiConfig.MsbConsts.AAI_SERVICE_INSTANCE_ADDR_4_CCVPN,
"connectivityId", connectivityId));
if (response.getStatusInfo().getFamily() != Response.Status.Family.SUCCESSFUL) {
@@ -142,7 +166,7 @@ public class AaiQuery4Ccvpn {
return getInfo(JSONObject.toJSONString(response.getEntity()), "connectivity", "service-instance");
}
- public JSONArray getServiceInstances(String globalCustomerId, String serviceType) throws CorrelationException {
+ private JSONArray getServiceInstances(String globalCustomerId, String serviceType) throws CorrelationException {
Map<String, String> params = new HashMap();
params.put("global-customer-id", globalCustomerId);
params.put("service-type", serviceType);
@@ -177,13 +201,13 @@ public class AaiQuery4Ccvpn {
return ret;
}
- public Response get(String host, String path) {
+ private Response get(String host, String path) {
Client client = ClientBuilder.newClient();
WebTarget target = client.target(host).path(path);
return target.request().headers(getAaiHeaders()).get();
}
- public Response patch(String host, String path, Map<String, Object> body) {
+ private Response patch(String host, String path, Map<String, Object> body) {
Client client = ClientBuilder.newClient();
WebTarget target = client.target(host).path(path);
return target.request().headers(getAaiHeaders()).method("PATCH", Entity.json(body));
diff --git a/holmes-actions/src/test/java/org/onap/holmes/common/aai/AaiQuery4CcvpnTest.java b/holmes-actions/src/test/java/org/onap/holmes/common/aai/AaiQuery4CcvpnTest.java
index 51cba1c..c7c32eb 100644
--- a/holmes-actions/src/test/java/org/onap/holmes/common/aai/AaiQuery4CcvpnTest.java
+++ b/holmes-actions/src/test/java/org/onap/holmes/common/aai/AaiQuery4CcvpnTest.java
@@ -211,14 +211,15 @@ public class AaiQuery4CcvpnTest {
}
@Test
- public void test_getServiceInstances_1() throws CorrelationException {
+ public void test_getServiceInstances_1() throws Exception {
mockGetMethod();
EasyMock.expect(response.getEntity()).andReturn(data.getJSONObject("service-instances-by-service-type"));
EasyMock.expect(response.getStatusInfo()).andReturn(Response.Status.OK);
PowerMock.replayAll();
- JSONArray instances = aai.getServiceInstances("custom-1", "service-type-1");
+ JSONArray instances = (JSONArray)Whitebox.invokeMethod(aai, "getServiceInstances",
+ "custom-1", "service-type-1");
PowerMock.verifyAll();
@@ -228,7 +229,7 @@ public class AaiQuery4CcvpnTest {
}
@Test
- public void test_getServiceInstances_1_exception() throws CorrelationException {
+ public void test_getServiceInstances_1_exception() throws Exception {
mockGetMethod();
EasyMock.expect(response.getEntity()).andReturn(data.getJSONObject("service-instances-by-service-type"));
EasyMock.expect(response.getStatusInfo()).andReturn(Response.Status.NOT_FOUND).times(2);
@@ -237,7 +238,8 @@ public class AaiQuery4CcvpnTest {
PowerMock.replayAll();
- JSONArray instances = aai.getServiceInstances("custom-1", "service-type-1");
+ JSONArray instances = (JSONArray)Whitebox.invokeMethod(aai, "getServiceInstances",
+ "custom-1", "service-type-1");
PowerMock.verifyAll();