1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
package org.onap.sdc.dcae.rule.editor.validators;
import org.onap.sdc.common.onaplog.enums.LogLevel;
import org.onap.sdc.dcae.composition.restmodels.ruleeditor.Condition;
import org.onap.sdc.dcae.composition.restmodels.ruleeditor.TopoSearchAction;
import org.onap.sdc.dcae.errormng.ActionStatus;
import org.onap.sdc.dcae.errormng.ErrConfMgr;
import org.onap.sdc.dcae.errormng.ResponseFormat;
import org.onap.sdc.dcae.rule.editor.utils.ValidationUtils;
import org.springframework.util.CollectionUtils;
import java.util.List;
public class TopoSearchValidator extends BaseActionValidator<TopoSearchAction> {
private static TopoSearchValidator topoSearchValidator = new TopoSearchValidator();
public static TopoSearchValidator getInstance() {
return topoSearchValidator;
}
private TopoSearchValidator() {
}
private ConditionValidator conditionValidator = ConditionValidator.getInstance();
@Override
public boolean validate(TopoSearchAction action, List<ResponseFormat> errors) {
boolean valid = super.validate(action, errors);
if (action.conditionalSearch() && searchFilterHasNoneEmptyFields(action.searchFilter()) && !conditionValidator.validateConditionalAction(action.searchFilter(), errors)) {
valid = false;
}
if (!ValidationUtils.validateNotEmpty(action.searchField())) {
valid = false;
errors.add(ErrConfMgr.INSTANCE.getResponseFormat(ActionStatus.MISSING_ACTION_FIELD, null, "search field", action.getActionType(), action.strippedTarget()));
}
if (!ValidationUtils.validateNotEmpty(action.searchValue())) {
valid = false;
errors.add(ErrConfMgr.INSTANCE.getResponseFormat(ActionStatus.MISSING_ACTION_FIELD, null, "search value", action.getActionType(), action.strippedTarget()));
}
return validateEnrichOrUpdates(action, errors) && valid;
}
private boolean searchFilterHasNoneEmptyFields(Condition searchFilter) {
return ValidationUtils.validateNotEmpty(searchFilter.getLeft()) || ValidationUtils.validateNotEmpty(searchFilter.getOperator()) || !CollectionUtils.isEmpty(searchFilter.getRight()) && searchFilter.getRight().stream().anyMatch(ValidationUtils::validateNotEmpty);
}
private boolean validateEnrichOrUpdates(TopoSearchAction action, List<ResponseFormat> errors) {
if (!action.doEnrich()) {
return validateUpdatesMap(action, errors);
}
if (action.enrichFields().isEmpty() || !action.enrichFields().stream().allMatch(ValidationUtils::validateNotEmpty)) {
errors.add(ErrConfMgr.INSTANCE.getResponseFormat(ActionStatus.MISSING_ACTION_FIELD, null, "enrich fields", action.getActionType(), action.strippedTarget()));
return false;
}
return true;
}
private boolean validateUpdatesMap(TopoSearchAction action, List<ResponseFormat> errors) {
boolean valid = true;
try {
if (!action.updatesMap().entrySet().stream().allMatch(p -> ValidationUtils.validateNotEmpty(p.getKey()) && ValidationUtils.validateNotEmpty(p.getValue()))) {
valid = false;
errors.add(ErrConfMgr.INSTANCE.getResponseFormat(ActionStatus.MISSING_ACTION_FIELD, null, "key/value", action.getActionType(), action.strippedTarget()));
}
} catch (IllegalStateException err) {
valid = false;
errLogger.log(LogLevel.ERROR, this.getClass().getName(), "updates validation error: {}", err);
errors.add(ErrConfMgr.INSTANCE.getResponseFormat(ActionStatus.DUPLICATE_KEY, null));
}
return valid;
}
}
|