fa52166420ea0f1fc43206ca91405cf5eccf5c53
[aai/esr-server.git] / esr-mgr / src / main / java / org / onap / aai / esr / wrapper / VimManagerWrapper.java
1 /**
2  * Copyright 2017 ZTE Corporation.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package org.onap.aai.esr.wrapper;
17
18 import java.util.ArrayList;
19 import java.util.List;
20
21 import javax.ws.rs.core.Response;
22
23 import org.onap.aai.esr.entity.aai.CloudRegionDetail;
24 import org.onap.aai.esr.entity.aai.CloudRegionList;
25 import org.onap.aai.esr.entity.aai.EsrSystemInfo;
26 import org.onap.aai.esr.entity.rest.VimRegisterInfo;
27 import org.onap.aai.esr.entity.rest.VimRegisterResponse;
28 import org.onap.aai.esr.exception.ExceptionUtil;
29 import org.onap.aai.esr.exception.ExtsysException;
30 import org.onap.aai.esr.externalservice.aai.CloudRegionProxy;
31 import org.onap.aai.esr.externalservice.cloud.Tenant;
32 import org.onap.aai.esr.externalservice.cloud.VimManagerProxy;
33 import org.onap.aai.esr.util.ExtsysUtil;
34 import org.onap.aai.esr.util.VimManagerUtil;
35 import org.slf4j.Logger;
36 import org.slf4j.LoggerFactory;
37
38 import com.google.gson.Gson;
39
40 public class VimManagerWrapper {
41
42   private static VimManagerWrapper vimManagerWrapper;
43   private static final Logger LOG = LoggerFactory.getLogger(VimManagerWrapper.class);
44   
45   private static VimManagerUtil vimManagerUtil = new VimManagerUtil();
46   
47   private static CloudRegionProxy cloudRegionProxy = new CloudRegionProxy();
48   
49   private static ExtsysUtil extsysUtil = new ExtsysUtil();
50
51   /**
52    * get VimManagerWrapper instance.
53    * 
54    * @return vim manager wrapper instance
55    */
56   public static VimManagerWrapper getInstance() {
57     if (vimManagerWrapper == null) {
58       vimManagerWrapper = new VimManagerWrapper();
59     }
60     return vimManagerWrapper;
61
62   }
63
64   public Response registerVim(VimRegisterInfo vimRegisterInfo) {
65     LOG.info(
66         "Start register VIM, input VIM info is: " + extsysUtil.objectToString(vimRegisterInfo));
67     CloudRegionDetail cloudRegion = new CloudRegionDetail();
68     VimRegisterResponse result = new VimRegisterResponse();
69     cloudRegion = vimManagerUtil.vimRegisterInfo2CloudRegion(vimRegisterInfo);
70     String cloudOwner = vimRegisterInfo.getCloudOwner();
71     String cloudRegionId = vimRegisterInfo.getCloudRegionId();
72     try {
73       cloudRegionProxy.registerVim(cloudOwner, cloudRegionId, cloudRegion);
74       result.setCloudOwner(cloudOwner);
75       result.setCloudRegionId(cloudRegionId);
76       Tenant tenant = new Tenant();
77       tenant.setDefaultTenant(cloudRegion.getEsrSystemInfoList().getEsrSystemInfo().get(0).getDefaultTenant());
78       try {
79         VimManagerProxy.updateVim(cloudOwner, cloudRegionId, tenant);
80       } catch (ExtsysException e) {
81         LOG.error("Update VIM by Multi-cloud failed !", e);
82       }
83       return Response.ok(result).build();
84     } catch (ExtsysException error) {
85       LOG.error("Register VIM failed !", error);
86       throw ExceptionUtil.buildExceptionResponse(error.getMessage());
87     }
88   }
89
90   public Response updateVim(String cloudOwner, String cloudRegionId,VimRegisterInfo vimRegisterInfo) {
91     LOG.info("Start update VIM, input VIM info is: " + extsysUtil.objectToString(vimRegisterInfo));
92     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
93     VimRegisterResponse result = new VimRegisterResponse();
94
95     cloudRegionDetail = getVimUpdateInfo(vimRegisterInfo);
96     try {
97         cloudRegionProxy.registerVim(cloudOwner, cloudRegionId, cloudRegionDetail);
98       result.setCloudOwner(cloudOwner);
99       result.setCloudRegionId(cloudRegionId);
100       return Response.ok(result).build();
101     } catch (ExtsysException e) {
102       LOG.error("Update VIM failed !", e);
103       throw ExceptionUtil.buildExceptionResponse(e.getMessage());
104     }
105   }
106
107   public Response queryVimListDetails() {
108     List<VimRegisterInfo> vimRegisterInfos = new ArrayList<>();
109     CloudRegionList cloudRegionList = new CloudRegionList();
110     try {
111       String aaiVimList = cloudRegionProxy.qureyVimList();
112       cloudRegionList = new Gson().fromJson(aaiVimList, CloudRegionList.class);
113       vimRegisterInfos = getVimDetailList(cloudRegionList);
114       return Response.ok(vimRegisterInfos).build();
115     } catch (ExtsysException error) {
116       LOG.error("Query vim list details failed !", error);
117       return Response.ok(vimRegisterInfos).build();
118     }
119
120   }
121
122   public Response queryVimById(String cloudOwner, String cloudRegionId) {
123     VimRegisterInfo vim = new VimRegisterInfo();
124     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
125     try {
126       String cloudRegionstr = cloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
127       LOG.info("Response from AAI by query VIM: " + cloudRegionstr);
128       cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
129       vim = vimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegionDetail);
130       return Response.ok(vim).build();
131     } catch (ExtsysException e) {
132       LOG.error("Query vim details by ID failed !", e);
133       return Response.ok(vim).build();
134     }
135
136   }
137
138   private List<VimRegisterInfo> getVimDetailList(CloudRegionList cloudRegionList) {
139     List<VimRegisterInfo> vimRegisterInfos = new ArrayList<>();
140     VimRegisterInfo vimRegisterInfo = new VimRegisterInfo();
141     int cloudRegionNum = cloudRegionList.getCloudRegion().size();
142     for (int i = 0; i < cloudRegionNum; i++) {
143       String cloudOwner = cloudRegionList.getCloudRegion().get(i).getCloudOwner();
144       String cloudRegionId = cloudRegionList.getCloudRegion().get(i).getCloudRegionId();
145       vimRegisterInfo = getVimDetail(cloudOwner, cloudRegionId);
146       vimRegisterInfos.add(vimRegisterInfo);
147     }
148     return vimRegisterInfos;
149   }
150
151   private VimRegisterInfo getVimDetail(String cloudOwner, String cloudRegionId) {
152     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
153     VimRegisterInfo registeredVimInfo = new VimRegisterInfo();
154     try {
155       String cloudRegionstr = cloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
156       cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
157       registeredVimInfo = vimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegionDetail);
158     } catch (ExtsysException error) {
159       LOG.error("query VIM detail failed ! cloud-owner = " + cloudOwner + ", cloud-region-id = "
160           + cloudRegionId, error);
161     }
162     return registeredVimInfo;
163   }
164
165   private CloudRegionDetail getOriginalCloudRegion(String cloudOwner, String cloudRegionId) {
166     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
167     try {
168       String cloudRegionstr = cloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
169       cloudRegionDetail = new Gson().fromJson(cloudRegionstr, CloudRegionDetail.class);
170       return cloudRegionDetail;
171     } catch (ExtsysException error) {
172       LOG.error("query VIM detail failed ! cloud-owner = " + cloudOwner + ", cloud-region-id = "
173           + cloudRegionId, error);
174       return null;
175     }
176   }
177   
178   private CloudRegionDetail getVimUpdateInfo(VimRegisterInfo vimRegisterInfo) {
179     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
180     CloudRegionDetail originalCloudRegionDetail = new CloudRegionDetail();
181     EsrSystemInfo originalSystemInfo = new EsrSystemInfo();
182     String cloudOwner = vimRegisterInfo.getCloudOwner();
183     String cloudRegionId = vimRegisterInfo.getCloudRegionId();
184     originalCloudRegionDetail = getOriginalCloudRegion(cloudOwner, cloudRegionId);
185     String resourceVersion = originalCloudRegionDetail.getResourceVersion();
186     cloudRegionDetail = vimManagerUtil.vimRegisterInfo2CloudRegion(vimRegisterInfo);
187     if(resourceVersion != null) {
188       cloudRegionDetail.setResourceVersion(resourceVersion);
189       originalSystemInfo = originalCloudRegionDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0);
190       cloudRegionDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0).setEsrSystemInfoId(originalSystemInfo.getEsrSystemInfoId());
191       cloudRegionDetail.getEsrSystemInfoList().getEsrSystemInfo().get(0).setResouceVersion(originalSystemInfo.getResouceVersion());
192     }
193     return cloudRegionDetail;
194   }
195
196   public Response delVim(String cloudOwner, String cloudRegionId) {
197     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
198     cloudRegionDetail = queryCloudRegionDetail(cloudOwner, cloudRegionId);
199     String resourceVersion = cloudRegionDetail.getResourceVersion();
200     try {
201       cloudRegionProxy.deleteVim(cloudOwner, cloudRegionId, resourceVersion);
202       return Response.noContent().build();
203     } catch (ExtsysException e) {
204       LOG.error("Delete cloud region from A&AI failed! cloud-owner = " + cloudOwner
205           + ", cloud-region-id = " + cloudRegionId + "resouce-version:" + resourceVersion, e);
206       throw ExceptionUtil.buildExceptionResponse(e.getMessage());
207     }
208   }
209
210   private CloudRegionDetail queryCloudRegionDetail (String cloudOwner, String cloudRegionId) {
211     CloudRegionDetail cloudRegionDetail = new CloudRegionDetail();
212     try {
213       String cloudRegionStr = cloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
214       LOG.info("Response from AAI by query cloud region: " + cloudRegionStr);
215       cloudRegionDetail = new Gson().fromJson(cloudRegionStr, CloudRegionDetail.class);
216     } catch (ExtsysException e) {
217       LOG.error("Query EMS detail failed! cloud-owner = " + cloudOwner
218                 + ", cloud-region-id = " + cloudRegionId , e);
219       throw ExceptionUtil.buildExceptionResponse(e.getMessage());
220     }
221     return cloudRegionDetail;
222   }
223 }