Merge "Method handling nokia-vnfmdriver"
[vfc/nfvo/driver/vnfm/svnfm.git] / nokia / vnfmdriver / vfcadaptorservice / vfcadaptor / src / main / java / org / onap / vfc / nfvo / driver / vnfm / svnfm / adaptor / Driver2CbamRequestConverter.java
index 2e05e1a..cb783c4 100644 (file)
 
 package org.onap.vfc.nfvo.driver.vnfm.svnfm.adaptor;
 
-import java.util.ArrayList;
-import java.util.List;
+import java.io.BufferedInputStream;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.IOException;
+import java.io.InputStream;
 
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMCreateVnfRequest;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMHealVnfRequest;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMInstantiateVnfRequest;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMScaleVnfRequest;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.CBAMTerminateVnfRequest;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.EndpointInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.ExtVirtualLinkData;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OpenStackAccessInfoV3;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.OpenstackV3Info;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VimInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.cbam.bo.entity.VnfExtCpData;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.CommonEnum;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.common.util.CommonUtil;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleDirection;
+import org.onap.vfc.nfvo.driver.vnfm.svnfm.constant.ScaleType;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.NslcmGrantVnfResponse;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.AccessInfo;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.GrantInfo;
-import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.NslcmVimInfo;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.nslcm.bo.entity.VimComputeResourceFlavour;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.HealVnfRequest;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.InstantiateVnfRequest;
@@ -42,65 +39,41 @@ import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.ScaleVnfRequest;
 import org.onap.vfc.nfvo.driver.vnfm.svnfm.vnfmdriver.bo.TerminateVnfRequest;
 import org.springframework.stereotype.Component;
 
