From 95c6ecdb1e1ae61e1ca8023d6d5db4090f0bc69b Mon Sep 17 00:00:00 2001 From: Luke Taylor Date: Tue, 29 Jan 2008 11:33:38 +0000 Subject: [PATCH] SEC-468: Added Mike Wiesner's patch for AspectJ annotation support. --- .../aspectj/AspectJAnnotationCallback.java | 16 +++++ .../AspectJAnnotationSecurityInterceptor.java | 61 +++++++++++++++++++ 2 files changed, 77 insertions(+) create mode 100644 core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationCallback.java create mode 100644 core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationSecurityInterceptor.java diff --git a/core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationCallback.java b/core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationCallback.java new file mode 100644 index 0000000000..0956d2aa7b --- /dev/null +++ b/core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationCallback.java @@ -0,0 +1,16 @@ +package org.springframework.security.intercept.method.aspectj; + + +/** + * Called by the {@link AspectJAnnotationSecurityInterceptor} when it wishes for the + * AspectJ processing to continue. + * + * @author Mike Wiesner + * @version $Id$ + */ + +public interface AspectJAnnotationCallback { + //~ Methods ======================================================================================================== + + Object proceedWithObject(); +} diff --git a/core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationSecurityInterceptor.java b/core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationSecurityInterceptor.java new file mode 100644 index 0000000000..2d044b0330 --- /dev/null +++ b/core/src/main/java/org/springframework/security/intercept/method/aspectj/AspectJAnnotationSecurityInterceptor.java @@ -0,0 +1,61 @@ +package org.springframework.security.intercept.method.aspectj; + +import org.springframework.security.intercept.AbstractSecurityInterceptor; +import org.springframework.security.intercept.InterceptorStatusToken; +import org.springframework.security.intercept.ObjectDefinitionSource; +import org.springframework.security.intercept.method.MethodDefinitionSource; + +import org.aspectj.lang.JoinPoint; + +/** + * AspectJ interceptor that supports @Aspect notation. + * + * @author Mike Wiesner + * @version $Id$ + */ +public class AspectJAnnotationSecurityInterceptor extends AbstractSecurityInterceptor { + //~ Instance fields ================================================================================================ + + private MethodDefinitionSource objectDefinitionSource; + + //~ Methods ======================================================================================================== + + public MethodDefinitionSource getObjectDefinitionSource() { + return this.objectDefinitionSource; + } + + public Class getSecureObjectClass() { + return JoinPoint.class; + } + + /** + * This method should be used to enforce security on a JoinPoint. + * + * @param jp The AspectJ joint point being invoked which requires a security decision + * @param advisorProceed the advice-defined anonymous class that implements AspectJCallback containing + * a simple return proceed(); statement + * + * @return The returned value from the method invocation + */ + public Object invoke(JoinPoint jp, AspectJAnnotationCallback advisorProceed) throws Throwable { + Object result = null; + InterceptorStatusToken token = super.beforeInvocation(jp); + + try { + result = advisorProceed.proceedWithObject(); + } finally { + result = super.afterInvocation(token, result); + } + + return result; + } + + public ObjectDefinitionSource obtainObjectDefinitionSource() { + return this.objectDefinitionSource; + } + + public void setObjectDefinitionSource(MethodDefinitionSource newSource) { + this.objectDefinitionSource = newSource; + } + +}