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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
package org.openecomp.sdc.be.components.validation;
import fj.data.Either;
import org.apache.commons.lang3.StringUtils;
import org.openecomp.sdc.be.components.impl.exceptions.ComponentException;
import org.openecomp.sdc.be.config.BeEcompErrorManager;
import org.openecomp.sdc.be.dao.api.ActionStatus;
import org.openecomp.sdc.be.impl.ComponentsUtils;
import org.openecomp.sdc.be.model.User;
import org.openecomp.sdc.be.user.IUserBusinessLogic;
import org.openecomp.sdc.be.user.Role;
import org.openecomp.sdc.common.log.wrappers.Logger;
import java.util.List;
@org.springframework.stereotype.Component
public class UserValidations {
private static final Logger log = Logger.getLogger(UserValidations.class);
private final IUserBusinessLogic userAdmin;
private final ComponentsUtils componentsUtils;
public UserValidations(IUserBusinessLogic userAdmin, ComponentsUtils componentsUtils) {
this.userAdmin = userAdmin;
this.componentsUtils = componentsUtils;
}
public User validateUserExists(String userId, String ecompErrorContext, boolean inTransaction) {
Either<User, ActionStatus> eitherCreator = userAdmin.getUser(userId, inTransaction);
if (eitherCreator.isRight() || eitherCreator.left().value() == null) {
ActionStatus status;
if (eitherCreator.right().value().equals(ActionStatus.USER_NOT_FOUND)) {
log.debug("validateUserExists - not authorized user, userId {}", userId);
status = ActionStatus.AUTH_FAILED;
} else {
log.debug("validateUserExists - failed to authorize user, userId {}", userId);
status = eitherCreator.right().value();
}
log.debug("User is not listed. userId {}", userId);
BeEcompErrorManager.getInstance().logBeUserMissingError(ecompErrorContext, userId);
throw new ComponentException(status);
}
return eitherCreator.left().value();
}
public void validateUserRole(User user, List<Role> roles) {
Role userRole = Role.valueOf(user.getRole());
if (roles != null) {
if (!roles.contains(userRole)) {
log.debug("user is not in appropriate role to perform action");
throw new ComponentException(ActionStatus.RESTRICTED_OPERATION);
}
}
}
public Either<User, ActionStatus> validateUserExistsActionStatus(String userId, String ecompErrorContext) {
Either<User, ActionStatus> eitherCreator = userAdmin.getUser(userId, false);
if (eitherCreator.isRight() || eitherCreator.left().value() == null) {
if (eitherCreator.right().value().equals(ActionStatus.USER_NOT_FOUND)) {
log.debug("validateUserExists - not authorized user, userId {}", userId);
Either.right(ActionStatus.RESTRICTED_OPERATION);
} else {
log.debug("validateUserExists - failed to authorize user, userId {}", userId);
}
log.debug("User is not listed. userId {}", userId);
BeEcompErrorManager.getInstance().logBeUserMissingError(ecompErrorContext, userId);
return Either.right(eitherCreator.right().value());
}
return Either.left(eitherCreator.left().value());
}
public User validateUserNotEmpty(User user, String ecompErrorContext) {
String userId = user.getUserId();
if (StringUtils.isEmpty(userId)) {
log.debug("User header is missing ");
BeEcompErrorManager.getInstance().logBeUserMissingError(ecompErrorContext, user.getUserId());
throw new ComponentException(ActionStatus.MISSING_INFORMATION);
}
return user;
}
public User validateUserExists(User user, String ecompErrorContext, boolean inTransaction) {
return validateUserExists(user.getUserId(), ecompErrorContext, inTransaction);
}
public void validateUserExist(String userId, String ecompErrorContext) {
validateUserExists(userId, ecompErrorContext, false);
}
}
|