2 * Copyright © 2017-2018 AT&T Intellectual Property.
\r
4 * Licensed under the Apache License, Version 2.0 (the "License");
\r
5 * you may not use this file except in compliance with the License.
\r
6 * You may obtain a copy of the License at
\r
8 * http://www.apache.org/licenses/LICENSE-2.0
\r
10 * Unless required by applicable law or agreed to in writing, software
\r
11 * distributed under the License is distributed on an "AS IS" BASIS,
\r
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
13 * See the License for the specific language governing permissions and
\r
14 * limitations under the License.
\r
17 package org.onap.ccsdk.apps.controllerblueprints.service.validator;
\r
19 import com.google.common.base.Preconditions;
\r
20 import org.apache.commons.lang3.StringUtils;
\r
21 import org.jetbrains.annotations.NotNull;
\r
22 import org.onap.ccsdk.apps.controllerblueprints.core.BluePrintException;
\r
23 import org.onap.ccsdk.apps.controllerblueprints.core.data.NodeTemplate;
\r
24 import org.onap.ccsdk.apps.controllerblueprints.core.data.ServiceTemplate;
\r
25 import org.onap.ccsdk.apps.controllerblueprints.core.service.BluePrintValidatorDefaultService;
\r
26 import org.onap.ccsdk.apps.controllerblueprints.core.utils.JacksonUtils;
\r
27 import org.onap.ccsdk.apps.controllerblueprints.resource.dict.validator.ResourceAssignmentValidator;
\r
29 import java.util.HashMap;
\r
30 import java.util.Map;
\r
33 * ServiceTemplateValidator.java Purpose: Provide Configuration Generator ServiceTemplateValidator
\r
35 * @author Brinda Santh
\r
39 public class ServiceTemplateValidator extends BluePrintValidatorDefaultService {
\r
41 StringBuilder message = new StringBuilder();
\r
42 private Map<String, String> metaData = new HashMap<>();
\r
45 * This is a validateServiceTemplate
\r
47 * @param serviceTemplateContent serviceTemplateContent
\r
49 * @throws BluePrintException BluePrintException
\r
51 public boolean validateServiceTemplate(String serviceTemplateContent) throws BluePrintException {
\r
52 if (StringUtils.isNotBlank(serviceTemplateContent)) {
\r
53 ServiceTemplate serviceTemplate =
\r
54 JacksonUtils.readValue(serviceTemplateContent, ServiceTemplate.class);
\r
55 return validateServiceTemplate(serviceTemplate);
\r
57 throw new BluePrintException(
\r
58 "Service Template Content is (" + serviceTemplateContent + ") not Defined.");
\r
63 * This is a validateServiceTemplate
\r
65 * @param serviceTemplate
\r
67 * @throws BluePrintException BluePrintException
\r
69 @SuppressWarnings("squid:S00112")
\r
70 public boolean validateServiceTemplate(ServiceTemplate serviceTemplate) throws BluePrintException {
\r
71 Map<String, Object> properties = new HashMap<>();
\r
72 super.validateBlueprint(serviceTemplate, properties);
\r
77 * This is a getMetaData to get the key information during the
\r
79 * @return Map<String, String>
\r
81 public Map<String, String> getMetaData() {
\r
86 public void validateMetadata(@NotNull Map<String, String> metaDataMap) throws BluePrintException {
\r
88 Preconditions.checkNotNull(serviceTemplate.getMetadata(), "Service Template Metadata Information is missing.");
\r
89 super.validateMetadata(metaDataMap);
\r
91 this.metaData.putAll(serviceTemplate.getMetadata());
\r
96 public void validateNodeTemplate(@NotNull String nodeTemplateName, @NotNull NodeTemplate nodeTemplate)
\r
97 throws BluePrintException {
\r
98 super.validateNodeTemplate(nodeTemplateName, nodeTemplate);
\r
99 validateNodeTemplateCustom(nodeTemplateName, nodeTemplate);
\r
104 private void validateNodeTemplateCustom(@NotNull String nodeTemplateName, @NotNull NodeTemplate nodeTemplate)
\r
105 throws BluePrintException {
\r
106 String derivedFrom = getBluePrintContext().nodeTemplateNodeType(nodeTemplateName).getDerivedFrom();
\r
107 if ("tosca.nodes.Artifact".equals(derivedFrom)) {
\r
108 ResourceAssignmentValidator resourceAssignmentValidator = new ResourceAssignmentValidator(nodeTemplate);
\r
109 resourceAssignmentValidator.validateResourceAssignment();
\r