SEC-1022: Remove use of static methods/initializers in Acl Permissions. Added extra constructors to DefaultPermissionFactory to allow injection of custom permissions to the registry.
This commit is contained in:
parent
24155d4abe
commit
9f76db0606
|
@ -35,8 +35,6 @@ public class BasePermission extends AbstractPermission {
|
||||||
public static final Permission DELETE = new BasePermission(1 << 3, 'D'); // 8
|
public static final Permission DELETE = new BasePermission(1 << 3, 'D'); // 8
|
||||||
public static final Permission ADMINISTRATION = new BasePermission(1 << 4, 'A'); // 16
|
public static final Permission ADMINISTRATION = new BasePermission(1 << 4, 'A'); // 16
|
||||||
|
|
||||||
protected static DefaultPermissionFactory defaultPermissionFactory = new DefaultPermissionFactory();
|
|
||||||
|
|
||||||
protected BasePermission(int mask) {
|
protected BasePermission(int mask) {
|
||||||
super(mask);
|
super(mask);
|
||||||
}
|
}
|
||||||
|
@ -44,21 +42,4 @@ public class BasePermission extends AbstractPermission {
|
||||||
protected BasePermission(int mask, char code) {
|
protected BasePermission(int mask, char code) {
|
||||||
super(mask, code);
|
super(mask, code);
|
||||||
}
|
}
|
||||||
|
|
||||||
// public final static Permission buildFromMask(int mask) {
|
|
||||||
// return defaultPermissionFactory.buildFromMask(mask);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// public final static Permission[] buildFromMask(int[] masks) {
|
|
||||||
// return defaultPermissionFactory.buildFromMask(masks);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// public final static Permission buildFromName(String name) {
|
|
||||||
// return defaultPermissionFactory.buildFromName(name);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// public final static Permission[] buildFromName(String[] names) {
|
|
||||||
// return defaultPermissionFactory.buildFromName(names);
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,36 +7,59 @@ import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.springframework.security.acls.jdbc.LookupStrategy;
|
|
||||||
import org.springframework.security.acls.model.Permission;
|
import org.springframework.security.acls.model.Permission;
|
||||||
import org.springframework.util.Assert;
|
import org.springframework.util.Assert;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default implementation of {@link PermissionFactory}.
|
* Default implementation of {@link PermissionFactory}.
|
||||||
* <p>
|
* <p>
|
||||||
* Generally this class will be used by a {@link Permission} instance, as opposed to being dependency
|
* Used as a strategy by classes which wish to map integer masks and permission names to <tt>Permission</tt>
|
||||||
* injected into a {@link LookupStrategy} or similar. Nevertheless, the latter mode of operation is
|
* instances for use with the ACL implementation.
|
||||||
* fully supported (in which case your {@link Permission} implementations probably should extend
|
* <p>
|
||||||
* {@link AbstractPermission} instead of {@link AbstractRegisteredPermission}).
|
* Maintains a registry of permission names and masks to <tt>Permission</tt> instances.
|
||||||
*
|
*
|
||||||
* @author Ben Alex
|
* @author Ben Alex
|
||||||
|
* @author Luke Taylor
|
||||||
* @since 2.0.3
|
* @since 2.0.3
|
||||||
*/
|
*/
|
||||||
public class DefaultPermissionFactory implements PermissionFactory {
|
public class DefaultPermissionFactory implements PermissionFactory {
|
||||||
private final Map<Integer, Permission> registeredPermissionsByInteger = new HashMap<Integer, Permission>();
|
private final Map<Integer, Permission> registeredPermissionsByInteger = new HashMap<Integer, Permission>();
|
||||||
private final Map<String, Permission> registeredPermissionsByName = new HashMap<String, Permission>();
|
private final Map<String, Permission> registeredPermissionsByName = new HashMap<String, Permission>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers the <tt>Permission</tt> fields from the <tt>BasePermission</tt> class.
|
||||||
|
*/
|
||||||
public DefaultPermissionFactory() {
|
public DefaultPermissionFactory() {
|
||||||
registerPublicPermissions(BasePermission.class);
|
registerPublicPermissions(BasePermission.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Permit registration of a {@link DefaultPermissionFactory} class. The class must provide
|
* Registers the <tt>Permission</tt> fields from the supplied class.
|
||||||
* public static fields of type {@link Permission} to represent the possible permissions.
|
*/
|
||||||
|
public DefaultPermissionFactory(Class<? extends Permission> permissionClass) {
|
||||||
|
registerPublicPermissions(permissionClass);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers a map of named <tt>Permission</tt> instances.
|
||||||
|
*
|
||||||
|
* @param namedPermissions the map of <tt>Permission</tt>s, keyed by name.
|
||||||
|
*/
|
||||||
|
public DefaultPermissionFactory(Map<String, ? extends Permission> namedPermissions) {
|
||||||
|
for (String name : namedPermissions.keySet()) {
|
||||||
|
registerPermission(namedPermissions.get(name), name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers the public static fields of type {@link Permission} for a give class.
|
||||||
|
* <p>
|
||||||
|
* These permissions will be registered under the name of the field. See {@link BasePermission}
|
||||||
|
* for an example.
|
||||||
*
|
*
|
||||||
* @param clazz a {@link Permission} class with public static fields to register
|
* @param clazz a {@link Permission} class with public static fields to register
|
||||||
*/
|
*/
|
||||||
public void registerPublicPermissions(Class<? extends Permission> clazz) {
|
protected void registerPublicPermissions(Class<? extends Permission> clazz) {
|
||||||
Assert.notNull(clazz, "Class required");
|
Assert.notNull(clazz, "Class required");
|
||||||
|
|
||||||
Field[] fields = clazz.getFields();
|
Field[] fields = clazz.getFields();
|
||||||
|
@ -56,7 +79,7 @@ public class DefaultPermissionFactory implements PermissionFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerPermission(Permission perm, String permissionName) {
|
protected void registerPermission(Permission perm, String permissionName) {
|
||||||
Assert.notNull(perm, "Permission required");
|
Assert.notNull(perm, "Permission required");
|
||||||
Assert.hasText(permissionName, "Permission name required");
|
Assert.hasText(permissionName, "Permission name required");
|
||||||
|
|
||||||
|
@ -72,8 +95,8 @@ public class DefaultPermissionFactory implements PermissionFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Permission buildFromMask(int mask) {
|
public Permission buildFromMask(int mask) {
|
||||||
if (registeredPermissionsByInteger.containsKey(new Integer(mask))) {
|
if (registeredPermissionsByInteger.containsKey(Integer.valueOf(mask))) {
|
||||||
// The requested mask has an exactly match against a statically-defined Permission, so return it
|
// The requested mask has an exact match against a statically-defined Permission, so return it
|
||||||
return (Permission) registeredPermissionsByInteger.get(new Integer(mask));
|
return (Permission) registeredPermissionsByInteger.get(new Integer(mask));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,7 +107,7 @@ public class DefaultPermissionFactory implements PermissionFactory {
|
||||||
int permissionToCheck = 1 << i;
|
int permissionToCheck = 1 << i;
|
||||||
|
|
||||||
if ((mask & permissionToCheck) == permissionToCheck) {
|
if ((mask & permissionToCheck) == permissionToCheck) {
|
||||||
Permission p = (Permission) registeredPermissionsByInteger.get(new Integer(permissionToCheck));
|
Permission p = (Permission) registeredPermissionsByInteger.get(Integer.valueOf(permissionToCheck));
|
||||||
Assert.state(p != null, "Mask " + permissionToCheck + " does not have a corresponding static Permission");
|
Assert.state(p != null, "Mask " + permissionToCheck + " does not have a corresponding static Permission");
|
||||||
permission.set(p);
|
permission.set(p);
|
||||||
}
|
}
|
||||||
|
@ -93,19 +116,19 @@ public class DefaultPermissionFactory implements PermissionFactory {
|
||||||
return permission;
|
return permission;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Permission[] buildFromMask(int[] masks) {
|
// public Permission[] buildFromMask(int[] masks) {
|
||||||
if ((masks == null) || (masks.length == 0)) {
|
// if ((masks == null) || (masks.length == 0)) {
|
||||||
return new Permission[0];
|
// return new Permission[0];
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
Permission[] permissions = new Permission[masks.length];
|
// Permission[] permissions = new Permission[masks.length];
|
||||||
|
//
|
||||||
for (int i = 0; i < masks.length; i++) {
|
// for (int i = 0; i < masks.length; i++) {
|
||||||
permissions[i] = buildFromMask(masks[i]);
|
// permissions[i] = buildFromMask(masks[i]);
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
return permissions;
|
// return permissions;
|
||||||
}
|
// }
|
||||||
|
|
||||||
public Permission buildFromName(String name) {
|
public Permission buildFromName(String name) {
|
||||||
Assert.isTrue(registeredPermissionsByName.containsKey(name), "Unknown permission '" + name + "'");
|
Assert.isTrue(registeredPermissionsByName.containsKey(name), "Unknown permission '" + name + "'");
|
||||||
|
|
|
@ -25,6 +25,7 @@ import org.springframework.security.acls.model.Permission;
|
||||||
*/
|
*/
|
||||||
public class SpecialPermission extends BasePermission {
|
public class SpecialPermission extends BasePermission {
|
||||||
public static final Permission ENTER = new SpecialPermission(1 << 5, 'E'); // 32
|
public static final Permission ENTER = new SpecialPermission(1 << 5, 'E'); // 32
|
||||||
|
public static final Permission LEAVE = new SpecialPermission(1 << 6, 'L');
|
||||||
|
|
||||||
protected SpecialPermission(int mask, char code) {
|
protected SpecialPermission(int mask, char code) {
|
||||||
super(mask, code);
|
super(mask, code);
|
||||||
|
|
Loading…
Reference in New Issue