2 * Copyright 2016-2017, Nokia Corporation
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
19 import java.io.IOException;
21 import org.apache.http.HttpStatus;
22 import org.apache.http.client.ClientProtocolException;
23 import org.onap.vfc.nfvo.driver.vnfm.svnfm.aai.bo.AaiVnfmInfo;
24 import org.onap.vfc.nfvo.driver.vnfm.svnfm.aai.bo.entity.EsrSystemInfo;
25 import org.onap.vfc.nfvo.driver.vnfm.svnfm.aai.inf.AaiMgmrInf;
26 import org.onap.vfc.nfvo.driver.vnfm.svnfm.catalog.inf.CatalogMgmrInf;
27 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfRequest;
28 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfResponse;
29 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
30 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfResponse;
31 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryOperExecutionResponse;
32 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryVnfResponse;
33 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
34 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
35 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
36 import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.bo.AdaptorEnv;
37 import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
38 import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
39 import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
40 import org.onap.vfc.nfvo.driver.vnfm.svnfm.exception.VnfmDriverException;
41 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
42 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
43 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfResponse;
44 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
45 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfResponse;
46 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.OperStatusVnfResponse;
47 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.QueryVnfResponse;
48 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
49 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfResponse;
50 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
51 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfResponse;
52 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.inf.VnfContinueProcessorInf;
53 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.inf.VnfmDriverMgmrInf;
54 import org.slf4j.Logger;
55 import org.slf4j.LoggerFactory;
56 import org.springframework.beans.factory.annotation.Autowired;
57 import org.springframework.stereotype.Component;
59 import com.google.gson.Gson;
63 public class VnfmDriverMgmrImpl implements VnfmDriverMgmrInf{
64 private static final Logger logger = LoggerFactory.getLogger(VnfmDriverMgmrImpl.class);
67 Driver2CbamRequestConverter requestConverter;
70 Cbam2DriverResponseConverter responseConverter;
73 private CbamMgmrInf cbamMgmr;
76 private CatalogMgmrInf catalogMgmr;
79 private NslcmMgmrInf nslcmMgmr;
82 private AaiMgmrInf aaiMgmr;
85 private VnfmJobExecutionRepository jobDbManager;
88 AdaptorEnv adaptorEnv;
91 private VnfContinueProcessorInf vnfContinueProcessorInf;
93 private Gson gson = new Gson();
95 public InstantiateVnfResponse instantiateVnf(InstantiateVnfRequest driverRequest, String vnfmId) throws VnfmDriverException {
96 InstantiateVnfResponse driverResponse;
98 buildVnfmHttpPathById(vnfmId);
101 CBAMCreateVnfRequest cbamRequest = requestConverter.createReqConvert(driverRequest);
102 CBAMCreateVnfResponse cbamResponse = cbamMgmr.createVnf(cbamRequest);
103 String vnfInstanceId = cbamResponse.getId();
105 Long jobId = saveCreateVnfJob(vnfInstanceId);
106 driverResponse = responseConverter.createRspConvert(cbamResponse, jobId);
108 vnfContinueProcessorInf.continueInstantiateVnf(driverRequest, vnfInstanceId, jobId.toString(), nslcmMgmr, catalogMgmr, cbamMgmr, requestConverter, jobDbManager);
110 } catch (Exception e) {
111 logger.error("error VnfmDriverMgmrImpl --> instantiateVnf. ", e);
112 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
115 return driverResponse;
118 private Long saveCreateVnfJob(String vnfInstanceId) {
119 VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
120 jobInfo.setVnfInstanceId(vnfInstanceId);
121 jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_INSTANTIATE);
122 jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
124 VnfmJobExecutionInfo jobInfo1 = (VnfmJobExecutionInfo) jobDbManager.save(jobInfo);
125 Long jobId = jobInfo1.getJobId();
129 public TerminateVnfResponse terminateVnf(TerminateVnfRequest driverRequest, String vnfmId, String vnfInstanceId) {
130 TerminateVnfResponse driverResponse;
132 buildVnfmHttpPathById(vnfmId);
133 driverResponse = generateTerminateVnfResponse(vnfInstanceId);
134 String jobId = driverResponse.getJobId();
135 vnfContinueProcessorInf.continueTerminateVnf(driverRequest, vnfInstanceId, jobId, nslcmMgmr, cbamMgmr, requestConverter, jobDbManager);
137 } catch (Exception e) {
138 logger.error("error VnfmDriverMgmrImpl --> terminateVnf. ", e);
139 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
142 return driverResponse;
145 private TerminateVnfResponse generateTerminateVnfResponse(String vnfInstanceId) {
146 VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
147 jobInfo.setVnfInstanceId(vnfInstanceId);
148 jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_TERMINATE);
149 jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
151 VnfmJobExecutionInfo jobInfo1= jobDbManager.save(jobInfo);
152 Long jobId = jobInfo1.getJobId();
154 TerminateVnfResponse response = new TerminateVnfResponse();
155 response.setJobId("" + jobId);
159 public QueryVnfResponse queryVnf(String vnfmId, String vnfInstanceId) {
160 QueryVnfResponse driverResponse;
162 buildVnfmHttpPathById(vnfmId);
163 CBAMQueryVnfResponse cbamResponse = cbamMgmr.queryVnf(vnfInstanceId);
164 driverResponse = responseConverter.queryRspConvert(cbamResponse);
165 } catch (Exception e) {
166 logger.error("error VnfmDriverMgmrImpl --> queryVnf. ", e);
167 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
170 return driverResponse;
173 public OperStatusVnfResponse getOperStatus(String vnfmId, String jobId) throws VnfmDriverException {
175 CBAMQueryOperExecutionResponse cbamResponse;
178 buildVnfmHttpPathById(vnfmId);
180 VnfmJobExecutionInfo jobInfo = jobDbManager.findOne(Long.getLong(jobId));
181 String execId = jobInfo.getVnfmExecutionId();
182 cbamResponse = cbamMgmr.queryOperExecution(execId);
183 } catch (Exception e) {
184 logger.error("error VnfmDriverMgmrImpl --> getOperStatus. ", e);
185 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
188 OperStatusVnfResponse response = responseConverter.operRspConvert(cbamResponse);
193 public ScaleVnfResponse scaleVnf(ScaleVnfRequest driverRequest, String vnfmId, String vnfInstanceId) throws VnfmDriverException {
194 ScaleVnfResponse driverResponse;
196 buildVnfmHttpPathById(vnfmId);
197 CBAMScaleVnfRequest cbamRequest = requestConverter.scaleReqconvert(driverRequest);
198 CBAMScaleVnfResponse cbamResponse = cbamMgmr.scaleVnf(cbamRequest, vnfInstanceId);
199 driverResponse = responseConverter.scaleRspConvert(cbamResponse);
200 } catch (Exception e) {
201 logger.error("error VnfmDriverMgmrImpl --> scaleVnf. ", e);
202 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
205 return driverResponse;
208 public HealVnfResponse healVnf(HealVnfRequest driverRequest, String vnfmId, String vnfInstanceId) throws VnfmDriverException {
209 HealVnfResponse driverResponse;
211 buildVnfmHttpPathById(vnfmId);
212 CBAMHealVnfRequest cbamRequest = requestConverter.healReqConvert(driverRequest);
213 CBAMHealVnfResponse cbamResponse = cbamMgmr.healVnf(cbamRequest, vnfInstanceId);
214 driverResponse = responseConverter.healRspConvert(cbamResponse);
215 } catch (Exception e) {
216 logger.error("error VnfmDriverMgmrImpl --> healVnf. ", e);
217 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
220 return driverResponse;
223 public String buildVnfmHttpPathById(String vnfmId) throws ClientProtocolException, IOException, VnfmDriverException {
228 public String buildVnfmHttpPathByRealId(String vnfmId) throws ClientProtocolException, IOException, VnfmDriverException {
229 AaiVnfmInfo vnfmInfo = aaiMgmr.queryVnfm(vnfmId);
230 logger.info("vnfmInfo in AAI is {}", gson.toJson(vnfmInfo));
231 if(isVnfmInfoValid(vnfmId, vnfmInfo))
233 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
236 EsrSystemInfo systemInfo = vnfmInfo.getEsrSystemInfoList().get(0);
238 String urlHead = systemInfo.getServiceUrl();
239 adaptorEnv.setCbamApiUriFront(urlHead);
240 adaptorEnv.setCbamUserName(systemInfo.getUserName());
241 adaptorEnv.setCbamPassword(systemInfo.getPassword());
246 private boolean isVnfmInfoValid(String vnfmId, AaiVnfmInfo vnfmInfo) {
247 return vnfmInfo == null || vnfmInfo.getEsrSystemInfoList() == null || vnfmInfo.getEsrSystemInfoList().isEmpty();
250 public void setRequestConverter(Driver2CbamRequestConverter requestConverter) {
251 this.requestConverter = requestConverter;
254 public void setResponseConverter(Cbam2DriverResponseConverter responseConverter) {
255 this.responseConverter = responseConverter;