+import com.google.gson.Gson;
+
 @Component
 public class Driver2CbamRequestConverter {
-       
+
        public CBAMCreateVnfRequest createReqConvert(InstantiateVnfRequest driverRequest) {
                CBAMCreateVnfRequest request = new CBAMCreateVnfRequest();
 
-               request.setVnfdId(driverRequest.getVnfDescriptorId());
+               request.setVnfdId(driverRequest.getVnfdId());
                request.setName(driverRequest.getVnfInstanceName());
                request.setDescription(driverRequest.getVnfInstanceDescription());
                return request;
        }
 
-       public CBAMInstantiateVnfRequest InstantiateReqConvert(InstantiateVnfRequest driverRequest,
-                       NslcmGrantVnfResponse nslc, GrantInfo grant, VimComputeResourceFlavour vimco) {
-               CBAMInstantiateVnfRequest request = new CBAMInstantiateVnfRequest();
-               List<VimInfo> vims = new ArrayList<VimInfo>();
-               VimInfo vim = new VimInfo();
-               EndpointInfo inter = new EndpointInfo();
-               OpenstackV3Info openstackV3 = new OpenstackV3Info();
-               List<NslcmVimInfo>  nslcmVim=nslc.getVim();
-               for(int i=0;i<=nslcmVim.size();i++) {
-               vim.setId(nslcmVim.get(i).getVimInfoId());
-               openstackV3.setId(nslcmVim.get(i).getVimId());
-               inter.setEndpoint(nslcmVim.get(i).getInterfaceEndpoint());
-               openstackV3.setInterfaceInfo(inter);
-               OpenStackAccessInfoV3 v3 = new OpenStackAccessInfoV3();
-               List<AccessInfo> accessInfo=nslcmVim.get(i).getAccessInfo();
-               for(int j=0;j<=accessInfo.size();j++) {
-               v3.setUsername(accessInfo.get(j).getUsername());
-               v3.setPassword(accessInfo.get(j).getPassword());
-               }
-               openstackV3.setAccessInfo(v3);
-               }
-               
-               vims.add(vim);
-               List<ExtVirtualLinkData> list = new ArrayList<ExtVirtualLinkData>();
-               ExtVirtualLinkData ext = new ExtVirtualLinkData();
+       public CBAMInstantiateVnfRequest instantiateRequestConvert(InstantiateVnfRequest driverRequest,
+                       NslcmGrantVnfResponse nslc, GrantInfo grant, VimComputeResourceFlavour vimco) throws IOException {
+        Gson gson = new Gson();
+               String inputJson = readcbamInputInfoFromJsonFile();
+               return gson.fromJson(inputJson, CBAMInstantiateVnfRequest.class);
+       }
 
-               ext.setResourceId(grant.getResourceDefinitionId());
-               ext.setVimId(grant.getVimId());
-               List<VnfExtCpData> cps = new ArrayList<VnfExtCpData>();
-               VnfExtCpData cp = new VnfExtCpData();
-               cp.setCpdId(vimco.getVduId());
-               ext.setExtCps(cps);
-               request.setVims(vims);
-               request.setFlavourId(driverRequest.getFlavourId());
-               request.setExtVirtualLinks(list);
-               // resquest.setVnfInstanceId(driverRequest.getExtVirtualLink().get(0).getVlInstanceId());
-               return request;
+       private String readcbamInputInfoFromJsonFile() throws IOException {
+               String filePath = "/etc/vnfpkginfo/cbam_input.json";
+               return CommonUtil.getJsonStrFromFile(filePath);
        }
 
        public CBAMTerminateVnfRequest terminateReqConvert(TerminateVnfRequest driverRequest) {
                CBAMTerminateVnfRequest request = new CBAMTerminateVnfRequest();
-               request.setTerminationType(driverRequest.getTerminationType());
+//             request.setTerminationType(driverRequest.getTerminationType().toUpperCase());
+               request.setTerminationType("FORCEFUL");
                request.setGracefulTerminationTimeout(driverRequest.getGracefulTerminationTimeout());
                return request;
        }
 
-       public CBAMHealVnfRequest healReqConvert(HealVnfRequest driverRequest) {
+       public CBAMHealVnfRequest healReqConvert() {
                CBAMHealVnfRequest request = new CBAMHealVnfRequest();
                request.setCause("");
                request.setAdditionalParams("");
@@ -109,15 +82,51 @@ public class Driver2CbamRequestConverter {
 
        public CBAMScaleVnfRequest scaleReqconvert(ScaleVnfRequest driverRequest) {
                CBAMScaleVnfRequest request = new CBAMScaleVnfRequest();
-               if (driverRequest.getType().equals("SCALE_OUT")) {
-                       request.setType(CommonEnum.ScaleDirection.OUT);
+               if (driverRequest.getType().equals(ScaleType.SCALE_OUT)) {
+                       request.setType(ScaleDirection.OUT);
                } else {
-                       request.setType(CommonEnum.ScaleDirection.IN);
+                       request.setType(ScaleDirection.IN);
                }
                request.setAspectId(driverRequest.getAspectId());
                request.setNumberOfSteps(driverRequest.getNumberOfSteps());
                request.setAdditionalParams(driverRequest.getAdditionalParam());
                return request;
        }
-
+       
+//     public static void main(String[] argv) throws IOException {
+//             Gson gson = new Gson();
+//             String filePath = "D:\\cbam_input.json";
+//             String inputJson = readcbamInputInfo(filePath);
+//             CBAMInstantiateVnfRequest request = gson.fromJson(inputJson, CBAMInstantiateVnfRequest.class);
+//             System.out.println(gson.toJson(request));
+//     }
+//     
+//     public static String readcbamInputInfo(String filePath) throws IOException {
+//             InputStream ins = null;
+//        BufferedInputStream bins = null;
+//        String fileContent = "";
+//        String fileName = filePath;
+//
+//        try {
+//            ins = new FileInputStream(fileName);
+//            bins = new BufferedInputStream(ins);
+//
+//            byte[] contentByte = new byte[ins.available()];
+//            int num = bins.read(contentByte);
+//
+//            if(num > 0) {
+//                fileContent = new String(contentByte);
+//            }
+//        } catch(FileNotFoundException e) {
+//             e.printStackTrace();;
+//        } finally {
+//            if(ins != null) {
+//                ins.close();
+//            }
+//            if(bins != null) {
+//                bins.close();
+//            }
+//        }
+//             return fileContent;
+//     }
 }