aboutsummaryrefslogtreecommitdiffstats
path: root/openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java
diff options
context:
space:
mode:
Diffstat (limited to 'openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java')
-rw-r--r--openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java559
1 files changed, 256 insertions, 303 deletions
diff --git a/openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java b/openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java
index 5a18155f03..8fd2d090db 100644
--- a/openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java
+++ b/openecomp-be/lib/openecomp-sdc-tosca-generator-lib/openecomp-sdc-tosca-generator-core/src/main/java/org/openecomp/sdc/generator/core/services/ManualVspToscaGenerationService.java
@@ -13,7 +13,6 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-
package org.openecomp.sdc.generator.core.services;
import java.util.ArrayList;
@@ -53,344 +52,298 @@ import org.openecomp.sdc.vendorsoftwareproduct.types.composition.Nic;
*/
public class ManualVspToscaGenerationService {
- //Map of the abstract node template id and substitution node type
- private Map<String, String> abstractSubstitutionIdTypes = new HashMap<>();
- //Map of service template name and service template for the generated service templates
- private Map<String, ServiceTemplate> generatedServiceTemplates = new HashMap<>();
-
+ //Map of the abstract node template id and substitution node type
+ private Map<String, String> abstractSubstitutionIdTypes = new HashMap<>();
+ //Map of service template name and service template for the generated service templates
+ private Map<String, ServiceTemplate> generatedServiceTemplates = new HashMap<>();
+
+ /**
+ * Create manual vsp tosca service model tosca service model.
+ *
+ * @param vspModelInfo the vsp model info
+ * @return the tosca service model
+ */
+ public ToscaServiceModel createManualVspToscaServiceModel(VspModelInfo vspModelInfo) {
+ ToscaServiceModel toscaServiceModel = new ToscaServiceModel();
+ Map<String, ServiceTemplate> serviceTemplates = new HashMap<>(GlobalTypesGenerator.getGlobalTypesServiceTemplate(OnboardingTypesEnum.MANUAL));
+ toscaServiceModel.setServiceTemplates(serviceTemplates);
+ toscaServiceModel
+ .setEntryDefinitionServiceTemplate(Constants.MAIN_TEMPLATE_NAME + GeneratorConstants.TOSCA_SERVICE_TEMPLATE_FILE_NAME_SUFFIX);
+ createToscaFromVspData(vspModelInfo, toscaServiceModel);
+ for (Map.Entry<String, ServiceTemplate> serviceTemplateEntry : generatedServiceTemplates.entrySet()) {
+ ToscaUtil.addServiceTemplateToMapWithKeyFileName(serviceTemplates, serviceTemplateEntry.getValue());
+ }
+ return toscaServiceModel;
+ }
- /**
- * Create manual vsp tosca service model tosca service model.
- *
- * @param vspModelInfo the vsp model info
- * @return the tosca service model
- */
- public ToscaServiceModel createManualVspToscaServiceModel(VspModelInfo vspModelInfo) {
- ToscaServiceModel toscaServiceModel = new ToscaServiceModel();
- Map<String, ServiceTemplate> serviceTemplates = new HashMap<>(GlobalTypesGenerator
- .getGlobalTypesServiceTemplate(OnboardingTypesEnum.MANUAL));
- toscaServiceModel.setServiceTemplates(serviceTemplates);
- toscaServiceModel.setEntryDefinitionServiceTemplate(Constants.MAIN_TEMPLATE_NAME
- + GeneratorConstants.TOSCA_SERVICE_TEMPLATE_FILE_NAME_SUFFIX);
- createToscaFromVspData(vspModelInfo, toscaServiceModel);
- for (Map.Entry<String, ServiceTemplate> serviceTemplateEntry :
- generatedServiceTemplates.entrySet()) {
- ToscaUtil.addServiceTemplateToMapWithKeyFileName(serviceTemplates, serviceTemplateEntry
- .getValue());
+ private void createToscaFromVspData(VspModelInfo vspModelInfo, ToscaServiceModel toscaServiceModel) {
+ //Only one component supported
+ Optional<String> componentName = getComponentNameFromVspModel(vspModelInfo);
+ if (componentName.isPresent()) {
+ //Create main service template
+ ServiceTemplate mainServiceTemplate = createMainServiceTemplate(vspModelInfo);
+ generatedServiceTemplates.put(Constants.MAIN_TEMPLATE_NAME, mainServiceTemplate);
+ //Create substitution service template
+ for (Map.Entry<String, String> entry : abstractSubstitutionIdTypes.entrySet()) {
+ ServiceTemplate substitutionServiceTemplate = createSubstitutionServiceTemplate(componentName.get(), entry.getValue(), vspModelInfo,
+ toscaServiceModel);
+ generatedServiceTemplates.put(componentName.get(), substitutionServiceTemplate);
+ }
+ }
}
- return toscaServiceModel;
- }
- private void createToscaFromVspData(VspModelInfo vspModelInfo,
- ToscaServiceModel toscaServiceModel) {
- //Only one component supported
- Optional<String> componentName = getComponentNameFromVspModel(vspModelInfo);
- if (componentName.isPresent()) {
- //Create main service template
- ServiceTemplate mainServiceTemplate = createMainServiceTemplate(vspModelInfo);
- generatedServiceTemplates.put(Constants.MAIN_TEMPLATE_NAME, mainServiceTemplate);
- //Create substitution service template
- for (Map.Entry<String, String> entry : abstractSubstitutionIdTypes.entrySet()) {
- ServiceTemplate substitutionServiceTemplate =
- createSubstitutionServiceTemplate(componentName.get(), entry.getValue(), vspModelInfo,
- toscaServiceModel);
- generatedServiceTemplates.put(componentName.get(), substitutionServiceTemplate);
- }
+ private Optional<String> getComponentNameFromVspModel(VspModelInfo vspModelInfo) {
+ String componentName = null;
+ if (MapUtils.isNotEmpty(vspModelInfo.getComponents())) {
+ //supported for single component only
+ componentName = vspModelInfo.getComponents().entrySet().iterator().next().getValue();
+ }
+ return Optional.ofNullable(componentName);
}
- }
+ private ServiceTemplate createMainServiceTemplate(VspModelInfo vspModelInfo) {
+ ServiceTemplate mainServiceTemplate = createInitMainServiceTemplate(vspModelInfo.getReleaseVendor());
+ Map<String, String> components = vspModelInfo.getComponents();
+ if (MapUtils.isNotEmpty(components)) {
+ //Currently since only one component is supported we can fetch the component in this manner.
+
+ // May be need to revisited for supporting multiple components
+ String componentId = components.entrySet().iterator().next().getKey();
+ createVnfConfigurationNodeTemplate(mainServiceTemplate, vspModelInfo);
+ createVnfNodeTemplate(mainServiceTemplate, vspModelInfo, componentId);
+ }
+ return mainServiceTemplate;
+ }
- private Optional<String> getComponentNameFromVspModel(VspModelInfo vspModelInfo) {
- String componentName = null;
- if (MapUtils.isNotEmpty(vspModelInfo.getComponents())) {
- //supported for single component only
- componentName = vspModelInfo.getComponents().entrySet().iterator().next().getValue();
+ private void createVnfConfigurationNodeTemplate(ServiceTemplate mainServiceTemplate, VspModelInfo vspModelInfo) {
+ Optional<String> componentName = getComponentNameFromVspModel(vspModelInfo);
+ if (componentName.isPresent()) {
+ NodeTemplate vnfConfigurationNodeTemplate = new NodeTemplate();
+ vnfConfigurationNodeTemplate.setType(ToscaNodeType.VNF_CONFIG_NODE_TYPE);
+ if (Objects.nonNull(vspModelInfo.getAllowedFlavors())) {
+ Map<String, Object> properties = new LinkedHashMap<>();
+ properties.put(GeneratorConstants.ALLOWED_FLAVORS_PROPERTY, vspModelInfo.getAllowedFlavors());
+ vnfConfigurationNodeTemplate.setProperties(properties);
+ }
+ String nodeTemplateId = componentName.get() + GeneratorConstants.VNF_CONFIG_NODE_TEMPLATE_ID_SUFFIX;
+ DataModelUtil.addNodeTemplate(mainServiceTemplate, nodeTemplateId, vnfConfigurationNodeTemplate);
+ }
}
- return Optional.ofNullable(componentName);
- }
- private ServiceTemplate createMainServiceTemplate(VspModelInfo vspModelInfo) {
- ServiceTemplate mainServiceTemplate = createInitMainServiceTemplate(vspModelInfo
- .getReleaseVendor());
- Map<String, String> components = vspModelInfo.getComponents();
- if (MapUtils.isNotEmpty(components)) {
- //Currently since only one component is supported we can fetch the component in this manner.
- // May be need to revisited for supporting multiple components
- String componentId = components.entrySet().iterator().next().getKey();
- createVnfConfigurationNodeTemplate(mainServiceTemplate, vspModelInfo);
- createVnfNodeTemplate(mainServiceTemplate, vspModelInfo, componentId);
+ private void createVnfNodeTemplate(ServiceTemplate mainServiceTemplate, VspModelInfo vspModelInfo, String componentId) {
+ Optional<String> componentName = getComponentNameFromVspModel(vspModelInfo);
+ if (componentName.isPresent()) {
+ NodeTemplate vnfNodeTemplate = new NodeTemplate();
+ vnfNodeTemplate.setType(ToscaNodeType.MULTIDEPLOYMENTFLAVOR_NODE_TYPE);
+ List<String> directiveList = new ArrayList<>();
+ directiveList.add(ToscaConstants.NODE_TEMPLATE_DIRECTIVE_SUBSTITUTABLE);
+ vnfNodeTemplate.setDirectives(directiveList);
+ vnfNodeTemplate.setProperties(getVnfNodeTemplateProperties(vspModelInfo, componentId));
+ DataModelUtil.addSubstitutionFilteringProperty(getSubstitutionServiceTemplateFileName(componentName.get()), vnfNodeTemplate, 1);
+ //Enable below if we need "abstract_" as prefix like we have in Unified model
+
+ //String nodeTemplateId =
+
+ // Constants.ABSTRACT_NODE_TEMPLATE_ID_PREFIX + componentName + "VNF_NODE_TEMPLATE_ID_SUFFIX";
+ String nodeTemplateId = componentName.get() + GeneratorConstants.VNF_NODE_TEMPLATE_ID_SUFFIX;
+ DataModelUtil.addNodeTemplate(mainServiceTemplate, nodeTemplateId, vnfNodeTemplate);
+ abstractSubstitutionIdTypes.put(componentName.get(), ToscaNodeType.MULTIDEPLOYMENTFLAVOR_NODE_TYPE);
+ }
}
- return mainServiceTemplate;
- }
- private void createVnfConfigurationNodeTemplate(ServiceTemplate mainServiceTemplate,
- VspModelInfo vspModelInfo) {
- Optional<String> componentName = getComponentNameFromVspModel(vspModelInfo);
- if (componentName.isPresent()) {
- NodeTemplate vnfConfigurationNodeTemplate = new NodeTemplate();
- vnfConfigurationNodeTemplate.setType(ToscaNodeType.VNF_CONFIG_NODE_TYPE);
- if (Objects.nonNull(vspModelInfo.getAllowedFlavors())) {
+ private Map<String, Object> getVnfNodeTemplateProperties(VspModelInfo vspModelInfo, String componentId) {
Map<String, Object> properties = new LinkedHashMap<>();
- properties.put(GeneratorConstants.ALLOWED_FLAVORS_PROPERTY, vspModelInfo.getAllowedFlavors());
- vnfConfigurationNodeTemplate.setProperties(properties);
- }
- String nodeTemplateId = componentName.get() + GeneratorConstants.VNF_CONFIG_NODE_TEMPLATE_ID_SUFFIX;
- DataModelUtil.addNodeTemplate(mainServiceTemplate, nodeTemplateId,
- vnfConfigurationNodeTemplate);
+ if (MapUtils.isNotEmpty(vspModelInfo.getMultiFlavorVfcImages())) {
+ List<MultiFlavorVfcImage> componentImages = vspModelInfo.getMultiFlavorVfcImages().get(componentId);
+ if (Objects.nonNull(componentImages)) {
+ Map<String, MultiFlavorVfcImage> vfcImages = new HashMap<>();
+ componentImages.stream()
+ .forEach(multiFlavorVfcImage -> vfcImages.put(multiFlavorVfcImage.getSoftware_version(), multiFlavorVfcImage));
+ properties.put(GeneratorConstants.IMAGES_PROPERTY, vfcImages);
+ }
+ }
+ return properties;
}
- }
- private void createVnfNodeTemplate(ServiceTemplate mainServiceTemplate,
- VspModelInfo vspModelInfo, String componentId) {
- Optional<String> componentName = getComponentNameFromVspModel(vspModelInfo);
- if (componentName.isPresent()) {
- NodeTemplate vnfNodeTemplate = new NodeTemplate();
- vnfNodeTemplate.setType(ToscaNodeType.MULTIDEPLOYMENTFLAVOR_NODE_TYPE);
- List<String> directiveList = new ArrayList<>();
- directiveList.add(ToscaConstants.NODE_TEMPLATE_DIRECTIVE_SUBSTITUTABLE);
- vnfNodeTemplate.setDirectives(directiveList);
- vnfNodeTemplate.setProperties(getVnfNodeTemplateProperties(vspModelInfo, componentId));
- DataModelUtil
- .addSubstitutionFilteringProperty(getSubstitutionServiceTemplateFileName(componentName
- .get()), vnfNodeTemplate, 1);
- //Enable below if we need "abstract_" as prefix like we have in Unified model
- //String nodeTemplateId =
- // Constants.ABSTRACT_NODE_TEMPLATE_ID_PREFIX + componentName + "VNF_NODE_TEMPLATE_ID_SUFFIX";
- String nodeTemplateId = componentName.get() + GeneratorConstants.VNF_NODE_TEMPLATE_ID_SUFFIX;
- DataModelUtil.addNodeTemplate(mainServiceTemplate, nodeTemplateId,
- vnfNodeTemplate);
- abstractSubstitutionIdTypes.put(componentName.get(), ToscaNodeType
- .MULTIDEPLOYMENTFLAVOR_NODE_TYPE);
+ private String getSubstitutionServiceTemplateFileName(String componentName) {
+ return componentName + GeneratorConstants.TOSCA_SERVICE_TEMPLATE_FILE_NAME_SUFFIX;
}
- }
- private Map<String, Object> getVnfNodeTemplateProperties(VspModelInfo vspModelInfo,
- String componentId) {
- Map<String, Object> properties = new LinkedHashMap<>();
- if (MapUtils.isNotEmpty(vspModelInfo.getMultiFlavorVfcImages())) {
- List<MultiFlavorVfcImage> componentImages =
- vspModelInfo.getMultiFlavorVfcImages().get(componentId);
- if (Objects.nonNull(componentImages)) {
- Map<String, MultiFlavorVfcImage> vfcImages = new HashMap<>();
- componentImages.stream()
- .forEach(multiFlavorVfcImage ->
- vfcImages.put(multiFlavorVfcImage.getSoftware_version(), multiFlavorVfcImage));
- properties.put(GeneratorConstants.IMAGES_PROPERTY, vfcImages);
- }
+ private ServiceTemplate createInitMainServiceTemplate(String releaseVendor) {
+ ServiceTemplate mainServiceTemplate = new ServiceTemplate();
+ Map<String, String> templateMetadata = new HashMap<>();
+ templateMetadata.put(ToscaConstants.ST_METADATA_TEMPLATE_NAME, Constants.MAIN_TEMPLATE_NAME);
+ if (Objects.nonNull(releaseVendor)) {
+ templateMetadata.put(GeneratorConstants.RELEASE_VENDOR, releaseVendor);
+ }
+ mainServiceTemplate.setTosca_definitions_version(ToscaConstants.TOSCA_DEFINITIONS_VERSION);
+ mainServiceTemplate.setMetadata(templateMetadata);
+ mainServiceTemplate.setTopology_template(new TopologyTemplate());
+ mainServiceTemplate.setImports(getImports());
+ return mainServiceTemplate;
}
- return properties;
- }
-
- private String getSubstitutionServiceTemplateFileName(String componentName) {
- return componentName + GeneratorConstants.TOSCA_SERVICE_TEMPLATE_FILE_NAME_SUFFIX;
- }
- private ServiceTemplate createInitMainServiceTemplate(String releaseVendor) {
- ServiceTemplate mainServiceTemplate = new ServiceTemplate();
- Map<String, String> templateMetadata = new HashMap<>();
- templateMetadata.put(ToscaConstants.ST_METADATA_TEMPLATE_NAME, Constants.MAIN_TEMPLATE_NAME);
- if (Objects.nonNull(releaseVendor)) {
- templateMetadata.put(GeneratorConstants.RELEASE_VENDOR, releaseVendor);
+ private List<Map<String, Import>> getImports() {
+ Map<String, Import> globalSubstitutionTypeImportMap = new HashMap<>();
+ Import globalSubstitutionTypeImport = new Import();
+ globalSubstitutionTypeImport.setFile(ToscaUtil.getServiceTemplateFileName(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME));
+ globalSubstitutionTypeImportMap.put(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME, globalSubstitutionTypeImport);
+ List<Map<String, Import>> manualVspGlobalTypesImportList = GlobalTypesGenerator.getManualVspGlobalTypesImportList();
+ manualVspGlobalTypesImportList.add(globalSubstitutionTypeImportMap);
+ return manualVspGlobalTypesImportList;
}
- mainServiceTemplate.setTosca_definitions_version(ToscaConstants.TOSCA_DEFINITIONS_VERSION);
- mainServiceTemplate.setMetadata(templateMetadata);
- mainServiceTemplate.setTopology_template(new TopologyTemplate());
- mainServiceTemplate.setImports(getImports());
- return mainServiceTemplate;
- }
-
- private List<Map<String, Import>> getImports() {
- Map<String, Import> globalSubstitutionTypeImportMap = new HashMap<>();
- Import globalSubstitutionTypeImport = new Import();
- globalSubstitutionTypeImport.setFile(ToscaUtil.getServiceTemplateFileName(Constants
- .GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME));
- globalSubstitutionTypeImportMap.put(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME,
- globalSubstitutionTypeImport);
- List<Map<String, Import>> manualVspGlobalTypesImportList = GlobalTypesGenerator
- .getManualVspGlobalTypesImportList();
- manualVspGlobalTypesImportList.add(globalSubstitutionTypeImportMap);
- return manualVspGlobalTypesImportList;
- }
-
- private ServiceTemplate createSubstitutionServiceTemplate(String serviceTemplateName,
- String substitutionNodeTypeId,
- VspModelInfo vspModelInfo,
- ToscaServiceModel toscaServiceModel) {
- ServiceTemplate substitutionServiceTemplate =
- createInitSubstitutionServiceTemplate(serviceTemplateName);
- createSubstitutionServiceTemplateComponents(substitutionServiceTemplate, vspModelInfo);
- createSubstitutionServiceTemplateNics(substitutionServiceTemplate, vspModelInfo);
- handleSubstitutionMapping(substitutionServiceTemplate, toscaServiceModel,
- substitutionNodeTypeId, serviceTemplateName);
- return substitutionServiceTemplate;
- }
- private void createSubstitutionServiceTemplateComponents(ServiceTemplate
- substitutionServiceTemplate,
- VspModelInfo vspModelInfo) {
- Map<String, String> components = vspModelInfo.getComponents();
- if (MapUtils.isNotEmpty(components)) {
- for (String componentName : components.values()) {
- String localNodeTypeId =
- createComponentDefinitionNodeTemplate(substitutionServiceTemplate, componentName);
- createLocalNodeType(substitutionServiceTemplate, localNodeTypeId);
- }
+ private ServiceTemplate createSubstitutionServiceTemplate(String serviceTemplateName, String substitutionNodeTypeId, VspModelInfo vspModelInfo,
+ ToscaServiceModel toscaServiceModel) {
+ ServiceTemplate substitutionServiceTemplate = createInitSubstitutionServiceTemplate(serviceTemplateName);
+ createSubstitutionServiceTemplateComponents(substitutionServiceTemplate, vspModelInfo);
+ createSubstitutionServiceTemplateNics(substitutionServiceTemplate, vspModelInfo);
+ handleSubstitutionMapping(substitutionServiceTemplate, toscaServiceModel, substitutionNodeTypeId, serviceTemplateName);
+ return substitutionServiceTemplate;
}
- }
- private void createSubstitutionServiceTemplateNics(ServiceTemplate substitutionServiceTemplate,
- VspModelInfo vspModelInfo) {
- Map<String, List<Nic>> nics = vspModelInfo.getNics();
- if (MapUtils.isNotEmpty(nics)) {
- for (Map.Entry<String, List<Nic>> entry : nics.entrySet()) {
- String componentId = entry.getKey();
- String componentNodeTemplateId = getSubstitutionComponentNodeTemplateId(
- vspModelInfo.getComponents().get(componentId));
- List<Nic> nicList = entry.getValue();
- if (CollectionUtils.isNotEmpty(nicList)) {
- for (Nic nic : nicList) {
- NodeTemplate nicNodeTemplate = new NodeTemplate();
- nicNodeTemplate.setType(ToscaNodeType.NETWORK_PORT);
- DataModelUtil.addBindingReqFromPortToCompute(componentNodeTemplateId, nicNodeTemplate);
- DataModelUtil.addNodeTemplate(substitutionServiceTemplate,
- getNicNodeTemplateId(nic.getName(), nic.getNetworkType()), nicNodeTemplate);
- }
+ private void createSubstitutionServiceTemplateComponents(ServiceTemplate substitutionServiceTemplate, VspModelInfo vspModelInfo) {
+ Map<String, String> components = vspModelInfo.getComponents();
+ if (MapUtils.isNotEmpty(components)) {
+ for (String componentName : components.values()) {
+ String localNodeTypeId = createComponentDefinitionNodeTemplate(substitutionServiceTemplate, componentName);
+ createLocalNodeType(substitutionServiceTemplate, localNodeTypeId);
+ }
}
- }
}
- }
- private String getSubstitutionComponentNodeTemplateId(String componentName) {
- //TODO: Confirm if anything else is needed here
- return componentName;
- }
-
- private String getNicNodeTemplateId(String nicName, NetworkType nicNetworkType) {
- StringBuilder builder = new StringBuilder();
- builder.append(nicName);
- if (nicNetworkType == NetworkType.External) {
- builder.append(GeneratorConstants.PORT_TYPE_EXTERNAL_NODE_TEMPLATE_SUFFIX);
- } else if (nicNetworkType == NetworkType.Internal) {
- builder.append(GeneratorConstants.PORT_TYPE_INTERNAL_NODE_TEMPLATE_SUFFIX);
+ private void createSubstitutionServiceTemplateNics(ServiceTemplate substitutionServiceTemplate, VspModelInfo vspModelInfo) {
+ Map<String, List<Nic>> nics = vspModelInfo.getNics();
+ if (MapUtils.isNotEmpty(nics)) {
+ for (Map.Entry<String, List<Nic>> entry : nics.entrySet()) {
+ String componentId = entry.getKey();
+ String componentNodeTemplateId = getSubstitutionComponentNodeTemplateId(vspModelInfo.getComponents().get(componentId));
+ List<Nic> nicList = entry.getValue();
+ if (CollectionUtils.isNotEmpty(nicList)) {
+ for (Nic nic : nicList) {
+ NodeTemplate nicNodeTemplate = new NodeTemplate();
+ nicNodeTemplate.setType(ToscaNodeType.NETWORK_PORT);
+ DataModelUtil.addBindingReqFromPortToCompute(componentNodeTemplateId, nicNodeTemplate);
+ DataModelUtil
+ .addNodeTemplate(substitutionServiceTemplate, getNicNodeTemplateId(nic.getName(), nic.getNetworkType()), nicNodeTemplate);
+ }
+ }
+ }
+ }
}
- builder.append(GeneratorConstants.PORT_NODE_TEMPLATE_ID_SUFFIX);
- return builder.toString();
- }
- private String createComponentDefinitionNodeTemplate(ServiceTemplate substitutionServiceTemplate,
- String componentName) {
- NodeTemplate nodeTemplate = new NodeTemplate();
- String localNodeTypeId = getLocalNodeTypeId(componentName);
- nodeTemplate.setType(localNodeTypeId);
- DataModelUtil.addNodeTemplate(substitutionServiceTemplate, componentName, nodeTemplate);
- return localNodeTypeId;
- }
-
- private void createLocalNodeType(ServiceTemplate substitutionServiceTemplate,
- String localNodeTypeId) {
- NodeType localNodeType = new NodeType();
- localNodeType.setDerived_from(ToscaNodeType.COMPUTE);
- DataModelUtil.addNodeType(substitutionServiceTemplate, localNodeTypeId, localNodeType );
- }
+ private String getSubstitutionComponentNodeTemplateId(String componentName) {
+ //TODO: Confirm if anything else is needed here
+ return componentName;
+ }
- private String getLocalNodeTypeId(String componentName) {
- return ToscaNodeType.VFC_NODE_TYPE_PREFIX + componentName;
- }
+ private String getNicNodeTemplateId(String nicName, NetworkType nicNetworkType) {
+ StringBuilder builder = new StringBuilder();
+ builder.append(nicName);
+ if (nicNetworkType == NetworkType.External) {
+ builder.append(GeneratorConstants.PORT_TYPE_EXTERNAL_NODE_TEMPLATE_SUFFIX);
+ } else if (nicNetworkType == NetworkType.Internal) {
+ builder.append(GeneratorConstants.PORT_TYPE_INTERNAL_NODE_TEMPLATE_SUFFIX);
+ }
+ builder.append(GeneratorConstants.PORT_NODE_TEMPLATE_ID_SUFFIX);
+ return builder.toString();
+ }
- private ServiceTemplate createInitSubstitutionServiceTemplate(String serviceTemplateName) {
- ServiceTemplate substitutionServiceTemplate = new ServiceTemplate();
- Map<String, String> templateMetadata = new HashMap<>();
- substitutionServiceTemplate.setTosca_definitions_version(ToscaConstants
- .TOSCA_DEFINITIONS_VERSION);
- templateMetadata.put(ToscaConstants.ST_METADATA_TEMPLATE_NAME, serviceTemplateName);
- substitutionServiceTemplate.setMetadata(templateMetadata);
- substitutionServiceTemplate.setTopology_template(new TopologyTemplate());
- substitutionServiceTemplate.setImports(getImports());
- return substitutionServiceTemplate;
- }
+ private String createComponentDefinitionNodeTemplate(ServiceTemplate substitutionServiceTemplate, String componentName) {
+ NodeTemplate nodeTemplate = new NodeTemplate();
+ String localNodeTypeId = getLocalNodeTypeId(componentName);
+ nodeTemplate.setType(localNodeTypeId);
+ DataModelUtil.addNodeTemplate(substitutionServiceTemplate, componentName, nodeTemplate);
+ return localNodeTypeId;
+ }
- private void handleSubstitutionMapping(ServiceTemplate substitutionServiceTemplate,
- ToscaServiceModel toscaServiceModel,
- String substitutionNodeTypeId,
- String componentName) {
- ServiceTemplate globalSubstitutionServiceTemplate = fetchGlobalSubstitutionServiceTemplate();
- NodeType substitutionNodeType =
- createGlobalSubstitutionNodeType(substitutionServiceTemplate, componentName);
- DataModelUtil.addNodeType(globalSubstitutionServiceTemplate, substitutionNodeTypeId,
- substitutionNodeType);
- Map<String, Map<String, List<String>>> substitutionMapping =
- GeneratorUtils.getSubstitutionNodeTypeExposedConnectionPoints(substitutionNodeType,
- substitutionServiceTemplate, toscaServiceModel);
- if (Objects.nonNull(substitutionMapping)) {
- //add substitution mapping after capability and requirement expose calculation
- substitutionServiceTemplate.getTopology_template().setSubstitution_mappings(
- DataModelUtil.createSubstitutionTemplateSubMapping(substitutionNodeTypeId,
- substitutionNodeType, substitutionMapping));
+ private void createLocalNodeType(ServiceTemplate substitutionServiceTemplate, String localNodeTypeId) {
+ NodeType localNodeType = new NodeType();
+ localNodeType.setDerived_from(ToscaNodeType.COMPUTE);
+ DataModelUtil.addNodeType(substitutionServiceTemplate, localNodeTypeId, localNodeType);
}
- }
- //*************** CREATE GLOBAL SUBSTITUTION SERVICE TEMPLATE **********************
+ private String getLocalNodeTypeId(String componentName) {
+ return ToscaNodeType.VFC_NODE_TYPE_PREFIX + componentName;
+ }
- private ServiceTemplate createInitGlobalSubstitutionServiceTemplate() {
- ServiceTemplate globalSubstitutionServiceTemplate = new ServiceTemplate();
- Map<String, String> templateMetadata = new HashMap<>();
- globalSubstitutionServiceTemplate.setTosca_definitions_version(ToscaConstants
- .TOSCA_DEFINITIONS_VERSION);
- templateMetadata.put(ToscaConstants.ST_METADATA_TEMPLATE_NAME,
- Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME);
- globalSubstitutionServiceTemplate.setMetadata(templateMetadata);
- globalSubstitutionServiceTemplate.setImports(getImports());
- return globalSubstitutionServiceTemplate;
- }
+ private ServiceTemplate createInitSubstitutionServiceTemplate(String serviceTemplateName) {
+ ServiceTemplate substitutionServiceTemplate = new ServiceTemplate();
+ Map<String, String> templateMetadata = new HashMap<>();
+ substitutionServiceTemplate.setTosca_definitions_version(ToscaConstants.TOSCA_DEFINITIONS_VERSION);
+ templateMetadata.put(ToscaConstants.ST_METADATA_TEMPLATE_NAME, serviceTemplateName);
+ substitutionServiceTemplate.setMetadata(templateMetadata);
+ substitutionServiceTemplate.setTopology_template(new TopologyTemplate());
+ substitutionServiceTemplate.setImports(getImports());
+ return substitutionServiceTemplate;
+ }
- private NodeType createGlobalSubstitutionNodeType(ServiceTemplate substitutionServiceTemplate,
- String componentName) {
- NodeType substitutionNodeType = new ToscaAnalyzerServiceImpl()
- .createInitSubstitutionNodeType(substitutionServiceTemplate,
- ToscaNodeType.MULTIFLAVOR_VFC_NODE_TYPE);
- substitutionNodeType.setProperties(
- getManualVspSubstitutionNodeTypeProperties(componentName));
- return substitutionNodeType;
- }
+ private void handleSubstitutionMapping(ServiceTemplate substitutionServiceTemplate, ToscaServiceModel toscaServiceModel,
+ String substitutionNodeTypeId, String componentName) {
+ ServiceTemplate globalSubstitutionServiceTemplate = fetchGlobalSubstitutionServiceTemplate();
+ NodeType substitutionNodeType = createGlobalSubstitutionNodeType(substitutionServiceTemplate, componentName);
+ DataModelUtil.addNodeType(globalSubstitutionServiceTemplate, substitutionNodeTypeId, substitutionNodeType);
+ Map<String, Map<String, List<String>>> substitutionMapping = GeneratorUtils
+ .getSubstitutionNodeTypeExposedConnectionPoints(substitutionNodeType, substitutionServiceTemplate, toscaServiceModel);
+ if (Objects.nonNull(substitutionMapping)) {
+ //add substitution mapping after capability and requirement expose calculation
+ substitutionServiceTemplate.getTopology_template().setSubstitution_mappings(
+ DataModelUtil.createSubstitutionTemplateSubMapping(substitutionNodeTypeId, substitutionNodeType, substitutionMapping));
+ }
+ }
- private Map<String, PropertyDefinition> getManualVspSubstitutionNodeTypeProperties(String componentName) {
- //Create num_cpus property
- PropertyDefinition numCpus = new PropertyDefinition();
- numCpus.setType(PropertyType.INTEGER.getDisplayName());
- numCpus.setDescription(GeneratorConstants.NUM_CPUS_PROP_DESC_PREFIX + componentName);
- numCpus.setRequired(true);
- //Create disk_size property
- PropertyDefinition diskSize = new PropertyDefinition();
- diskSize.setType(PropertyType.SCALAR_UNIT_SIZE.getDisplayName());
- diskSize.setDescription(GeneratorConstants.DISK_SIZE_PROP_DESC_PREFIX + componentName);
- diskSize.setRequired(true);
- //Create mem_size property
- PropertyDefinition memSize = new PropertyDefinition();
- memSize.setType(PropertyType.SCALAR_UNIT_SIZE.getDisplayName());
- memSize.setDescription(GeneratorConstants.MEM_SIZE_PROP_DESC_PREFIX + componentName);
- memSize.setRequired(true);
+ //*************** CREATE GLOBAL SUBSTITUTION SERVICE TEMPLATE **********************
+ private ServiceTemplate createInitGlobalSubstitutionServiceTemplate() {
+ ServiceTemplate globalSubstitutionServiceTemplate = new ServiceTemplate();
+ Map<String, String> templateMetadata = new HashMap<>();
+ globalSubstitutionServiceTemplate.setTosca_definitions_version(ToscaConstants.TOSCA_DEFINITIONS_VERSION);
+ templateMetadata.put(ToscaConstants.ST_METADATA_TEMPLATE_NAME, Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME);
+ globalSubstitutionServiceTemplate.setMetadata(templateMetadata);
+ globalSubstitutionServiceTemplate.setImports(getImports());
+ return globalSubstitutionServiceTemplate;
+ }
- Map<String, PropertyDefinition> manualVspProperties = new LinkedHashMap<>();
- manualVspProperties.put(GeneratorConstants.NUM_CPUS, numCpus);
- manualVspProperties.put(GeneratorConstants.DISK_SIZE, diskSize);
- manualVspProperties.put(GeneratorConstants.MEM_SIZE, memSize);
+ private NodeType createGlobalSubstitutionNodeType(ServiceTemplate substitutionServiceTemplate, String componentName) {
+ NodeType substitutionNodeType = new ToscaAnalyzerServiceImpl()
+ .createInitSubstitutionNodeType(substitutionServiceTemplate, ToscaNodeType.MULTIFLAVOR_VFC_NODE_TYPE);
+ substitutionNodeType.setProperties(getManualVspSubstitutionNodeTypeProperties(componentName));
+ return substitutionNodeType;
+ }
- return manualVspProperties;
- }
+ private Map<String, PropertyDefinition> getManualVspSubstitutionNodeTypeProperties(String componentName) {
+ //Create num_cpus property
+ PropertyDefinition numCpus = new PropertyDefinition();
+ numCpus.setType(PropertyType.INTEGER.getDisplayName());
+ numCpus.setDescription(GeneratorConstants.NUM_CPUS_PROP_DESC_PREFIX + componentName);
+ numCpus.setRequired(true);
+ //Create disk_size property
+ PropertyDefinition diskSize = new PropertyDefinition();
+ diskSize.setType(PropertyType.SCALAR_UNIT_SIZE.getDisplayName());
+ diskSize.setDescription(GeneratorConstants.DISK_SIZE_PROP_DESC_PREFIX + componentName);
+ diskSize.setRequired(true);
+ //Create mem_size property
+ PropertyDefinition memSize = new PropertyDefinition();
+ memSize.setType(PropertyType.SCALAR_UNIT_SIZE.getDisplayName());
+ memSize.setDescription(GeneratorConstants.MEM_SIZE_PROP_DESC_PREFIX + componentName);
+ memSize.setRequired(true);
+ Map<String, PropertyDefinition> manualVspProperties = new LinkedHashMap<>();
+ manualVspProperties.put(GeneratorConstants.NUM_CPUS, numCpus);
+ manualVspProperties.put(GeneratorConstants.DISK_SIZE, diskSize);
+ manualVspProperties.put(GeneratorConstants.MEM_SIZE, memSize);
+ return manualVspProperties;
+ }
- /**
- * Fetch global substitution service template service template.
- *
- * @return the global substitution service template
- */
- private ServiceTemplate fetchGlobalSubstitutionServiceTemplate() {
- ServiceTemplate globalSubstitutionServiceTemplate =
- generatedServiceTemplates.get(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME);
- if (Objects.isNull(globalSubstitutionServiceTemplate)) {
- globalSubstitutionServiceTemplate = createInitGlobalSubstitutionServiceTemplate();
- generatedServiceTemplates.put(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME,
- globalSubstitutionServiceTemplate);
+ /**
+ * Fetch global substitution service template service template.
+ *
+ * @return the global substitution service template
+ */
+ private ServiceTemplate fetchGlobalSubstitutionServiceTemplate() {
+ ServiceTemplate globalSubstitutionServiceTemplate = generatedServiceTemplates.get(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME);
+ if (Objects.isNull(globalSubstitutionServiceTemplate)) {
+ globalSubstitutionServiceTemplate = createInitGlobalSubstitutionServiceTemplate();
+ generatedServiceTemplates.put(Constants.GLOBAL_SUBSTITUTION_TYPES_TEMPLATE_NAME, globalSubstitutionServiceTemplate);
+ }
+ return globalSubstitutionServiceTemplate;
}
- return globalSubstitutionServiceTemplate;
- }
}