summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorluxin <luxin7@huawei.com>2017-10-26 16:10:33 +0800
committerluxin <luxin7@huawei.com>2017-10-26 16:10:33 +0800
commit4afd4ca9884405638160ea3062fbef1214381552 (patch)
tree87927f91f71e9edce7b306852796c0e03a8b18f1
parent8ac42cc229bcec06af8882946f9d30fc9dfb0cca (diff)
Add query vnfm from ESR interface
Change-Id: I1eba072dbef479b10b8bafe312220899b5ebe68f Issue-Id:VFC-552 Signed-off-by: luxin <luxin7@huawei.com>
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/VnfmUtil.java74
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/servicetoken/VnfmRestfulUtil.java29
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/ParamConstants.java2
-rw-r--r--huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java18
4 files changed, 84 insertions, 39 deletions
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/VnfmUtil.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/VnfmUtil.java
index 0ebab2ee..9b8ef6ee 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/VnfmUtil.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/VnfmUtil.java
@@ -16,6 +16,10 @@
package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.commons.codec.binary.Base64;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.restclient.RestfulResponse;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.servicetoken.VnfmRestfulUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.Constant;
@@ -49,8 +53,19 @@ public final class VnfmUtil {
* @since VFC 1.0
*/
public static JSONObject getVnfmById(String vnfmId) {
+ Map<String, String> headerMap = new HashMap<>(5);
+ headerMap.put("Content-Type", "application/json");
+ headerMap.put("Accept", "application/json");
+ headerMap.put("X-TransactionId", "9999");
+ headerMap.put("X-FromAppId", "esr-server");
+
+ Base64 token = new Base64();
+ String authen = new String(token.encode(("AAI:AAI").getBytes()));
+ headerMap.put("Authorization", "Basic " + authen);
+ LOGGER.info("getVimById headerMap: {}", headerMap.toString());
+
RestfulResponse rsp = VnfmRestfulUtil.getRemoteResponse(String.format(ParamConstants.ESR_GET_VNFM_URL, vnfmId),
- VnfmRestfulUtil.TYPE_GET, null);
+ VnfmRestfulUtil.TYPE_GET, headerMap, null);
if(rsp == null) {
LOGGER.error("funtion=getVnfmById, response is null.");
return null;
@@ -61,7 +76,7 @@ public final class VnfmUtil {
}
JSONObject esrVnfm = JSONObject.fromObject(rsp.getResponseContent());
LOGGER.info("esrVnfm: {}", esrVnfm);
- JSONObject vnfmJson = parseEsrVnfm(esrVnfm);
+ JSONObject vnfmJson = parseEsrVnfm(vnfmId, esrVnfm);
LOGGER.info("vnfmJson: {}", esrVnfm);
return vnfmJson;
}
@@ -69,40 +84,23 @@ public final class VnfmUtil {
/**
* <br>
*
+ * @param vnfmId
* @param
* esrVnfm
+ * http://172.30.3.34:80/aai/v11/external-system/esr-vnfm-list/esr-vnfm/6f78d29e-3c4b-4d41-a200-6d3b518fb874/esr-system-info-list
* {
- * "vnfm-id": "",
- * "vim-id": "",
- * "certificate-url": "",
- * "resource-version": "",
- * "esr-system-info-list": [{
- * "esr-system-info-id": "",
- * "system-name": "",
- * "type": "",
- * "vendor": "",
- * "version": "",
- * "service-url": "",
- * "user-name": "",
- * "password": "",
- * "system-type": "",
- * "protocal": "",
- * "ssl-cacert": "",
- * "ssl-insecure": "",
- * "ip-address": "",
- * "port": "",
- * "cloud-domain": "",
- * "default-tenant": "",
- * "resource-version": "",
- * "relationship-list": [
- * ]
- * }
- * ],
- * "relationship-list": [{
- * "related-to": "",
- * "related-link": "",
- * "relationship-data": [],
- * "related-to-property": []
+ * "esr-system-info": [
+ * {
+ * "esr-system-info-id": "2b0c1a80-1b95-4d28-b206-f9cb6d7f8d3a",
+ * "system-name": "hwvnfm",
+ * "type": "vnfm",
+ * "vendor": "huawei",
+ * "version": "v1.0",
+ * "service-url": "http://172.30.20.5:30001",
+ * "user-name": "admin",
+ * "password": "Huawei12#$",
+ * "system-type": "VNFM",
+ * "resource-version": "1508828777218"
* }
* ]
* }
@@ -124,17 +122,17 @@ public final class VnfmUtil {
* }
* @since VFC 1.0
*/
- private static JSONObject parseEsrVnfm(JSONObject esrVnfm) {
+ private static JSONObject parseEsrVnfm(String vnfmId, JSONObject esrVnfm) {
JSONObject vnfmObj = new JSONObject();
- JSONObject esrSysInfo = esrVnfm.getJSONArray("esr-system-info-list").getJSONObject(0);
- vnfmObj.put(Constant.VNFMID, esrSysInfo.getString("esr-system-info-id"));
+ JSONObject esrSysInfo = esrVnfm.getJSONArray("esr-system-info").getJSONObject(0);
+ vnfmObj.put(Constant.VNFMID, vnfmId);
vnfmObj.put("name", esrSysInfo.getString("system-name"));
vnfmObj.put("type", esrSysInfo.getString("type"));
- vnfmObj.put("vimId", esrVnfm.getString("vim-id"));
+ vnfmObj.put("vimId", "");
vnfmObj.put("vendor", esrSysInfo.getString("vendor"));
vnfmObj.put("version", esrSysInfo.getString("version"));
vnfmObj.put("description", "");
- vnfmObj.put("certificateUrl", esrVnfm.getString("certificate-url"));
+ vnfmObj.put("certificateUrl", "");
vnfmObj.put("url", esrSysInfo.getString("service-url"));
vnfmObj.put("userName", esrSysInfo.getString("user-name"));
vnfmObj.put("password", esrSysInfo.getString("password"));
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/servicetoken/VnfmRestfulUtil.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/servicetoken/VnfmRestfulUtil.java
index d3be616a..b7c9c7ad 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/servicetoken/VnfmRestfulUtil.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/common/servicetoken/VnfmRestfulUtil.java
@@ -382,6 +382,35 @@ public final class VnfmRestfulUtil {
return rsp;
}
+ public static RestfulResponse getRemoteResponse(String url, String methodType, Map<String, String> headerMap,
+ String params) {
+ RestfulResponse rsp = null;
+ Restful rest = RestfulFactory.getRestInstance(RestfulFactory.PROTO_HTTP);
+ try {
+
+ RestfulParametes restfulParametes = new RestfulParametes();
+ restfulParametes.setHeaderMap(headerMap);
+ if(params != null) {
+ restfulParametes.setRawData(params);
+ }
+
+ if(rest != null) {
+ if(TYPE_GET.equalsIgnoreCase(methodType)) {
+ rsp = rest.get(url, restfulParametes);
+ } else if(TYPE_POST.equalsIgnoreCase(methodType)) {
+ rsp = rest.post(url, restfulParametes);
+ } else if(TYPE_PUT.equalsIgnoreCase(methodType)) {
+ rsp = rest.put(url, restfulParametes);
+ } else if(TYPE_DEL.equalsIgnoreCase(methodType)) {
+ rsp = rest.delete(url, restfulParametes);
+ }
+ }
+ } catch(ServiceException e) {
+ LOG.error("function=getRemoteResponse, get restful response catch exception {}", e);
+ }
+ return rsp;
+ }
+
/**
* Make Params map<br>
*
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/ParamConstants.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/ParamConstants.java
index 6aafba8f..5de4651a 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/ParamConstants.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/constant/ParamConstants.java
@@ -110,7 +110,7 @@ public class ParamConstants {
public static final String MSB_UNREGISTER_URL = "/api/microservices/v1/services/hw-vnfm";
// /api/extsys/v1/vnfms/%s
- public static final String ESR_GET_VNFM_URL = "/external-system/esr-vnfm-list/esr-vnfm/%s";
+ public static final String ESR_GET_VNFM_URL = "/external-system/esr-vnfm-list/esr-vnfm/%s/esr-system-info-list";
// /api/extsys/v1/vnfms
public static final String ESR_GET_VNFMS_URL = "/external-system/esr-vnfm-list";
diff --git a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java
index 4867ace7..4b6520f5 100644
--- a/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java
+++ b/huawei/vnfmadapter/VnfmadapterService/service/src/main/java/org/onap/vfc/nfvo/vnfm/svnfm/vnfmadapter/service/rest/VnfRoa.java
@@ -35,6 +35,7 @@ import javax.ws.rs.core.MediaType;
import org.apache.commons.collections.map.UnmodifiableMap;
import org.apache.commons.lang3.StringUtils;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmJsonUtil;
+import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmUtil;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.restclient.ServiceException;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.Constant;
import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.VnfMgr;
@@ -237,6 +238,23 @@ public class VnfRoa {
}
/**
+ * <br>
+ *
+ * @param vnfmId
+ * @param resp
+ * @return
+ * @throws ServiceException
+ * @since VFC 1.0
+ */
+ @GET
+ @Path("/{vnfmId}")
+ public String getVnfmById(@PathParam("vnfmId") String vnfmId, @Context HttpServletResponse resp)
+ throws ServiceException {
+ LOG.warn("function=getVnfmById, vnfmId: {}", vnfmId);
+ return VnfmUtil.getVnfmById(vnfmId).toString();
+ }
+
+ /**
* Provide function for get job
* <br/>
*