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;
20 import java.io.IOException;
21 import java.util.ArrayList;
22 import java.util.List;
23 import java.util.concurrent.Executors;
25 import org.apache.http.client.ClientProtocolException;
26 import org.onap.vfc.nfvo.driver.vnfm.svnfm.catalog.bo.entity.VnfPackageInfo;
27 import org.onap.vfc.nfvo.driver.vnfm.svnfm.catalog.inf.CatalogMgmrInf;
28 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfRequest;
29 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfResponse;
30 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.inf.CbamMgmrInf;
31 import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonConstants;
32 import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
33 import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum.LifecycleOperation;
34 import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.bean.VnfmJobExecutionInfo;
35 import org.onap.vfc.nfvo.driver.vnfm.svnfm.db.repository.VnfmJobExecutionRepository;
36 import org.onap.vfc.nfvo.driver.vnfm.svnfm.http.client.HttpClientProcessorImpl;
37 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfRequest;
38 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
39 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmNotifyLCMEventsRequest;
40 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.ResourceDefinition;
41 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.inf.NslcmMgmrInf;
42 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
43 import org.slf4j.Logger;
44 import org.slf4j.LoggerFactory;
45 import org.zeroturnaround.zip.ZipUtil;
48 public class InstantiateVnfContinueRunnable implements Runnable {
49 private static final Logger logger = LoggerFactory.getLogger(InstantiateVnfContinueRunnable.class);
50 private CbamMgmrInf cbamMgmr;
51 private CatalogMgmrInf catalogMgmr;
52 private NslcmMgmrInf nslcmMgmr;
54 private InstantiateVnfRequest driverRequest;
55 private String vnfInstanceId;
58 private VnfmJobExecutionRepository jobDbMgmr;
60 private Driver2CbamRequestConverter requestConverter;
62 public InstantiateVnfContinueRunnable(InstantiateVnfRequest driverRequest, String vnfInstanceId, String jobId,
63 NslcmMgmrInf nslcmMgmr, CatalogMgmrInf catalogMgmr, CbamMgmrInf cbamMgmr, Driver2CbamRequestConverter requestConverter, VnfmJobExecutionRepository dbManager)
65 this.driverRequest = driverRequest;
66 this.vnfInstanceId = vnfInstanceId;
68 this.nslcmMgmr = nslcmMgmr;
69 this.catalogMgmr = catalogMgmr;
70 this.cbamMgmr = cbamMgmr;
71 this.requestConverter = requestConverter;
72 this.jobDbMgmr = dbManager;
77 //step 1 handle vnf package
80 NslcmGrantVnfRequest grantRequest = buildNslcmGrantVnfRequest();
81 NslcmGrantVnfResponse grantResponse = nslcmMgmr.grantVnf(grantRequest);
83 //step 5: instantiate vnf
84 CBAMInstantiateVnfRequest instantiateReq = requestConverter.InstantiateReqConvert(driverRequest, grantResponse, null, null);
85 CBAMInstantiateVnfResponse cbamInstantiateResponse = cbamMgmr.instantiateVnf(instantiateReq, vnfInstanceId);
86 handleCbamInstantiateResponse(cbamInstantiateResponse, jobId);
88 NslcmNotifyLCMEventsRequest nslcmNotifyReq = buildNslcmNotifyLCMEventsRequest(cbamInstantiateResponse);
89 nslcmMgmr.notifyVnf(nslcmNotifyReq, vnfInstanceId);
91 } catch (ClientProtocolException e) {
92 logger.error("InstantiateVnfContinueRunnable run error ClientProtocolException", e);
93 } catch (IOException e) {
94 logger.error("InstantiateVnfContinueRunnable run error IOException", e);
99 private void handleVnfPackage() {
100 Executors.newSingleThreadExecutor().execute(new Runnable() {
104 //step 1: query vnfPackage uri -- download package -- extract it -- upload CBAM package to CBAM
105 VnfPackageInfo vnfPackageInfo = catalogMgmr.queryVnfPackage(driverRequest.getVnfPackageId());
106 String packageUrl = vnfPackageInfo.getDownloadUri();
107 String saveDir = "/service/vnfPackage";
108 String packageFileName = packageUrl.substring(packageUrl.lastIndexOf("/"));
109 Process process = Runtime.getRuntime().exec("mkdir -p " + saveDir);
112 if (HttpClientProcessorImpl.downLoadFromUrl(packageUrl, packageFileName, saveDir)) {
113 File csarFile = new File(saveDir + "/" + packageFileName);
115 ZipUtil.explode(csarFile);
117 String cbamPackageDirName = saveDir + "/" + packageFileName + "/Artifacts";
118 String cbamPackageName = new File(cbamPackageDirName).list()[0];
119 cbamMgmr.uploadVnfPackage(cbamPackageName);
121 } catch (Exception e) {
122 logger.error("Error to handleVnfPackage", e);
129 private NslcmNotifyLCMEventsRequest buildNslcmNotifyLCMEventsRequest(CBAMInstantiateVnfResponse cbamInstantiateResponse) {
130 NslcmNotifyLCMEventsRequest request = new NslcmNotifyLCMEventsRequest();
131 if(CommonEnum.OperationStatus.STARTED == cbamInstantiateResponse.getStatus())
133 request.setStatus(CommonEnum.status.start);
137 request.setStatus(CommonEnum.status.result);
139 //TODO the following are for the result
140 // request.setAffectedVnfc(affectedVnfc);
141 // request.setAffectedVI(affectedVI);
142 // request.setAffectedVirtualStorage(affectedVirtualStorage);
145 request.setVnfInstanceId(vnfInstanceId);
146 request.setOperation(CommonConstants.NSLCM_OPERATION_INSTANTIATE);
147 request.setJobId(jobId);
151 private NslcmGrantVnfRequest buildNslcmGrantVnfRequest() {
152 NslcmGrantVnfRequest request = new NslcmGrantVnfRequest();
154 request.setVnfInstanceId(vnfInstanceId);
155 request.setLifecycleOperation(LifecycleOperation.Instantiate);
156 request.setJobId(jobId);
158 ResourceDefinition resource = getFreeVnfResource();
159 List<ResourceDefinition> resourceList = new ArrayList<ResourceDefinition>();
160 resourceList.add(resource);
161 request.setAddResource(resourceList);
166 private ResourceDefinition getFreeVnfResource() {
167 // TODO Auto-generated method stub
171 private void handleCbamInstantiateResponse(CBAMInstantiateVnfResponse cbamInstantiateResponse, String jobId) {
172 VnfmJobExecutionInfo jobInfo = jobDbMgmr.findOne(Long.getLong(jobId));
174 jobInfo.setVnfmExecutionId(cbamInstantiateResponse.getId());
175 if(CommonEnum.OperationStatus.FAILED == cbamInstantiateResponse.getStatus()){
176 jobInfo.setStatus(CommonConstants.CBAM_OPERATION_STATUS_ERROR);
178 jobDbMgmr.save(jobInfo);
181 public static void main(String[] argv) {
182 String saveDir = "D:/tmp/20170926/data";
183 String packageFileName = "vCSCF_v3.0.csar";
184 File csarFile = new File(saveDir + "/" + packageFileName);
185 ZipUtil.explode(csarFile);
187 String cbamPackageDirName = saveDir + "/" + packageFileName + "/Artifacts";
188 String cbamPackageName = new File(cbamPackageDirName).list()[0];
189 System.out.println(cbamPackageName);