|
@@ -0,0 +1,132 @@
|
|
|
+/* Copyright 2004, 2005 Acegi Technology Pty Limited
|
|
|
+ *
|
|
|
+ * Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
+ * you may not use this file except in compliance with the License.
|
|
|
+ * You may obtain a copy of the License at
|
|
|
+ *
|
|
|
+ * http://www.apache.org/licenses/LICENSE-2.0
|
|
|
+ *
|
|
|
+ * Unless required by applicable law or agreed to in writing, software
|
|
|
+ * distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
+ * See the License for the specific language governing permissions and
|
|
|
+ * limitations under the License.
|
|
|
+ */
|
|
|
+package net.sf.acegisecurity.annotation;
|
|
|
+
|
|
|
+import java.lang.annotation.Annotation;
|
|
|
+import java.lang.reflect.Field;
|
|
|
+import java.lang.reflect.Method;
|
|
|
+import java.util.Collection;
|
|
|
+import java.util.HashSet;
|
|
|
+import java.util.Set;
|
|
|
+
|
|
|
+import net.sf.acegisecurity.SecurityConfig;
|
|
|
+
|
|
|
+import org.springframework.metadata.Attributes;
|
|
|
+
|
|
|
+/**
|
|
|
+ * Java 5 Annotation <code>Attributes</code> metadata implementation used for
|
|
|
+ * secure method interception.
|
|
|
+ *
|
|
|
+ * <p>This <code>Attributes</code> implementation will return security
|
|
|
+ * configuration for classes described using the <code>Secured</code> Java 5
|
|
|
+ * annotation.
|
|
|
+ *
|
|
|
+ * <p>The <code>SecurityAnnotationAttributes</code> implementation can be used
|
|
|
+ * to configure a <code>MethodDefinitionAttributes</code> and
|
|
|
+ * <code>MethodSecurityInterceptor</code> bean definition (see below).
|
|
|
+ *
|
|
|
+ * <p>For example:
|
|
|
+ * <pre>
|
|
|
+ * <bean id="attributes"
|
|
|
+ * class="net.sf.acegisecurity.annotation.SecurityAnnotationAttributes"/>
|
|
|
+ *
|
|
|
+ * <bean id="objectDefinitionSource"
|
|
|
+ * class="net.sf.acegisecurity.intercept.method.MethodDefinitionAttributes">
|
|
|
+ * <property name="attributes">
|
|
|
+ * <ref local="attributes"/>
|
|
|
+ * </property>
|
|
|
+ * </bean>
|
|
|
+ *
|
|
|
+ * <bean id="securityInterceptor"
|
|
|
+ * class="net.sf.acegisecurity.intercept.method.aopalliance.MethodSecurityInterceptor">
|
|
|
+ * . . .
|
|
|
+ * <property name="objectDefinitionSource">
|
|
|
+ * <ref local="objectDefinitionSource"/>
|
|
|
+ * </property>
|
|
|
+ * </bean>
|
|
|
+ * </pre>
|
|
|
+ *
|
|
|
+ * <p>These security annotations are similiar to the Commons Attributes
|
|
|
+ * approach, however they are using Java 5 language-level metadata support.
|
|
|
+ *
|
|
|
+ * @author Mark St.Godard
|
|
|
+ * @version $Id$
|
|
|
+ *
|
|
|
+ * @see net.sf.acegisecurity.annotation.Secured
|
|
|
+ */
|
|
|
+public class SecurityAnnotationAttributes implements Attributes {
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Get the <code>Secured</code> attributes for a given target class.
|
|
|
+ * @param method The target method
|
|
|
+ * @return Collection of <code>SecurityConfig</code>
|
|
|
+ * @see Attributes#getAttributes
|
|
|
+ */
|
|
|
+ public Collection getAttributes(Class target) {
|
|
|
+
|
|
|
+ Set<SecurityConfig> attributes = new HashSet<SecurityConfig>();
|
|
|
+
|
|
|
+ for (Annotation annotation : target.getAnnotations()) {
|
|
|
+ // check for Secured annotations
|
|
|
+ if (annotation instanceof Secured) {
|
|
|
+ Secured attr = (Secured) annotation;
|
|
|
+ for (String auth : attr.value()) {
|
|
|
+ attributes.add(new SecurityConfig(auth));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return attributes;
|
|
|
+ }
|
|
|
+
|
|
|
+ public Collection getAttributes(Class clazz, Class filter) {
|
|
|
+ throw new UnsupportedOperationException("Unsupported operation");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Get the <code>Secured</code> attributes for a given target method.
|
|
|
+ * @param method The target method
|
|
|
+ * @return Collection of <code>SecurityConfig</code>
|
|
|
+ * @see Attributes#getAttributes
|
|
|
+ */
|
|
|
+ public Collection getAttributes(Method method) {
|
|
|
+ Set<SecurityConfig> attributes = new HashSet<SecurityConfig>();
|
|
|
+
|
|
|
+ for (Annotation annotation : method.getAnnotations()) {
|
|
|
+ // check for Secured annotations
|
|
|
+ if (annotation instanceof Secured) {
|
|
|
+ Secured attr = (Secured) annotation;
|
|
|
+ for (String auth : attr.value()) {
|
|
|
+ attributes.add(new SecurityConfig(auth));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return attributes;
|
|
|
+ }
|
|
|
+
|
|
|
+ public Collection getAttributes(Method method, Class clazz) {
|
|
|
+ throw new UnsupportedOperationException("Unsupported operation");
|
|
|
+ }
|
|
|
+
|
|
|
+ public Collection getAttributes(Field field) {
|
|
|
+ throw new UnsupportedOperationException("Unsupported operation");
|
|
|
+ }
|
|
|
+
|
|
|
+ public Collection getAttributes(Field field, Class clazz) {
|
|
|
+ throw new UnsupportedOperationException("Unsupported operation");
|
|
|
+ }
|
|
|
+
|
|
|
+}
|