2  * ============LICENSE_START=======================================================
 
   4  * ================================================================================
 
   5  * Copyright (C) 2018 Nokia. All rights reserved.
 
   6  * =============================================================================
 
   7  * Licensed under the Apache License, Version 2.0 (the "License");
 
   8  * you may not use this file except in compliance with the License.
 
   9  * You may obtain a copy of the License at
 
  11  *      http://www.apache.org/licenses/LICENSE-2.0
 
  13  * Unless required by applicable law or agreed to in writing, software
 
  14  * distributed under the License is distributed on an "AS IS" BASIS,
 
  15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  16  * See the License for the specific language governing permissions and
 
  17  * limitations under the License.
 
  18  * ============LICENSE_END=========================================================
 
  20 package org.onap.appc.flow.controller.node;
 
  22 import com.att.eelf.configuration.EELFLogger;
 
  23 import com.att.eelf.configuration.EELFManager;
 
  24 import org.apache.commons.lang3.StringUtils;
 
  25 import org.onap.appc.flow.controller.interfaceData.InventoryInfo;
 
  26 import org.onap.appc.flow.controller.interfaceData.Vm;
 
  27 import org.onap.appc.flow.controller.interfaceData.VnfInfo;
 
  28 import org.onap.appc.flow.controller.interfaceData.Vnfcslist;
 
  29 import org.onap.ccsdk.sli.core.sli.SvcLogicContext;
 
  32  * Helper class for FlowControlNode
 
  34 class InventoryInfoExtractor {
 
  36   private static final EELFLogger log = EELFManager.getInstance().getLogger(InventoryInfoExtractor.class);
 
  38   InventoryInfo getInventoryInfo(SvcLogicContext ctx, String vnfId) {
 
  39     String fn = "InventoryInfoExtractor.getInventoryInfo";
 
  41     VnfInfo vnfInfo = new VnfInfo();
 
  42     vnfInfo.setVnfId(vnfId);
 
  43     vnfInfo.setVnfName(ctx.getAttribute("tmp.vnfInfo.vnf.vnf-name"));
 
  44     vnfInfo.setVnfType(ctx.getAttribute("tmp.vnfInfo.vnf.vnf-type"));
 
  46     String vmcount = ctx.getAttribute("tmp.vnfInfo.vm-count");
 
  47     log.info(fn + "vmcount:" + vmcount);
 
  49     int vmCount = (StringUtils.isNotBlank(vmcount)) ? Integer.parseInt(vmcount) : 0;
 
  51     for (int i = 0; i < vmCount; i++) {
 
  52       processVm(ctx, vnfInfo, i);
 
  55     InventoryInfo inventoryInfo = new InventoryInfo();
 
  56     inventoryInfo.setVnfInfo(vnfInfo);
 
  57     log.info(fn + "Inventory Output:" + inventoryInfo.toString());
 
  62   private void processVm(SvcLogicContext ctx, VnfInfo vnfInfo, int index) {
 
  64     vm.setVserverId(ctx.getAttribute("tmp.vnfInfo.vm[" + index + "].vserver-id"));
 
  65     int vnfcCount = Integer.parseInt(ctx.getAttribute("tmp.vnfInfo.vm[" + index + "].vnfc-count"));
 
  67       Vnfcslist vnfc = new Vnfcslist();
 
  68       vnfc.setVnfcName(ctx.getAttribute("tmp.vnfInfo.vm[" + index + "].vnfc-name"));
 
  69       vnfc.setVnfcType(ctx.getAttribute("tmp.vnfInfo.vm[" + index + "].vnfc-type"));
 
  72     vnfInfo.getVm().add(vm);