| Coloured | Raw |
1// Copyright 2007, Tim Vernum 2// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation 3// files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, 4// modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the 5// Software is furnished to do so, subject to the following conditions: 6// The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 7// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE 8// WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 9// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 10// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 11 12package security.constraint; 13 14import org.aopalliance.intercept.MethodInterceptor; 15import org.aopalliance.intercept.MethodInvocation; 16 17public class AccessControlInterceptor implements MethodInterceptor 18{ 19 private final AccessChecker _checker; 20 21 public AccessControlInterceptor() 22 { 23 _checker = new AccessChecker(); 24 } 25 26 public Object invoke(MethodInvocation invocation) throws Throwable 27 { 28 AccessControl control = getAnnotation(invocation); 29 if (control != null) 30 { 31 if (!_checker.isAccessAllowed(control)) 32 { 33 throw new SecurityException("No access to " + invocation.getMethod() + " with access control " + control); 34 } 35 } 36 return invocation.proceed(); 37 } 38 39 private AccessControl getAnnotation(MethodInvocation invocation) 40 { 41 AccessControl annotation = invocation.getMethod().getAnnotation(AccessControl.class); 42 if (annotation == null) 43 { 44 annotation = invocation.getThis().getClass().getAnnotation(AccessControl.class); 45 } 46 return annotation; 47 } 48 49}
// Copyright 2007, Tim Vernum
// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation
// files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy,
// modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
// WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package security.constraint;
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
public class AccessControlInterceptor implements MethodInterceptor
{
private final AccessChecker _checker;
public AccessControlInterceptor()
{
_checker = new AccessChecker();
}
public Object invoke(MethodInvocation invocation) throws Throwable
{
AccessControl control = getAnnotation(invocation);
if (control != null)
{
if (!_checker.isAccessAllowed(control))
{
throw new SecurityException("No access to " + invocation.getMethod() + " with access control " + control);
}
}
return invocation.proceed();
}
private AccessControl getAnnotation(MethodInvocation invocation)
{
AccessControl annotation = invocation.getMethod().getAnnotation(AccessControl.class);
if (annotation == null)
{
annotation = invocation.getThis().getClass().getAnnotation(AccessControl.class);
}
return annotation;
}
}