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; } }