- }
-
- 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 queryVimById(String cloudOwner, String cloudRegionId) {
- VimRegisterInfo vim = new VimRegisterInfo();
- CloudRegion cloudRegion = new CloudRegion();
- 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);
- return Response.ok(vim).build();
- } catch (Exception e) {
- e.printStackTrace();
- return Response.serverError().build();
+
+ public Response queryVimById(String cloudOwner, String cloudRegionId) {
+ VimRegisterInfo vim = new VimRegisterInfo();
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
+ try {
+ String cloudRegionstr = cloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
+ LOG.info("Response from AAI by query VIM: " + cloudRegionstr);
+ cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
+ vim = vimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegionDetail);
+ return Response.ok(vim).build();
+ } catch (ExtsysException e) {
+ LOG.error("Query vim details by ID failed !", e);
+ return Response.ok(vim).build();
+ }
+
+ }
+
+ private List<VimRegisterInfo> getVimDetailList(CloudRegionList cloudRegionList) {
+ List<VimRegisterInfo> vimRegisterInfos = new ArrayList<>();
+ 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 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 (ExtsysException error) {
+ LOG.error("query VIM detail failed ! cloud-owner = " + cloudOwner + ", cloud-region-id = " + cloudRegionId,
+ error);
+ }
+ 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 (ExtsysException error) {
+ LOG.error("query VIM detail failed ! cloud-owner = " + cloudOwner + ", cloud-region-id = " + cloudRegionId,
+ error);
+ return null;
+ }
+ }
+
+ private CloudRegionDetail getVimUpdateInfo(VimRegisterInfo vimRegisterInfo) {
+ String cloudOwner = vimRegisterInfo.getCloudOwner();
+ String cloudRegionId = vimRegisterInfo.getCloudRegionId();
+ CloudRegionDetail originalCloudRegionDetail = getOriginalCloudRegion(cloudOwner, cloudRegionId);
+ String resourceVersion = originalCloudRegionDetail.getResourceVersion();
+ CloudRegionDetail cloudRegionDetail = vimManagerUtil.vimRegisterInfo2CloudRegion(vimRegisterInfo);
+ if (resourceVersion != null) {
+ cloudRegionDetail.setResourceVersion(resourceVersion);
+ EsrSystemInfo 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) {
+ CloudRegionDetail cloudRegionDetail = queryCloudRegionDetail(cloudOwner, cloudRegionId);
+ String resourceVersion = cloudRegionDetail.getResourceVersion();
+ try {
+ cloudRegionProxy.deleteVim(cloudOwner, cloudRegionId, resourceVersion);
+ return Response.noContent().build();
+ } catch (ExtsysException e) {
+ LOG.error("Delete cloud region from A&AI failed! cloud-owner = " + cloudOwner + ", cloud-region-id = "
+ + cloudRegionId + "resouce-version:" + resourceVersion, e);
+ throw ExceptionUtil.buildExceptionResponse(e.getMessage());
+ }
+ }
+
+ private CloudRegionDetail queryCloudRegionDetail(String cloudOwner, String cloudRegionId) {
+ CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
+ try {
+ String cloudRegionStr = cloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
+ LOG.info("Response from AAI by query cloud region: " + cloudRegionStr);
+ cloudRegionDetail = new Gson().fromJson(cloudRegionStr, CloudRegionDetail.class);
+ } catch (ExtsysException e) {
+ LOG.error("Query EMS detail failed! cloud-owner = " + cloudOwner + ", cloud-region-id = " + cloudRegionId,
+ e);
+ throw ExceptionUtil.buildExceptionResponse(e.getMessage());
+ }
+ return cloudRegionDetail;