import javax.ws.rs.core.Response;
-import org.onap.aai.esr.entity.aai.CloudRegion;
+import org.onap.aai.esr.entity.aai.CloudRegionDetail;
+import org.onap.aai.esr.entity.aai.CloudRegionList;
+import org.onap.aai.esr.entity.aai.EsrSystemInfo;
import org.onap.aai.esr.entity.rest.VimRegisterInfo;
import org.onap.aai.esr.entity.rest.VimRegisterResponse;
import org.onap.aai.esr.externalservice.aai.CloudRegionProxy;
/**
* get VimManagerWrapper instance.
+ *
* @return vim manager wrapper instance
*/
public static VimManagerWrapper getInstance() {
vimManagerWrapper = new VimManagerWrapper();
}
return vimManagerWrapper;
-
+
}
-
+
public Response registerVim(VimRegisterInfo vimRegisterInfo) {
- LOG.info("Start register VIM, input VIM info is: " + ExtsysUtil.objectToString(vimRegisterInfo));
- CloudRegion cloudRegion = new CloudRegion();
+ LOG.info(
+ "Start register VIM, input VIM info is: " + ExtsysUtil.objectToString(vimRegisterInfo));
+ CloudRegionDetail cloudRegion = new CloudRegionDetail();
VimRegisterResponse result = new VimRegisterResponse();
cloudRegion = VimManagerUtil.vimRegisterInfo2CloudRegion(vimRegisterInfo);
- String cloud_owner = vimRegisterInfo.getCloudOwner();
- String cloud_region_id = vimRegisterInfo.getCloudRegionId();
+ String cloudOwner = vimRegisterInfo.getCloudOwner();
+ String cloudRegionId = vimRegisterInfo.getCloudRegionId();
+ try {
+ CloudRegionProxy.registerVim(cloudOwner, cloudRegionId, cloudRegion);
+ result.setCloudOwner(cloudOwner);
+ result.setCloudRegionId(cloudRegionId);
+ return Response.ok(result).build();
+ } catch (Exception error) {
+ error.printStackTrace();
+ LOG.error("Register VIM failed !" + error.getMessage());
+ return Response.serverError().build();
+ }
+ }
+
+ public Response updateVim(String cloudOwner, String cloudRegionId,VimRegisterInfo vimRegisterInfo) {
+ LOG.info("Start update VIM, input VIM info is: " + ExtsysUtil.objectToString(vimRegisterInfo));
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
+ VimRegisterResponse result = new VimRegisterResponse();
+ cloudRegionDetail = getVimUpdateInfo(vimRegisterInfo);
try {
- CloudRegionProxy.registerVim(cloud_owner, cloud_region_id, cloudRegion);
- result.setCloudOwner(cloud_owner);
- result.setCloudRegionId(cloud_region_id);
+ CloudRegionProxy.registerVim(cloudOwner, cloudRegionId, cloudRegionDetail);
+ result.setCloudOwner(cloudOwner);
+ result.setCloudRegionId(cloudRegionId);
return Response.ok(result).build();
} catch (Exception e) {
e.printStackTrace();
+ LOG.error("Update VIM failed !" + e.getMessage());
return Response.serverError().build();
}
}
- public Response updateVim(VimRegisterInfo vim) {
- //TODO
- return Response.ok().build();
- }
-
- public Response queryVimList() {
- //TODO
- ArrayList<VimRegisterInfo> vimList = new ArrayList<VimRegisterInfo>();
- return Response.ok(vimList).build();
+ public Response queryVimListDetails() {
+ ArrayList<VimRegisterInfo> vimRegisterInfos = new ArrayList<VimRegisterInfo>();
+ CloudRegionList cloudRegionList = new CloudRegionList();
+ try {
+ String aaiVimList = CloudRegionProxy.qureyVimList();
+ cloudRegionList = new Gson().fromJson(aaiVimList, CloudRegionList.class);
+ vimRegisterInfos = getVimDetailList(cloudRegionList);
+ return Response.ok(vimRegisterInfos).build();
+ } catch (Exception error) {
+ error.printStackTrace();
+ LOG.error("Query vim list details failed !" + error.getMessage());
+ return Response.serverError().build();
+ }
+
}
-
+
public Response queryVimById(String cloudOwner, String cloudRegionId) {
VimRegisterInfo vim = new VimRegisterInfo();
- CloudRegion cloudRegion = new CloudRegion();
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
try {
String cloudRegionstr = CloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
LOG.info("Response from AAI by query VIM: " + cloudRegionstr);
- cloudRegion = new Gson().fromJson(cloudRegionstr, CloudRegion.class);
- vim = VimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegion);
+ cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
+ vim = VimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegionDetail);
return Response.ok(vim).build();
} catch (Exception e) {
e.printStackTrace();
return Response.serverError().build();
}
-
+
+ }
+
+ private ArrayList<VimRegisterInfo> getVimDetailList(CloudRegionList cloudRegionList) {
+ ArrayList<VimRegisterInfo> vimRegisterInfos = new ArrayList<VimRegisterInfo>();
+ VimRegisterInfo vimRegisterInfo = new VimRegisterInfo();
+ int cloudRegionNum = cloudRegionList.getCloudRegion().size();
+ for (int i = 0; i < cloudRegionNum; i++) {
+ String cloudOwner = cloudRegionList.getCloudRegion().get(i).getCloudOwner();
+ String cloudRegionId = cloudRegionList.getCloudRegion().get(i).getCloudRegionId();
+ vimRegisterInfo = getVimDetail(cloudOwner, cloudRegionId);
+ vimRegisterInfos.add(vimRegisterInfo);
+ }
+ return vimRegisterInfos;
+ }
+
+ private VimRegisterInfo getVimDetail(String cloudOwner, String cloudRegionId) {
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
+ VimRegisterInfo registeredVimInfo = new VimRegisterInfo();
+ try {
+ String cloudRegionstr = CloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
+ cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
+ registeredVimInfo = VimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegionDetail);
+ } catch (Exception error) {
+ error.printStackTrace();
+ LOG.error("query VIM detail failed ! cloud-owner = " + cloudOwner + ", cloud-region-id = "
+ + cloudRegionId + error.getMessage());
+ }
+ return registeredVimInfo;
+ }
+
+ private CloudRegionDetail getOriginalCloudRegion(String cloudOwner, String cloudRegionId) {
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
+ try {
+ String cloudRegionstr = CloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
+ cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
+ return cloudRegionDetail;
+ } catch (Exception error) {
+ error.printStackTrace();
+ LOG.error("query VIM detail failed ! cloud-owner = " + cloudOwner + ", cloud-region-id = "
+ + cloudRegionId + error.getMessage());
+ return null;
+ }
}
- public Response delVim(String vimId) {
- //TODO
+ private CloudRegionDetail getVimUpdateInfo(VimRegisterInfo vimRegisterInfo) {
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
+ CloudRegionDetail originalCloudRegionDetail = new CloudRegionDetail();
+ EsrSystemInfo originalSystemInfo = new EsrSystemInfo();
+ String cloudOwner = vimRegisterInfo.getCloudOwner();
+ String cloudRegionId = vimRegisterInfo.getCloudRegionId();
+ originalCloudRegionDetail = getOriginalCloudRegion(cloudOwner, cloudRegionId);
+ String resourceVersion = originalCloudRegionDetail.getResourceVersion();
+ cloudRegionDetail = VimManagerUtil.vimRegisterInfo2CloudRegion(vimRegisterInfo);
+ if(resourceVersion != null) {
+ cloudRegionDetail.setResourceVersion(resourceVersion);
+ originalSystemInfo = originalCloudRegionDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0);
+ cloudRegionDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0).setEsrSystemInfoId(originalSystemInfo.getEsrSystemInfoId());
+ cloudRegionDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0).setResouceVersion(originalSystemInfo.getResouceVersion());
+ }
+ return cloudRegionDetail;
+ }
+
+ public Response delVim(String cloudOwner, String cloudRegionId) {
+ // TODO
return Response.noContent().build();
}
}