2 * ============LICENSE_START=======================================================
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
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.policy.rest.util;
22 import java.io.IOException;
23 import java.util.HashMap;
24 import java.util.Iterator;
25 import java.util.LinkedHashMap;
26 import java.util.List;
28 import java.util.Map.Entry;
30 import org.apache.commons.lang.StringUtils;
31 import org.json.JSONObject;
32 import org.onap.policy.common.logging.flexlogger.FlexLogger;
33 import org.onap.policy.common.logging.flexlogger.Logger;
34 import org.onap.policy.rest.adapter.ClosedLoopFaultBody;
35 import org.onap.policy.rest.adapter.ClosedLoopPMBody;
36 import org.onap.policy.rest.adapter.PolicyRestAdapter;
37 import org.onap.policy.rest.dao.CommonClassDao;
38 import org.onap.policy.rest.jpa.MicroServiceModels;
39 import org.onap.policy.rest.jpa.SafePolicyWarning;
40 import org.onap.policy.utils.PolicyUtils;
41 import org.onap.policy.xacml.api.XACMLErrorConstants;
42 import org.springframework.beans.factory.annotation.Autowired;
43 import org.springframework.stereotype.Service;
45 import com.fasterxml.jackson.databind.JsonNode;
46 import com.fasterxml.jackson.databind.ObjectMapper;
47 import com.google.common.base.Splitter;
48 import com.google.common.base.Strings;
51 public class PolicyValidation {
53 private static final Logger LOGGER = FlexLogger.getLogger(PolicyValidation.class);
55 public static final String CONFIG_POLICY = "Config";
56 public static final String ACTION_POLICY = "Action";
57 public static final String DECISION_POLICY = "Decision";
58 public static final String CLOSEDLOOP_POLICY = "ClosedLoop_Fault";
59 public static final String CLOSEDLOOP_PM = "ClosedLoop_PM";
60 public static final String ENFORCER_CONFIG_POLICY= "Enforcer Config";
61 public static final String MICROSERVICES="Micro Service";
62 public static final String FIREWALL="Firewall Config";
63 public static final String HTML_ITALICS_LNBREAK = "</i><br>";
64 public static final String SUCCESS = "success";
65 public static final String EMPTY_COMPONENT_ATTR = "Component Attributes: One or more Fields in Component Attributes is Empty.";
67 private static Map<String, String> mapAttribute = new HashMap<>();
69 private static CommonClassDao commonClassDao;
72 public PolicyValidation(CommonClassDao commonClassDao){
73 PolicyValidation.commonClassDao = commonClassDao;
77 * This is an empty constructor
79 public PolicyValidation(){}
82 public StringBuilder validatePolicy(PolicyRestAdapter policyData) throws IOException{
85 StringBuilder responseString = new StringBuilder();
86 ObjectMapper mapper = new ObjectMapper();
88 if(policyData.getPolicyName() != null){
89 String policyNameValidate = PolicyUtils.policySpecialCharValidator(policyData.getPolicyName());
90 if(!policyNameValidate.contains(SUCCESS)){
91 responseString.append("PolicyName:" + policyNameValidate + "<br>");
95 responseString.append( "PolicyName: PolicyName Should not be empty" + "<br>");
98 if(policyData.getPolicyDescription() != null){
99 String descriptionValidate = PolicyUtils.descriptionValidator(policyData.getPolicyDescription());
100 if(!descriptionValidate.contains(SUCCESS)){
101 responseString.append("Description:" + descriptionValidate + "<br>");
106 if(CONFIG_POLICY.equalsIgnoreCase(policyData.getPolicyType())){
107 if ("Base".equals(policyData.getConfigPolicyType()) || CLOSEDLOOP_POLICY.equals(policyData.getConfigPolicyType())
108 || CLOSEDLOOP_PM.equals(policyData.getConfigPolicyType()) || ENFORCER_CONFIG_POLICY.equals(policyData.getConfigPolicyType())
109 || MICROSERVICES.equals(policyData.getConfigPolicyType())) {
111 if(!Strings.isNullOrEmpty(policyData.getOnapName())) {
112 String onapNameValidate = PolicyUtils.policySpecialCharValidator(policyData.getOnapName());
113 if(!onapNameValidate.contains(SUCCESS)){
114 responseString.append("OnapName:" + onapNameValidate + "<br>");
118 responseString.append("Onap Name: Onap Name Should not be empty" + "<br>");
123 if(!Strings.isNullOrEmpty(policyData.getRiskType())) {
124 String riskTypeValidate = PolicyUtils.policySpecialCharValidator(policyData.getRiskType());
125 if(!riskTypeValidate.contains(SUCCESS)){
126 responseString.append("RiskType:" + riskTypeValidate + "<br>");
130 responseString.append("Risk Type: Risk Type Should not be Empty" + "<br>");
134 if(!Strings.isNullOrEmpty(policyData.getRiskLevel())) {
135 String validateRiskLevel = PolicyUtils.policySpecialCharValidator(policyData.getRiskLevel());
136 if(!validateRiskLevel.contains(SUCCESS)){
137 responseString.append("RiskLevel:" + validateRiskLevel + "<br>");
141 responseString.append("Risk Level: Risk Level Should not be Empty" + "<br>");
145 if(!Strings.isNullOrEmpty(policyData.getGuard())) {
146 String validateGuard = PolicyUtils.policySpecialCharValidator(policyData.getGuard());
147 if(!validateGuard.contains(SUCCESS)){
148 responseString.append("Guard:" + validateGuard + "<br>");
152 responseString.append("Guard: Guard Value Should not be Empty" + "<br>");
156 if("Base".equalsIgnoreCase(policyData.getConfigPolicyType())){
157 if(!Strings.isNullOrEmpty(policyData.getConfigName())) {
158 String configNameValidate = PolicyUtils.policySpecialCharValidator(policyData.getConfigName());
159 if(!configNameValidate.contains(SUCCESS)){
160 responseString.append("ConfigName:" + configNameValidate + "<br>");
164 responseString.append("Config Name: Config Name Should not be Empty" + "<br>");
167 if(!Strings.isNullOrEmpty(policyData.getConfigType())) {
168 String configTypeValidate = PolicyUtils.policySpecialCharValidator(policyData.getConfigType());
169 if(!configTypeValidate.contains(SUCCESS)){
170 responseString.append("ConfigType:" + configTypeValidate + "<br>");
174 responseString.append("Config Type: Config Type Should not be Empty" + "<br>");
177 if(!Strings.isNullOrEmpty(policyData.getConfigBodyData())) {
178 String configBodyData = policyData.getConfigBodyData();
179 String configType = policyData.getConfigType();
180 if (configType != null) {
181 if (configType.equals("JSON")) {
182 if (!PolicyUtils.isJSONValid(configBodyData)) {
183 responseString.append("Config Body: JSON Content is not valid" + "<br>");
186 } else if (configType.equals("XML")) {
187 if (!PolicyUtils.isXMLValid(configBodyData)) {
188 responseString.append("Config Body: XML Content data is not valid" + "<br>");
191 } else if (configType.equals("PROPERTIES")) {
192 if (!PolicyUtils.isPropValid(configBodyData)||configBodyData.equals("")) {
193 responseString.append("Config Body: Property data is not valid" + "<br>");
196 } else if ("OTHER".equals(configType) && ("".equals(configBodyData))) {
197 responseString.append("Config Body: Config Body Should not be Empty" + "<br>");
202 responseString.append("Config Body: Config Body Should not be Empty" + "<br>");
207 if(FIREWALL.equalsIgnoreCase(policyData.getConfigPolicyType())){
208 if(policyData.getConfigName() != null && !policyData.getConfigName().isEmpty()){
209 String configNameValidate = PolicyUtils.policySpecialCharValidator(policyData.getConfigName());
210 if(!configNameValidate.contains(SUCCESS)){
211 responseString.append("<b>ConfigName</b>:<i>" + configNameValidate + HTML_ITALICS_LNBREAK);
215 responseString.append("<b>Config Name</b>:<i> Config Name is required" + HTML_ITALICS_LNBREAK);
218 if(policyData.getSecurityZone() == null || policyData.getSecurityZone().isEmpty()){
219 responseString.append("<b>Security Zone</b>:<i> Security Zone is required" + HTML_ITALICS_LNBREAK);
223 if("BRMS_Param".equalsIgnoreCase(policyData.getConfigPolicyType()) && Strings.isNullOrEmpty(policyData.getRuleName())){
224 responseString.append("<b>BRMS Template</b>:<i>BRMS Template is required" + HTML_ITALICS_LNBREAK);
227 if("BRMS_Raw".equalsIgnoreCase(policyData.getConfigPolicyType())){
228 if(policyData.getConfigBodyData() != null && !policyData.getConfigBodyData().isEmpty()){
229 String message = PolicyUtils.brmsRawValidate(policyData.getConfigBodyData());
231 // If there are any error other than Annotations then this is not Valid
232 if(message.contains("[ERR")){
233 responseString.append("<b>Raw Rule Validate</b>:<i>Raw Rule has error"+ message + HTML_ITALICS_LNBREAK);
237 responseString.append("<b>Raw Rule</b>:<i>Raw Rule is required" + HTML_ITALICS_LNBREAK);
241 if(CLOSEDLOOP_PM.equalsIgnoreCase(policyData.getConfigPolicyType())){
243 if(Strings.isNullOrEmpty(policyData.getServiceTypePolicyName().get("serviceTypePolicyName").toString())){
244 responseString.append("<b>ServiceType PolicyName</b>:<i>ServiceType PolicyName is required" + HTML_ITALICS_LNBREAK);
249 LOGGER.error("ERROR in ClosedLoop_PM PolicyName" , e);
250 responseString.append("<b>ServiceType PolicyName</b>:<i>ServiceType PolicyName is required" + HTML_ITALICS_LNBREAK);
254 if(policyData.getJsonBody() != null){
256 ClosedLoopPMBody pmBody = mapper.readValue(policyData.getJsonBody(), ClosedLoopPMBody.class);
257 if(pmBody.getEmailAddress() != null){
258 String result = emailValidation(pmBody.getEmailAddress(), responseString.toString());
259 if(result != SUCCESS){
260 responseString.append(result + "<br>");
264 if((pmBody.isGamma() || pmBody.isMcr() || pmBody.isTrinity() || pmBody.isvDNS() || pmBody.isvUSP()) != true){
265 responseString.append("<b>D2/Virtualized Services</b>: <i>Select at least one D2/Virtualized Services" + HTML_ITALICS_LNBREAK);
268 if(pmBody.getGeoLink() != null && !pmBody.getGeoLink().isEmpty()){
269 String result = PolicyUtils.policySpecialCharValidator(pmBody.getGeoLink());
270 if(!result.contains(SUCCESS)){
271 responseString.append("<b>GeoLink</b>:<i>" + result + HTML_ITALICS_LNBREAK);
275 if(pmBody.getAttributes() != null && !pmBody.getAttributes().isEmpty()){
276 for(Entry<String, String> entry : pmBody.getAttributes().entrySet()){
277 String key = entry.getKey();
278 String value = entry.getValue();
279 if(!key.contains("Message")){
280 String attributeValidate = PolicyUtils.policySpecialCharValidator(value);
281 if(!attributeValidate.contains(SUCCESS)){
282 responseString.append("<b>Attributes</b>:<i>" + key + " : value has spaces or invalid characters" + HTML_ITALICS_LNBREAK);
289 responseString.append("<b>D2/Virtualized Services</b>:<i>Select atleast one D2/Virtualized Services" + HTML_ITALICS_LNBREAK);
293 if(CLOSEDLOOP_POLICY.equalsIgnoreCase(policyData.getConfigPolicyType())){
294 if(policyData.getJsonBody() != null){
296 // For API we need to get the conditions key from the Json request and check it before deserializing to POJO due to the enum
297 if("API".equals(policyData.getApiflag())){
298 JSONObject json = new JSONObject(policyData.getJsonBody());
299 if(!json.isNull("conditions")){
300 String apiCondition = (String) json.get("conditions");
301 if(Strings.isNullOrEmpty(apiCondition)){
302 responseString.append("<b>Conditions</b>: <i>Select At least one Condition" + HTML_ITALICS_LNBREAK);
303 return responseString;
306 responseString.append("<b>Conditions</b>: <i>There were no conditions provided in configBody json" + HTML_ITALICS_LNBREAK);
307 return responseString;
311 ClosedLoopFaultBody faultBody = mapper.readValue(policyData.getJsonBody(), ClosedLoopFaultBody.class);
312 if(faultBody.getEmailAddress() != null && !faultBody.getEmailAddress().isEmpty()){
313 String result = emailValidation(faultBody.getEmailAddress(), responseString.toString());
314 if(result != SUCCESS){
315 responseString.append(result+ "<br>");
319 if((faultBody.isGamma() || faultBody.isMcr() || faultBody.isTrinity() || faultBody.isvDNS() || faultBody.isvUSP()) != true){
320 responseString.append("<b>D2/Virtualized Services</b>: <i>Select at least one D2/Virtualized Services" + HTML_ITALICS_LNBREAK);
323 if(faultBody.getActions() == null || faultBody.getActions().isEmpty()){
324 responseString.append("<b>vPRO Actions</b>: <i>vPRO Actions is required" + HTML_ITALICS_LNBREAK);
327 if(faultBody.getClosedLoopPolicyStatus() == null || faultBody.getClosedLoopPolicyStatus().isEmpty()){
328 responseString.append("<b>Policy Status</b>: <i>Policy Status is required" + HTML_ITALICS_LNBREAK);
331 if(faultBody.getConditions() == null){
332 responseString.append("<b>Conditions</b>: <i>Select At least one Condition" + HTML_ITALICS_LNBREAK);
335 if(faultBody.getGeoLink() != null && !faultBody.getGeoLink().isEmpty()){
336 String result = PolicyUtils.policySpecialCharWithSpaceValidator(faultBody.getGeoLink());
337 if(!result.contains(SUCCESS)){
338 responseString.append("<b>GeoLink</b>:<i>" + result + HTML_ITALICS_LNBREAK);
342 if(faultBody.getAgingWindow() == 0){
343 responseString.append("<b>Aging Window</b>: <i>Aging Window is required" + HTML_ITALICS_LNBREAK);
346 if(faultBody.getTimeInterval() == 0){
347 responseString.append("<b>Time Interval</b>: <i>Time Interval is required" + HTML_ITALICS_LNBREAK);
350 if(faultBody.getRetrys() == 0){
351 responseString.append("<b>Number of Retries</b>: <i>Number of Retries is required" + HTML_ITALICS_LNBREAK);
354 if(faultBody.getTimeOutvPRO() == 0){
355 responseString.append("<b>APP-C Timeout</b>: <i>APP-C Timeout is required" + HTML_ITALICS_LNBREAK);
358 if(faultBody.getTimeOutRuby() == 0){
359 responseString.append("<b>TimeOutRuby</b>: <i>TimeOutRuby is required" + HTML_ITALICS_LNBREAK);
362 if(faultBody.getVnfType() == null || faultBody.getVnfType().isEmpty()){
363 responseString.append("<b>Vnf Type</b>: <i>Vnf Type is required" + HTML_ITALICS_LNBREAK);
367 responseString.append("<b>D2/Virtualized Services</b>: <i>Select atleast one D2/Virtualized Services" + HTML_ITALICS_LNBREAK);
368 responseString.append("<b>vPRO Actions</b>: <i>vPRO Actions is required" + HTML_ITALICS_LNBREAK);
369 responseString.append("<b>Aging Window</b>: <i>Aging Window is required" + HTML_ITALICS_LNBREAK);
370 responseString.append("<b>Policy Status</b>: <i>Policy Status is required" + HTML_ITALICS_LNBREAK);
371 responseString.append("<b>Conditions</b>: <i>Select Atleast one Condition" + HTML_ITALICS_LNBREAK);
372 responseString.append("<b>PEP Name</b>: <i>PEP Name is required" + HTML_ITALICS_LNBREAK);
373 responseString.append("<b>PEP Action</b>: <i>PEP Action is required" + HTML_ITALICS_LNBREAK);
374 responseString.append("<b>Time Interval</b>: <i>Time Interval is required" + HTML_ITALICS_LNBREAK);
375 responseString.append("<b>Number of Retries</b>: <i>Number of Retries is required" + HTML_ITALICS_LNBREAK);
376 responseString.append("<b>APP-C Timeout</b>: <i>APP-C Timeout is required" + HTML_ITALICS_LNBREAK);
377 responseString.append("<b>TimeOutRuby</b>: <i>TimeOutRuby is required" + HTML_ITALICS_LNBREAK);
378 responseString.append("<b>Vnf Type</b>: <i>Vnf Type is required" + HTML_ITALICS_LNBREAK);
383 if (MICROSERVICES.equals(policyData.getConfigPolicyType())){
384 if(!Strings.isNullOrEmpty(policyData.getServiceType())){
385 pullJsonKeyPairs((JsonNode) policyData.getPolicyJSON());
387 String service = null;
388 String version = null;
389 if (policyData.getServiceType().contains("-v")){
390 service = policyData.getServiceType().split("-v")[0];
391 version = policyData.getServiceType().split("-v")[1];
393 service = policyData.getServiceType();
394 version = policyData.getVersion();
397 if(!Strings.isNullOrEmpty(version)) {
398 MicroServiceModels returnModel = getAttributeObject(service, version);
400 if(returnModel != null) {
401 String annotation = returnModel.getAnnotation();
402 if (!Strings.isNullOrEmpty(annotation)){
403 Map<String, String> rangeMap = Splitter.on(",").withKeyValueSeparator("=").split(annotation);
404 for (Entry<String, String> rMap : rangeMap.entrySet()){
405 if (rMap.getValue().contains("range::")){
406 String value = mapAttribute.get(rMap.getKey().trim());
407 String[] tempString = rMap.getValue().split("::")[1].split("-");
408 int startNum = Integer.parseInt(tempString[0]);
409 int endNum = Integer.parseInt(tempString[1]);
410 String returnString = "InvalidreturnModel Range:" + rMap.getKey() + " must be between "
411 + startNum + " - " + endNum + ",";
414 if (PolicyUtils.isInteger(value.replace("\"", ""))){
415 int result = Integer.parseInt(value.replace("\"", ""));
416 if (result < startNum || result > endNum){
417 responseString.append(returnString);
421 responseString.append(returnString);
425 responseString.append("<b>"+rMap.getKey()+"</b>:<i>" + rMap.getKey()
426 + " is required for the MicroService model " + service + HTML_ITALICS_LNBREAK);
434 responseString.append("<b>Micro Service Model</b>:<i> Invalid Model. The model name, " + service +
435 " of version, " + version + " was not found in the dictionary" + HTML_ITALICS_LNBREAK);
439 responseString.append("<b>Micro Version</b>:<i> Micro Service Version is required" + HTML_ITALICS_LNBREAK);
443 responseString.append("<b>Micro Service</b>:<i> Micro Service is required" + HTML_ITALICS_LNBREAK);
447 if(Strings.isNullOrEmpty(policyData.getPriority())){
448 responseString.append("<b>Priority</b>:<i> Priority is required" + HTML_ITALICS_LNBREAK);
453 if (DECISION_POLICY.equalsIgnoreCase(policyData.getPolicyType())){
454 if(!Strings.isNullOrEmpty(policyData.getOnapName())){
455 String onapNameValidate = PolicyUtils.policySpecialCharValidator(policyData.getOnapName());
456 if(!onapNameValidate.contains(SUCCESS)){
457 responseString.append("OnapName:" + onapNameValidate + "<br>");
461 responseString.append("Onap Name: Onap Name Should not be empty" + "<br>");
465 if("Rainy_Day".equals(policyData.getRuleProvider())){
466 if(policyData.getRainyday()==null){
467 responseString.append("<b> Rainy Day Parameters are Required </b><br>");
470 if(Strings.isNullOrEmpty(policyData.getRainyday().getServiceType())){
471 responseString.append("Rainy Day <b>Service Type</b> is Required<br>");
474 if(Strings.isNullOrEmpty(policyData.getRainyday().getVnfType())){
475 responseString.append("Rainy Day <b>VNF Type</b> is Required<br>");
478 if(Strings.isNullOrEmpty(policyData.getRainyday().getBbid())){
479 responseString.append("Rainy Day <b>Building Block ID</b> is Required<br>");
482 if(Strings.isNullOrEmpty(policyData.getRainyday().getWorkstep())){
483 responseString.append("Rainy Day <b>Work Step</b> is Required<br>");
486 if(!policyData.getRainyday().getTreatmentTableChoices().isEmpty() &&
487 policyData.getRainyday().getTreatmentTableChoices() != null){
489 for(Object treatmentMap: policyData.getRainyday().getTreatmentTableChoices()){
490 String errorCode = null;
491 String treatment = null;
492 if(treatmentMap instanceof LinkedHashMap<?, ?>){
494 if(((LinkedHashMap<?, ?>) treatmentMap).containsKey("errorcode")){
495 errorCode = ((LinkedHashMap<?, ?>) treatmentMap).get("errorcode").toString();
497 if(((LinkedHashMap<?, ?>) treatmentMap).containsKey("treatment")){
498 treatment = ((LinkedHashMap<?, ?>) treatmentMap).get("treatment").toString();
502 if(Strings.isNullOrEmpty(errorCode) && Strings.isNullOrEmpty(treatment)){
503 responseString.append("Rainy Day <b>Error Code</b> and <b>Desired Treatment</b> cannot be empty<br>");
507 if(Strings.isNullOrEmpty(errorCode)){
508 responseString.append("Rainy Day <b>Error Code</b> is Required for each Desired Treatment<br>");
512 if(Strings.isNullOrEmpty(treatment)){
513 responseString.append("Rainy Day <b>Desired Treatment</b> is Required for each Error Code<br>");
520 responseString.append("Rainy Day <b>Desired Automated Treatments</b> are Required<br>");
526 if("GUARD_YAML".equals(policyData.getRuleProvider()) || "GUARD_BL_YAML".equals(policyData.getRuleProvider())){
527 if(policyData.getYamlparams()==null){
528 responseString.append("<b> Guard Params are Required </b>" + "<br>");
531 if(Strings.isNullOrEmpty(policyData.getYamlparams().getActor())){
532 responseString.append("Guard Params <b>Actor</b> is Required " + "<br>");
535 if(Strings.isNullOrEmpty(policyData.getYamlparams().getRecipe())){
536 responseString.append("Guard Params <b>Recipe</b> is Required " + "<br>");
539 if(Strings.isNullOrEmpty(policyData.getYamlparams().getGuardActiveStart())){
540 responseString.append("Guard Params <b>Guard Active Start</b> is Required " + "<br>");
543 if(Strings.isNullOrEmpty(policyData.getYamlparams().getGuardActiveEnd())){
544 responseString.append("Guard Params <b>Guard Active End</b> is Required " + "<br>");
547 if("GUARD_YAML".equals(policyData.getRuleProvider())){
548 if(Strings.isNullOrEmpty(policyData.getYamlparams().getLimit())){
549 responseString.append(" Guard Params <b>Limit</b> is Required " + "<br>");
551 }else if(!PolicyUtils.isInteger(policyData.getYamlparams().getLimit())){
552 responseString.append(" Guard Params <b>Limit</b> Should be Integer " + "<br>");
555 if(Strings.isNullOrEmpty(policyData.getYamlparams().getTimeWindow())){
556 responseString.append("Guard Params <b>Time Window</b> is Required" + "<br>");
558 }else if(!PolicyUtils.isInteger(policyData.getYamlparams().getTimeWindow())){
559 responseString.append(" Guard Params <b>Time Window</b> Should be Integer " + "<br>");
562 if(Strings.isNullOrEmpty(policyData.getYamlparams().getTimeUnits())){
563 responseString.append("Guard Params <b>Time Units</b> is Required" + "<br>");
566 }else if("GUARD_BL_YAML".equals(policyData.getRuleProvider())){
567 if(policyData.getYamlparams().getBlackList()==null || policyData.getYamlparams().getBlackList().isEmpty()){
568 responseString.append(" Guard Params <b>BlackList</b> is Required " + "<br>");
571 for(String blackList: policyData.getYamlparams().getBlackList()){
572 if(blackList==null || !(SUCCESS.equals(PolicyUtils.policySpecialCharValidator(blackList)))){
573 responseString.append(" Guard Params <b>BlackList</b> Should be valid String" + "<br>");
584 if(ACTION_POLICY.equalsIgnoreCase(policyData.getPolicyType())){
585 if(!Strings.isNullOrEmpty(policyData.getActionPerformer())){
586 String actionPerformer = PolicyUtils.policySpecialCharValidator(policyData.getActionPerformer());
587 if(!actionPerformer.contains(SUCCESS)){
588 responseString.append("ActionPerformer:" + actionPerformer + "<br>");
592 responseString.append("ActionPerformer: ActionPerformer Should not be empty" + "<br>");
595 if(policyData.getAttributes() != null){
596 for(Object attribute : policyData.getAttributes()){
597 if(attribute instanceof LinkedHashMap<?, ?>){
599 //This is for validation check if the value exists or not
600 String key = ((LinkedHashMap<?, ?>) attribute).get("key").toString();
601 String value = ((LinkedHashMap<?, ?>) attribute).get("value").toString();
602 if("".equals(key) || "".equals(value)){
603 responseString.append(EMPTY_COMPONENT_ATTR + "<br>");
608 LOGGER.error("This is a Policy Validation check" +e);
609 responseString.append(EMPTY_COMPONENT_ATTR + "<br>");
616 responseString.append(EMPTY_COMPONENT_ATTR + "<br>");
619 if(!Strings.isNullOrEmpty(policyData.getActionAttributeValue())){
620 String actionAttribute = PolicyUtils.policySpecialCharValidator(policyData.getActionAttributeValue());
621 if(!actionAttribute.contains(SUCCESS)){
622 responseString.append("ActionAttribute:" + actionAttribute + "<br>");
626 responseString.append("ActionAttribute: ActionAttribute Should not be empty" + "<br>");
630 if(!policyData.getRuleAlgorithmschoices().isEmpty()){
631 for(Object attribute : policyData.getRuleAlgorithmschoices()){
632 if(attribute instanceof LinkedHashMap<?, ?>){
634 String label = ((LinkedHashMap<?, ?>) attribute).get("id").toString();
635 String key = ((LinkedHashMap<?, ?>) attribute).get("dynamicRuleAlgorithmField1").toString();
636 String rule = ((LinkedHashMap<?, ?>) attribute).get("dynamicRuleAlgorithmCombo").toString();
637 String value = ((LinkedHashMap<?, ?>) attribute).get("dynamicRuleAlgorithmField2").toString();
639 if(Strings.isNullOrEmpty(label) || Strings.isNullOrEmpty(key) || Strings.isNullOrEmpty(rule) || Strings.isNullOrEmpty(value)){
640 responseString.append("Rule Algorithms: One or more Fields in Rule Algorithms is Empty." + "<br>");
644 LOGGER.error("This is a Policy Validation check" +e);
645 responseString.append("Rule Algorithms: One or more Fields in Rule Algorithms is Empty." + "<br>");
654 if(CONFIG_POLICY.equals(policyData.getPolicyType())){
657 if(commonClassDao!=null){
658 List<Object> spData = commonClassDao.getDataById(SafePolicyWarning.class, "riskType", policyData.getRiskType());
659 if (!spData.isEmpty()){
660 SafePolicyWarning safePolicyWarningData = (SafePolicyWarning) spData.get(0);
661 value = "Message:" + safePolicyWarningData.getMessage();
664 responseString.append(SUCCESS + "@#"+ value);
668 responseString.append(SUCCESS);
672 return responseString;
675 LOGGER.error("Exception Occured during Policy Validation" +e);
680 protected String emailValidation(String email, String response){
682 String validateEmail = PolicyUtils.validateEmailAddress(email.replace("\"", ""));
683 if(!validateEmail.contains(SUCCESS)){
684 response += "<b>Email</b>:<i>" + validateEmail + HTML_ITALICS_LNBREAK;
692 private MicroServiceModels getAttributeObject(String name, String version) {
693 MicroServiceModels workingModel = null;
695 List<Object> microServiceModelsData = commonClassDao.getDataById(MicroServiceModels.class, "modelName:version", name+":"+version);
696 if(microServiceModelsData != null){
697 workingModel = (MicroServiceModels) microServiceModelsData.get(0);
700 String message = XACMLErrorConstants.ERROR_DATA_ISSUE + "Invalid Template. The template name, "
701 + name + " was not found in the dictionary: ";
702 LOGGER.error(XACMLErrorConstants.ERROR_DATA_ISSUE + message + e);
709 private void pullJsonKeyPairs(JsonNode rootNode) {
710 Iterator<Map.Entry<String, JsonNode>> fieldsIterator = rootNode.fields();
712 while (fieldsIterator.hasNext()) {
713 Map.Entry<String, JsonNode> field = fieldsIterator.next();
714 final String key = field.getKey();
715 final JsonNode value = field.getValue();
716 if (value.isContainerNode() && !value.isArray()) {
717 pullJsonKeyPairs(value); // RECURSIVE CALL
719 if (value.isArray()){
720 String newValue = StringUtils.replaceEach(value.toString(), new String[]{"[", "]", "\""}, new String[]{"", "", ""});
721 mapAttribute.put(key, newValue);
723 mapAttribute.put(key, value.toString().trim());