X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=esr-mgr%2Fsrc%2Fmain%2Fjava%2Forg%2Fonap%2Faai%2Fesr%2Fwrapper%2FVnfmManagerWrapper.java;h=d1b3b77423ae59e75e4f8d88618e4cb6e08ce771;hb=c62f4b64bdd6a26cd8d78406e4bcf8ab907384a1;hp=a1ac53cbca53adf2c62673ddc0c6bf7b95176d98;hpb=fa6dd60a45a093205ae55065f6de044c91493e60;p=aai%2Fesr-server.git diff --git a/esr-mgr/src/main/java/org/onap/aai/esr/wrapper/VnfmManagerWrapper.java b/esr-mgr/src/main/java/org/onap/aai/esr/wrapper/VnfmManagerWrapper.java index a1ac53c..d1b3b77 100644 --- a/esr-mgr/src/main/java/org/onap/aai/esr/wrapper/VnfmManagerWrapper.java +++ b/esr-mgr/src/main/java/org/onap/aai/esr/wrapper/VnfmManagerWrapper.java @@ -19,17 +19,25 @@ import java.util.ArrayList; import javax.ws.rs.core.Response; -import org.onap.aai.esr.entity.rest.RegisterResponse; -import org.onap.aai.esr.entity.rest.VnfmRestData; +import org.onap.aai.esr.entity.aai.EsrSystemInfo; +import org.onap.aai.esr.entity.aai.EsrVnfmDetail; +import org.onap.aai.esr.entity.aai.EsrVnfmList; +import org.onap.aai.esr.entity.rest.CommonRegisterResponse; +import org.onap.aai.esr.entity.rest.VnfmRegisterInfo; +import org.onap.aai.esr.externalservice.aai.ExternalSystemProxy; +import org.onap.aai.esr.util.VnfmManagerUtil; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import com.google.gson.Gson; + public class VnfmManagerWrapper { private static VnfmManagerWrapper vnfmManagerWrapper; private static final Logger LOG = LoggerFactory.getLogger(VnfmManagerWrapper.class); /** * get VnfmManagerWrapper instance. + * * @return vnfm manager wrapper instance */ public static VnfmManagerWrapper getInstance() { @@ -39,31 +47,141 @@ public class VnfmManagerWrapper { return vnfmManagerWrapper; } - public Response registerVnfm(VnfmRestData vnfm) { - //TODO - RegisterResponse result = null; - return Response.ok(result).build(); + public Response registerVnfm(VnfmRegisterInfo vnfm) { + CommonRegisterResponse result = new CommonRegisterResponse(); + EsrVnfmDetail esrVnfmDetail = new EsrVnfmDetail(); + esrVnfmDetail = VnfmManagerUtil.vnfmRegisterInfo2EsrVnfm(vnfm); + String vnfmId = esrVnfmDetail.getVnfmId(); + try { + ExternalSystemProxy.registerVnfm(vnfmId, esrVnfmDetail); + result.setId(vnfmId); + return Response.ok(result).build(); + } catch (Exception e) { + e.printStackTrace(); + LOG.error("Register VNFM failed !" + e.getMessage()); + return Response.serverError().build(); + } } - - public Response updateVnfm(VnfmRestData vnfm, String vnfmId) { - //TODO - return Response.ok().build(); + + public Response updateVnfm(VnfmRegisterInfo vnfm, String vnfmId) { + CommonRegisterResponse result = new CommonRegisterResponse(); + EsrVnfmDetail esrVnfmDetail = new EsrVnfmDetail(); + EsrVnfmDetail originalEsrVnfmDetail = new EsrVnfmDetail(); + EsrSystemInfo originalEsrSystemInfo = new EsrSystemInfo(); + originalEsrVnfmDetail = queryEsrVnfmDetail(vnfmId); + esrVnfmDetail = VnfmManagerUtil.vnfmRegisterInfo2EsrVnfm(vnfm); + String resourceVersion = getResourceVersion(vnfmId); + esrVnfmDetail.setResourceVersion(resourceVersion); + esrVnfmDetail.setVnfmId(vnfmId); + originalEsrSystemInfo = originalEsrVnfmDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0); + esrVnfmDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0) + .setEsrSystemInfoId(originalEsrSystemInfo.getEsrSystemInfoId()); + esrVnfmDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0) + .setResouceVersion(originalEsrSystemInfo.getResouceVersion()); + try { + ExternalSystemProxy.registerVnfm(vnfmId, esrVnfmDetail); + result.setId(vnfmId); + return Response.ok(result).build(); + } catch (Exception e) { + e.printStackTrace(); + LOG.error("Update VNFM failed !" + e.getMessage()); + return Response.serverError().build(); + } } - + public Response queryVnfmList() { - ArrayList vnfmList = new ArrayList(); - //TODO - return Response.ok(vnfmList).build(); + ArrayList vnfmList = new ArrayList(); + EsrVnfmList esrVnfm = new EsrVnfmList(); + try { + String esrVnfmStr = ExternalSystemProxy.queryVnfmList(); + esrVnfm = new Gson().fromJson(esrVnfmStr, EsrVnfmList.class); + LOG.info("Response from AAI by query VNFM list: " + esrVnfm); + vnfmList = getVnfmDetailList(esrVnfm); + return Response.ok(vnfmList).build(); + } catch (Exception e) { + e.printStackTrace(); + LOG.error("Query VNFM list failed !"); + return Response.serverError().build(); + } } - + public Response queryVnfmById(String vnfmId) { - VnfmRestData vnfm = new VnfmRestData(); - //TODO - return Response.ok(vnfm).build(); + VnfmRegisterInfo vnfm = new VnfmRegisterInfo(); + vnfm = queryVnfmDetail(vnfmId); + if (vnfm != null) { + return Response.ok(vnfm).build(); + } else { + return Response.ok().build(); + } } - + public Response delVnfm(String vnfmId) { - //TODO - return Response.noContent().build(); + String resourceVersion = getResourceVersion(vnfmId); + if (resourceVersion != null) { + try { + ExternalSystemProxy.deleteVnfm(vnfmId, resourceVersion); + return Response.ok().build(); + } catch (Exception e) { + e.printStackTrace(); + LOG.error("Delete VNFM from A&AI failed! VNFM ID: " + vnfmId + "resouce-version:" + + resourceVersion, e.getMessage()); + return Response.serverError().build(); + } + } else { + LOG.error("resouce-version is null ! Can not delete resouce from A&AI. "); + return Response.serverError().build(); + } + } + + private VnfmRegisterInfo queryVnfmDetail(String vnfmId) { + VnfmRegisterInfo vnfm = new VnfmRegisterInfo(); + EsrVnfmDetail esrVnfmDetail = new EsrVnfmDetail(); + try { + String esrVnfmstr = ExternalSystemProxy.queryVnfmDetail(vnfmId); + LOG.info("Response from AAI by query VNFM: " + esrVnfmstr); + esrVnfmDetail = new Gson().fromJson(esrVnfmstr, EsrVnfmDetail.class); + vnfm = VnfmManagerUtil.esrVnfm2VnfmRegisterInfo(esrVnfmDetail); + return vnfm; + } catch (Exception e) { + e.printStackTrace(); + LOG.error("Query VNFM detail failed! VNFM ID: " + vnfmId, e.getMessage()); + return null; + } + } + + private ArrayList getVnfmDetailList(EsrVnfmList esrVnfm) { + ArrayList vnfmInfoList = new ArrayList(); + VnfmRegisterInfo vnfmInfo = new VnfmRegisterInfo(); + for (int i = 0; i < esrVnfm.getEsrVnfm().size(); i++) { + String vnfmId = esrVnfm.getEsrVnfm().get(i).getVnfmId(); + vnfmInfo = queryVnfmDetail(vnfmId); + if (vnfmInfo != null) { + vnfmInfoList.add(vnfmInfo); + } + } + return vnfmInfoList; + } + + private String getResourceVersion (String vnfmId) { + EsrVnfmDetail esrVnfmDetail = new EsrVnfmDetail(); + String resourceVersion = null; + esrVnfmDetail = queryEsrVnfmDetail(vnfmId); + if (esrVnfmDetail != null && esrVnfmDetail.getResourceVersion() != null) { + resourceVersion = esrVnfmDetail.getResourceVersion(); + } + return resourceVersion; + } + + private EsrVnfmDetail queryEsrVnfmDetail (String vnfmId) { + EsrVnfmDetail esrVnfmDetail = new EsrVnfmDetail(); + try { + String esrVnfmstr = ExternalSystemProxy.queryVnfmDetail(vnfmId); + LOG.info("Response from AAI by query VNFM: " + esrVnfmstr); + esrVnfmDetail = new Gson().fromJson(esrVnfmstr, EsrVnfmDetail.class); + } catch (Exception e) { + e.printStackTrace(); + LOG.error("Query VNFM detail failed! VNFM ID: " + vnfmId, e.getMessage()); + } + return esrVnfmDetail; } }