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;
20 import java.util.ArrayList;
21 import java.util.List;
23 import org.apache.http.HttpStatus;
24 import org.apache.logging.log4j.LogManager;
25 import org.apache.logging.log4j.Logger;
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.CBAMOperExecutVnfRequest;
32 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryOperExecutionResponse;
33 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMQueryVnfResponse;
34 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
35 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfResponse;
36 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
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.bo.VnfmInfo;
42 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
43 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
44 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfResponse;
45 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
46 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfResponse;
47 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.OperStatusVnfResponse;
48 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.QueryVnfResponse;
49 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
50 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfResponse;
51 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
52 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfResponse;
53 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.entity.ResponseDescriptor;
54 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.entity.ResponseHistoryList;
55 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.inf.VnfmDriverMgmrInf;
56 import org.springframework.beans.factory.annotation.Autowired;
57 import org.springframework.stereotype.Component;
61 public class VnfmDriverMgmrIml implements VnfmDriverMgmrInf{
62 private static final Logger logger = LogManager.getLogger("VnfmDriverMgmrIml");
65 Driver2CbamRequestConverter requestConverter;
68 Cbam2DriverResponseConverter responseConverter;
71 private CbamMgmrInf cbamMgmr;
74 private CatalogMgmrInf catalogMgmr;
77 private NslcmMgmrInf nslcmMgmr;
80 private VnfmJobExecutionRepository jobDbManager;
82 public InstantiateVnfResponse instantiateVnf(InstantiateVnfRequest driverRequest, String vnfmId) throws VnfmDriverException {
83 InstantiateVnfResponse driverResponse;
85 //step 1: query vnfm info
86 VnfmInfo vnfmInfo = nslcmMgmr.queryVnfm(vnfmId);
88 if(vnfmInfo == null || vnfmId.equalsIgnoreCase(vnfmInfo.getVnfmId()))
90 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
94 CBAMCreateVnfRequest cbamRequest = requestConverter.createReqConvert(driverRequest);
95 CBAMCreateVnfResponse cbamResponse = cbamMgmr.createVnf(cbamRequest);
96 driverResponse = responseConverter.createRspConvert(cbamResponse);
98 String vnfInstanceId = driverResponse.getVnfInstanceId();
99 String jobId = driverResponse.getJobId();
100 continueInstantiateVnf(driverRequest, vnfInstanceId, jobId);
103 } catch (Exception e) {
104 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
107 return driverResponse;
110 public void continueInstantiateVnf(InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId) {
111 InstantiateVnfContinueRunnable runnable = new InstantiateVnfContinueRunnable(driverRequest, vnfInstanceId, jobId,
112 nslcmMgmr, catalogMgmr, cbamMgmr, requestConverter, jobDbManager);
114 Thread thread = new Thread(runnable);
119 public TerminateVnfResponse terminateVnf(TerminateVnfRequest driverRequest, String vnfmId, String vnfInstanceId) {
120 TerminateVnfResponse driverResponse;
122 VnfmInfo vnfmInfo = nslcmMgmr.queryVnfm(vnfmId);
124 if(vnfmInfo == null || vnfmId.equalsIgnoreCase(vnfmInfo.getVnfmId()))
126 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
128 driverResponse = generateTerminateVnfResponse(vnfInstanceId);
129 String jobId = driverResponse.getJobId();
130 continueTerminateVnf(driverRequest, vnfInstanceId, jobId);
132 } catch (Exception e) {
133 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
136 return driverResponse;
139 private TerminateVnfResponse generateTerminateVnfResponse(String vnfInstanceId) {
140 VnfmJobExecutionInfo jobInfo = new VnfmJobExecutionInfo();
141 jobInfo.setVnfInstanceId(vnfInstanceId);
142 jobInfo.setVnfmInterfceName(CommonConstants.NSLCM_OPERATION_TERMINATE);
143 jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_START);
145 VnfmJobExecutionInfo jobInfo1= jobDbManager.save(jobInfo);
146 Long jobId = jobInfo1.getJobId();
148 TerminateVnfResponse response = new TerminateVnfResponse();
149 response.setJobId("" + jobId);
153 public void continueTerminateVnf(TerminateVnfRequest driverRequest, String vnfInstanceId, String jobId) {
154 TerminateVnfContinueRunnable runnable = new TerminateVnfContinueRunnable(driverRequest, vnfInstanceId, jobId,
155 nslcmMgmr, cbamMgmr, requestConverter, jobDbManager);
157 Thread thread = new Thread(runnable);
163 public QueryVnfResponse queryVnf(String vnfmId, String vnfInstanceId) {
164 QueryVnfResponse driverResponse;
166 nslcmMgmr.queryVnfm(vnfmId);
167 VnfmInfo vnfmInfo = nslcmMgmr.queryVnfm(vnfmId);
169 if(vnfmInfo == null || vnfmId.equalsIgnoreCase(vnfmInfo.getVnfmId()))
171 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
173 CBAMQueryVnfResponse cbamResponse = cbamMgmr.queryVnf(vnfInstanceId);
174 driverResponse = responseConverter.queryRspConvert(cbamResponse);
175 } catch (Exception e) {
176 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
179 return driverResponse;
182 public OperStatusVnfResponse getOperStatus(String vnfmId, String jobId) throws VnfmDriverException {
185 vnfmInfo = nslcmMgmr.queryVnfm(vnfmId);
186 } catch (Exception e) {
187 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
190 if(vnfmInfo == null || vnfmId.equalsIgnoreCase(vnfmInfo.getVnfmId()))
192 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
195 VnfmJobExecutionInfo jobInfo = jobDbManager.findOne(Long.getLong(jobId));
196 String execId = jobInfo.getVnfmExecutionId();
198 CBAMQueryOperExecutionResponse cbamResponse;
201 cbamResponse = cbamMgmr.queryOperExecution(execId);
202 } catch (Exception e) {
203 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
206 OperStatusVnfResponse response = responseConverter.operRspConvert(cbamResponse);
211 public ScaleVnfResponse scaleVnf(ScaleVnfRequest driverRequest, String vnfmId, String vnfInstanceId) throws VnfmDriverException {
212 ScaleVnfResponse driverResponse;
214 VnfmInfo vnfmInfo = nslcmMgmr.queryVnfm(vnfmId);
216 if(vnfmInfo == null || vnfmId.equalsIgnoreCase(vnfmInfo.getVnfmId()))
218 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
220 CBAMScaleVnfRequest cbamRequest = requestConverter.scaleReqconvert(driverRequest);
221 CBAMScaleVnfResponse cbamResponse = cbamMgmr.scaleVnf(cbamRequest, vnfInstanceId);
222 driverResponse = responseConverter.scaleRspConvert(cbamResponse);
223 } catch (Exception e) {
224 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
227 return driverResponse;
230 public HealVnfResponse healVnf(HealVnfRequest driverRequest, String vnfmId, String vnfInstanceId) throws VnfmDriverException {
231 HealVnfResponse driverResponse;
233 VnfmInfo vnfmInfo = nslcmMgmr.queryVnfm(vnfmId);
235 if(vnfmInfo == null || vnfmId.equalsIgnoreCase(vnfmInfo.getVnfmId()))
237 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
239 CBAMHealVnfRequest cbamRequest = requestConverter.healReqConvert(driverRequest);
240 CBAMHealVnfResponse cbamResponse = cbamMgmr.healVnf(cbamRequest, vnfInstanceId);
241 driverResponse = responseConverter.healRspConvert(cbamResponse);
242 } catch (Exception e) {
243 throw new VnfmDriverException(HttpStatus.SC_INTERNAL_SERVER_ERROR, CommonConstants.HTTP_ERROR_DESC_500);
246 return driverResponse;