use of org.apache.archiva.redback.rbac.RbacManagerException in project archiva by apache.
the class ArchivaLockedAdminEnvironmentCheck method validateEnvironment.
/**
* This environment check will unlock system administrator accounts that are locked on the restart of the
* application when the environment checks are processed.
*
* @param violations
*/
@Override
public void validateEnvironment(List<String> violations) {
if (!checked) {
for (UserManager userManager : userManagers) {
if (userManager.isReadOnly()) {
continue;
}
List<String> roles = new ArrayList<>();
roles.add(RedbackRoleConstants.SYSTEM_ADMINISTRATOR_ROLE);
List<UserAssignment> systemAdminstrators;
try {
systemAdminstrators = rbacManager.getUserAssignmentsForRoles(roles);
for (UserAssignment userAssignment : systemAdminstrators) {
try {
User admin = userManager.findUser(userAssignment.getPrincipal());
if (admin.isLocked()) {
log.info("Unlocking system administrator: {}", admin.getUsername());
admin.setLocked(false);
userManager.updateUser(admin);
}
} catch (UserNotFoundException ne) {
log.warn("Dangling UserAssignment -> {}", userAssignment.getPrincipal());
} catch (UserManagerException e) {
log.warn("fail to find user {} for admin unlock check: {}", userAssignment.getPrincipal(), e.getMessage());
}
}
} catch (RbacManagerException e) {
log.warn("Exception when checking for locked admin user: {}", e.getMessage(), e);
}
checked = true;
}
}
}
use of org.apache.archiva.redback.rbac.RbacManagerException in project archiva by apache.
the class ArchivaRbacManager method removePermission.
@Override
public void removePermission(Permission permission) throws RbacObjectNotFoundException, RbacObjectInvalidException, RbacManagerException {
boolean allFailed = true;
Exception lastException = null;
for (RBACManager rbacManager : rbacManagersPerId.values()) {
try {
rbacManager.removePermission(permission);
permissionsCache.remove(permission.getName());
allFailed = false;
} catch (Exception e) {
lastException = e;
}
}
if (lastException != null && allFailed) {
throw new RbacManagerException(lastException.getMessage(), lastException);
}
}
use of org.apache.archiva.redback.rbac.RbacManagerException in project archiva by apache.
the class ArchivaRbacManager method getRole.
@Override
public Role getRole(String roleName) throws RbacObjectNotFoundException, RbacManagerException {
Role el = rolesCache.get(roleName);
if (el != null) {
return el;
}
Exception lastException = null;
for (RBACManager rbacManager : rbacManagersPerId.values()) {
try {
Role role = rbacManager.getRole(roleName);
if (role != null) {
rolesCache.put(role.getName(), role);
return role;
}
} catch (Exception e) {
lastException = e;
}
}
log.debug("cannot find role for name: ‘{}", roleName);
if (lastException != null) {
throw new RbacManagerException(lastException.getMessage(), lastException);
}
return null;
}
use of org.apache.archiva.redback.rbac.RbacManagerException in project archiva by apache.
the class ArchivaRbacManager method getUserAssignmentsForRoles.
@Override
public List<UserAssignment> getUserAssignmentsForRoles(Collection<String> roleNames) throws RbacManagerException {
List<UserAssignment> allUserAssignments = new ArrayList<>();
boolean allFailed = true;
Exception lastException = null;
for (RBACManager rbacManager : rbacManagersPerId.values()) {
try {
List<UserAssignment> userAssignments = rbacManager.getUserAssignmentsForRoles(roleNames);
allUserAssignments.addAll(userAssignments);
allFailed = false;
} catch (Exception e) {
lastException = e;
}
}
if (lastException != null && allFailed) {
throw new RbacManagerException(lastException.getMessage(), lastException);
}
return allUserAssignments;
}
use of org.apache.archiva.redback.rbac.RbacManagerException in project archiva by apache.
the class ArchivaRbacManager method getAllResources.
@Override
public List<Resource> getAllResources() throws RbacManagerException {
Map<String, Resource> allResources = new HashMap<>();
boolean allFailed = true;
Exception lastException = null;
for (RBACManager rbacManager : rbacManagersPerId.values()) {
try {
List<Resource> resources = rbacManager.getAllResources();
for (Resource r : resources) {
allResources.put(r.getIdentifier(), r);
}
allFailed = false;
} catch (Exception e) {
lastException = e;
}
}
if (lastException != null && allFailed) {
throw new RbacManagerException(lastException.getMessage(), lastException);
}
return new ArrayList<>(allResources.values());
}
Aggregations