diff options
author | Olivier Lamy <olamy@apache.org> | 2013-02-21 14:37:38 +0000 |
---|---|---|
committer | Olivier Lamy <olamy@apache.org> | 2013-02-21 14:37:38 +0000 |
commit | c8adb4d6733095ef635b5b802756552009ae8992 (patch) | |
tree | bc175b53aff2202ba36956f0a154a248266bd80f /archiva-modules/archiva-web/archiva-web-common/src | |
parent | ea7cd81727b995143e16848356fd2fd064455f78 (diff) | |
download | archiva-c8adb4d6733095ef635b5b802756552009ae8992.tar.gz archiva-c8adb4d6733095ef635b5b802756552009ae8992.zip |
add some caching in the chained rbac manager
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1448661 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'archiva-modules/archiva-web/archiva-web-common/src')
-rw-r--r-- | archiva-modules/archiva-web/archiva-web-common/src/main/java/org/apache/archiva/web/security/ArchivaRbacManager.java | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/archiva-modules/archiva-web/archiva-web-common/src/main/java/org/apache/archiva/web/security/ArchivaRbacManager.java b/archiva-modules/archiva-web/archiva-web-common/src/main/java/org/apache/archiva/web/security/ArchivaRbacManager.java index 28080185f..fd24898bf 100644 --- a/archiva-modules/archiva-web/archiva-web-common/src/main/java/org/apache/archiva/web/security/ArchivaRbacManager.java +++ b/archiva-modules/archiva-web/archiva-web-common/src/main/java/org/apache/archiva/web/security/ArchivaRbacManager.java @@ -185,6 +185,13 @@ public class ArchivaRbacManager 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() ) { @@ -193,6 +200,7 @@ public class ArchivaRbacManager Role role = rbacManager.getRole( roleName ); if ( role != null ) { + rolesCache.put( role.getName(), role ); return role; } } @@ -250,6 +258,7 @@ public class ArchivaRbacManager try { rbacManager.removeRole( role ); + rolesCache.remove( role.getName() ); allFailed = false; } catch ( Exception e ) @@ -305,6 +314,13 @@ public class ArchivaRbacManager public Permission getPermission( String permissionName ) throws RbacObjectNotFoundException, RbacManagerException { + + Permission el = permissionsCache.get( permissionName ); + if ( el != null ) + { + return el; + } + Exception lastException = null; for ( RBACManager rbacManager : rbacManagersPerId.values() ) { @@ -313,6 +329,7 @@ public class ArchivaRbacManager Permission p = rbacManager.getPermission( permissionName ); if ( p != null ) { + permissionsCache.put( permissionName, p ); return p; } } @@ -369,6 +386,7 @@ public class ArchivaRbacManager try { rbacManager.removePermission( permission ); + permissionsCache.remove( permission.getName() ); allFailed = false; } catch ( Exception e ) @@ -417,6 +435,13 @@ public class ArchivaRbacManager public Operation getOperation( String operationName ) throws RbacObjectNotFoundException, RbacManagerException { + + Operation el = operationsCache.get( operationName ); + if ( el != null ) + { + return el; + } + Exception lastException = null; for ( RBACManager rbacManager : rbacManagersPerId.values() ) { @@ -425,6 +450,7 @@ public class ArchivaRbacManager Operation o = rbacManager.getOperation( operationName ); if ( o != null ) { + operationsCache.put( operationName, o ); return o; } } @@ -481,6 +507,7 @@ public class ArchivaRbacManager try { rbacManager.removeOperation( operation ); + operationsCache.remove( operation.getName() ); allFailed = false; } catch ( Exception e ) @@ -531,6 +558,12 @@ public class ArchivaRbacManager throws RbacObjectNotFoundException, RbacManagerException { + Resource el = resourcesCache.get( resourceIdentifier ); + if ( el != null ) + { + return el; + } + Exception lastException = null; for ( RBACManager rbacManager : rbacManagersPerId.values() ) { @@ -539,6 +572,7 @@ public class ArchivaRbacManager Resource r = rbacManager.getResource( resourceIdentifier ); if ( r != null ) { + resourcesCache.put( resourceIdentifier, r ); return r; } } @@ -595,6 +629,7 @@ public class ArchivaRbacManager try { rbacManager.removeResource( resource ); + resourcesCache.remove( resource.getIdentifier() ); allFailed = false; } catch ( Exception e ) @@ -643,6 +678,11 @@ public class ArchivaRbacManager public UserAssignment getUserAssignment( String principal ) throws RbacObjectNotFoundException, RbacManagerException { + UserAssignment el = userAssignmentsCache.get( principal ); + if ( el != null ) + { + return el; + } Exception lastException = null; for ( RBACManager rbacManager : rbacManagersPerId.values() ) @@ -652,6 +692,7 @@ public class ArchivaRbacManager UserAssignment ua = rbacManager.getUserAssignment( principal ); if ( ua != null ) { + userAssignmentsCache.put( principal, ua ); return ua; } } @@ -782,6 +823,7 @@ public class ArchivaRbacManager try { rbacManager.removeUserAssignment( userAssignment ); + userAssignmentsCache.remove( userAssignment.getPrincipal() ); allFailed = false; } catch ( Exception e ) @@ -800,6 +842,12 @@ public class ArchivaRbacManager public boolean roleExists( String name ) throws RbacManagerException { + Role r = rolesCache.get( name ); + if ( r != null ) + { + return true; + } + boolean allFailed = true; Exception lastException = null; for ( RBACManager rbacManager : rbacManagersPerId.values() ) |