258d3321bc7c06dec3807fd06a186b99523946ed
[sdc.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. 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
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
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=========================================================
19  */
20
21 package org.openecomp.sdc.translator.services.heattotosca.impl.resourcetranslation;
22
23 import org.openecomp.sdc.common.errors.CoreException;
24 import org.openecomp.sdc.datatypes.error.ErrorLevel;
25 import org.openecomp.sdc.heat.datatypes.HeatBoolean;
26 import org.openecomp.sdc.heat.datatypes.model.Resource;
27 import org.openecomp.sdc.logging.api.Logger;
28 import org.openecomp.sdc.logging.api.LoggerFactory;
29 import org.openecomp.sdc.logging.context.impl.MdcDataErrorMessage;
30 import org.openecomp.sdc.logging.types.LoggerConstants;
31 import org.openecomp.sdc.logging.types.LoggerErrorCode;
32 import org.openecomp.sdc.logging.types.LoggerErrorDescription;
33 import org.openecomp.sdc.logging.types.LoggerTragetServiceName;
34 import org.openecomp.sdc.tosca.datatypes.ToscaFunctions;
35 import org.openecomp.sdc.tosca.datatypes.model.NodeTemplate;
36 import org.openecomp.sdc.tosca.datatypes.model.ParameterDefinition;
37 import org.openecomp.sdc.tosca.datatypes.model.PropertyType;
38 import org.openecomp.sdc.tosca.services.DataModelUtil;
39 import org.openecomp.sdc.tosca.services.ToscaConstants;
40 import org.openecomp.sdc.translator.datatypes.heattotosca.AttachedResourceId;
41 import org.openecomp.sdc.translator.datatypes.heattotosca.to.TranslateTo;
42 import org.openecomp.sdc.translator.services.heattotosca.HeatToToscaUtil;
43 import org.openecomp.sdc.translator.services.heattotosca.ResourceTranslationFactory;
44 import org.openecomp.sdc.translator.services.heattotosca.errors.MissingMandatoryPropertyErrorBuilder;
45 import org.openecomp.sdc.translator.services.heattotosca.mapping.TranslatorHeatToToscaPropertyConverter;
46
47 import java.util.HashMap;
48 import java.util.Map;
49 import java.util.Optional;
50
51 public class ResourceTranslationNeutronSubnetImpl extends ResourceTranslationBase {
52   protected static Logger logger =
53       (Logger) LoggerFactory.getLogger(ResourceTranslationNeutronSubnetImpl.class);
54
55   @Override
56   public void translate(TranslateTo translateTo) {
57     Optional<AttachedResourceId> subnetNetwork = getAttachedNetworkResource(translateTo);
58
59     if (!subnetNetwork.isPresent() || !subnetNetwork.get().isGetResource()) {
60       return;
61     }
62
63     Resource networkResource = HeatToToscaUtil
64         .getResource(translateTo.getHeatOrchestrationTemplate(),
65             (String) subnetNetwork.get().getEntityId(), translateTo.getHeatFileName());
66     Optional<String> translatedNetworkId = ResourceTranslationFactory.getInstance(networkResource)
67         .translateResource(translateTo.getHeatFileName(), translateTo.getServiceTemplate(),
68             translateTo.getHeatOrchestrationTemplate(), networkResource,
69             (String) subnetNetwork.get().getEntityId(), translateTo.getContext());
70     if (translatedNetworkId.isPresent()) {
71       NodeTemplate networkNodeTemplate = DataModelUtil
72           .getNodeTemplate(translateTo.getServiceTemplate(), translatedNetworkId.get());
73
74       Map<String, Map<String, Object>> subNetMap =
75           (Map<String, Map<String, Object>>) networkNodeTemplate.getProperties().get("subnets");
76       if (subNetMap == null) {
77         subNetMap = new HashMap<>();
78         networkNodeTemplate.getProperties().put("subnets", subNetMap);
79         TranslatorHeatToToscaPropertyConverter
80             .setSimpleProperty(translateTo.getServiceTemplate(),translateTo.getTranslatedId(),
81                 translateTo.getResource().getProperties(),
82                 translateTo.getHeatFileName(), translateTo.getResource().getType(),
83                 translateTo.getHeatOrchestrationTemplate(), translateTo.getContext(),
84                 networkNodeTemplate.getProperties(), "enable_dhcp",
85                 ToscaConstants.DHCP_ENABLED_PROPERTY_NAME, networkNodeTemplate); //dhcp_enabled
86         TranslatorHeatToToscaPropertyConverter
87             .setSimpleProperty(translateTo.getServiceTemplate(),translateTo.getTranslatedId(),
88                 translateTo.getResource().getProperties(),
89                 translateTo.getHeatFileName(), translateTo.getResource().getType(),
90                 translateTo.getHeatOrchestrationTemplate(), translateTo.getContext(),
91                 networkNodeTemplate.getProperties(), "ip_version", null, networkNodeTemplate);
92         handleDhcpProperty(translateTo, networkNodeTemplate);
93       }
94
95       Map<String, Object> properties;
96       properties = TranslatorHeatToToscaPropertyConverter
97           .getToscaPropertiesSimpleConversion(translateTo.getServiceTemplate(),translateTo.
98                   getResourceId(),translateTo.getResource().getProperties(), null,
99               translateTo.getHeatFileName(), translateTo.getHeatOrchestrationTemplate(),
100               translateTo.getResource().getType(), networkNodeTemplate, translateTo.getContext());
101
102       subNetMap.put(translateTo.getResourceId(), properties);
103     }
104   }
105
106   @Override
107   protected String generateTranslatedId(TranslateTo translateTo) {
108     Optional<AttachedResourceId> subnetNetwork = getAttachedNetworkResource(translateTo);
109
110     if (!subnetNetwork.isPresent() || !subnetNetwork.get().isGetResource()) {
111       logger.warn("Heat resource: '" + translateTo.getResourceId() + "' with type: '"
112           + translateTo.getResource().getType()
113           + "' include 'network_id/'network'' property without 'get_resource' function, therefore"
114           + " this resource will be ignored in TOSCA translation.");
115       return null;
116     }
117     return (String) subnetNetwork.get().getTranslatedId();
118   }
119
120   private void handleDhcpProperty(TranslateTo translateTo, NodeTemplate networkNodeTemplate) {
121     Object dhcpEnabled =
122         networkNodeTemplate.getProperties().get(ToscaConstants.DHCP_ENABLED_PROPERTY_NAME);
123     if (dhcpEnabled instanceof Map) {
124       Object dhcpEnabledParameterName =
125           ((Map) dhcpEnabled).get(ToscaFunctions.GET_INPUT.getDisplayName());
126       if (dhcpEnabledParameterName != null) {
127         ParameterDefinition dhcpParameterDefinition = null;
128         if (translateTo.getServiceTemplate().getTopology_template().getInputs() != null) {
129           dhcpParameterDefinition =
130               translateTo.getServiceTemplate().getTopology_template().getInputs()
131                   .get(dhcpEnabledParameterName);
132         }
133         if (dhcpParameterDefinition == null) {
134           logger.warn("Missing input parameter " + dhcpEnabledParameterName);
135         } else {
136           Object defaultVal = dhcpParameterDefinition.get_default();
137           if (defaultVal != null) {
138             try {
139               Boolean booleanValue = HeatBoolean.eval(defaultVal);
140               dhcpParameterDefinition.set_default(booleanValue);
141             } catch (CoreException coreException) {
142               logger.debug("",coreException);
143               //if value is not valid value for boolean set with dhcp_enabled default value = true
144               dhcpParameterDefinition.set_default(true);
145               logger.warn("Parameter '" + dhcpEnabledParameterName + "' used for "
146                   + ToscaConstants.DHCP_ENABLED_PROPERTY_NAME
147                   + " boolean property, but it's value is not a valid boolean value, therefore "
148                   + ToscaConstants.DHCP_ENABLED_PROPERTY_NAME
149                   + " property will be set with default value of 'true'.");
150             }
151             dhcpParameterDefinition.setType(PropertyType.BOOLEAN.getDisplayName());
152           }
153         }
154       }
155     }
156   }
157
158   private Optional<AttachedResourceId> getAttachedNetworkResource(TranslateTo translateTo) {
159     Optional<AttachedResourceId> subnetNetwork = Optional.empty();
160     Optional<AttachedResourceId> attachedNetworkId =
161         HeatToToscaUtil.extractAttachedResourceId(translateTo, "network_id");
162     if (!attachedNetworkId.isPresent()) {
163       Optional<AttachedResourceId> attachedNetwork =
164           HeatToToscaUtil.extractAttachedResourceId(translateTo, "network");
165       if (!attachedNetwork.isPresent()) {
166         MdcDataErrorMessage.createErrorMessageAndUpdateMdc(LoggerConstants.TARGET_ENTITY_DB,
167             LoggerTragetServiceName.GET_RESOURCE, ErrorLevel.ERROR.name(),
168             LoggerErrorCode.DATA_ERROR.getErrorCode(),
169             LoggerErrorDescription.MISSING_MANDATORY_PROPERTY);
170         throw new CoreException(
171             new MissingMandatoryPropertyErrorBuilder("network_id/'network'").build());
172       } else {
173         subnetNetwork = attachedNetwork;
174       }
175     } else {
176       subnetNetwork = attachedNetworkId;
177     }
178     return subnetNetwork;
179   }
180 }
181
182