Improve handling 'empty'/null string in Service fields
[sdc.git] / catalog-be / src / main / java / org / openecomp / sdc / be / components / validation / service / ServiceNamingPolicyValidator.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2020 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 package org.openecomp.sdc.be.components.validation.service;
21
22 import org.apache.commons.lang3.StringUtils;
23 import org.openecomp.sdc.be.components.impl.exceptions.ByActionStatusComponentException;
24 import org.openecomp.sdc.be.components.impl.exceptions.ByResponseFormatComponentException;
25 import org.openecomp.sdc.be.dao.api.ActionStatus;
26 import org.openecomp.sdc.be.impl.ComponentsUtils;
27 import org.openecomp.sdc.be.model.Service;
28 import org.openecomp.sdc.be.model.User;
29 import org.openecomp.sdc.be.resources.data.auditing.AuditingActionEnum;
30 import org.openecomp.sdc.common.log.wrappers.Logger;
31 import org.openecomp.sdc.common.util.ValidationUtils;
32 import org.openecomp.sdc.exception.ResponseFormat;
33
34 @org.springframework.stereotype.Component
35 public class ServiceNamingPolicyValidator implements ServiceFieldValidator {
36
37     private static final Logger log = Logger.getLogger(ServiceNamingPolicyValidator.class.getName());
38     private ComponentsUtils componentsUtils;
39
40     public ServiceNamingPolicyValidator(ComponentsUtils componentsUtils) {
41         this.componentsUtils = componentsUtils;
42     }
43
44     @Override
45     public void validateAndCorrectField(User user, Service service, AuditingActionEnum actionEnum) {
46         Boolean isEcompGeneratedCurr = service.isEcompGeneratedNaming();
47         String namingPolicyUpdate = service.getNamingPolicy();
48         if (isEcompGeneratedCurr == null) {
49             throw new ByActionStatusComponentException(ActionStatus.MISSING_ECOMP_GENERATED_NAMING);
50         }
51         if (isEcompGeneratedCurr) {
52             if (StringUtils.isEmpty(namingPolicyUpdate)) {
53                 return;
54             }
55             if (!ValidationUtils.validateServiceNamingPolicyLength(namingPolicyUpdate)) {
56                 ResponseFormat responseFormat = componentsUtils
57                     .getResponseFormat(ActionStatus.NAMING_POLICY_EXCEEDS_LIMIT, "" + ValidationUtils.SERVICE_NAMING_POLICY_MAX_SIZE);
58                 throw new ByResponseFormatComponentException(responseFormat);
59             }
60             if (!ValidationUtils.validateCommentPattern(namingPolicyUpdate)) {
61                 throw new ByActionStatusComponentException(ActionStatus.INVALID_NAMING_POLICY);
62             }
63         } else {
64             if (StringUtils.isNotEmpty(namingPolicyUpdate)) {
65                 log.warn("NamingPolicy must be empty for EcompGeneratedNaming=false");
66             }
67             service.setNamingPolicy("");
68         }
69     }
70 }