Class AbstractSecurityExpressionHandler<T>
java.lang.Object
org.springframework.security.access.expression.AbstractSecurityExpressionHandler<T>
- All Implemented Interfaces:
org.springframework.aop.framework.AopInfrastructureBean,org.springframework.beans.factory.Aware,org.springframework.context.ApplicationContextAware,SecurityExpressionHandler<T>
- Direct Known Subclasses:
DefaultHttpSecurityExpressionHandler,DefaultMessageSecurityExpressionHandler,DefaultMethodSecurityExpressionHandler,DefaultWebSecurityExpressionHandler
public abstract class AbstractSecurityExpressionHandler<T>
extends Object
implements SecurityExpressionHandler<T>, org.springframework.context.ApplicationContextAware
Base implementation of the facade which isolates Spring Security's requirements for
evaluating security expressions from the implementation of the underlying expression
objects.
- Since:
- 3.1
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal org.springframework.expression.EvaluationContextcreateEvaluationContext(@Nullable Authentication authentication, T invocation) Invokes the internal template methods to createStandardEvaluationContextandSecurityExpressionRootobjects.protected org.springframework.expression.spel.support.StandardEvaluationContextcreateEvaluationContextInternal(@Nullable Authentication authentication, T invocation) Override to create a custom instance ofStandardEvaluationContext.protected abstract SecurityExpressionOperationscreateSecurityExpressionRoot(@Nullable Authentication authentication, T invocation) Implement in order to create a root object of the correct type for the supported invocation type.protected final AuthorizationManagerFactory<T>protected @Nullable org.springframework.expression.BeanResolverprotected final DefaultAuthorizationManagerFactory<T>Deprecated.final org.springframework.expression.ExpressionParserprotected PermissionEvaluatorprotected @Nullable RoleHierarchyDeprecated.UsegetDefaultAuthorizationManagerFactory()insteadvoidsetApplicationContext(org.springframework.context.ApplicationContext applicationContext) final voidsetAuthorizationManagerFactory(AuthorizationManagerFactory<T> authorizationManagerFactory) Sets theAuthorizationManagerFactoryto be used.final voidsetExpressionParser(org.springframework.expression.ExpressionParser expressionParser) voidsetPermissionEvaluator(PermissionEvaluator permissionEvaluator) voidsetRoleHierarchy(@Nullable RoleHierarchy roleHierarchy) Deprecated.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.security.access.expression.SecurityExpressionHandler
createEvaluationContext
-
Constructor Details
-
AbstractSecurityExpressionHandler
public AbstractSecurityExpressionHandler()
-
-
Method Details
-
getExpressionParser
public final org.springframework.expression.ExpressionParser getExpressionParser()- Specified by:
getExpressionParserin interfaceSecurityExpressionHandler<T>- Returns:
- an expression parser for the expressions used by the implementation.
-
setExpressionParser
public final void setExpressionParser(org.springframework.expression.ExpressionParser expressionParser) -
createEvaluationContext
public final org.springframework.expression.EvaluationContext createEvaluationContext(@Nullable Authentication authentication, T invocation) Invokes the internal template methods to createStandardEvaluationContextandSecurityExpressionRootobjects.- Specified by:
createEvaluationContextin interfaceSecurityExpressionHandler<T>- Parameters:
authentication- the current authentication objectinvocation- the invocation (filter, method, channel)- Returns:
- the context object for use in evaluating the expression, populated with a suitable root object.
-
createEvaluationContextInternal
protected org.springframework.expression.spel.support.StandardEvaluationContext createEvaluationContextInternal(@Nullable Authentication authentication, T invocation) Override to create a custom instance ofStandardEvaluationContext.The returned object will have a
SecurityExpressionRootPropertyAccessoradded, allowing beans in theApplicationContextto be accessed via expression properties.- Parameters:
authentication- the current authentication objectinvocation- the invocation (filter, method, channel)- Returns:
- A
StandardEvaluationContextor potentially a custom subclass if overridden.
-
createSecurityExpressionRoot
protected abstract SecurityExpressionOperations createSecurityExpressionRoot(@Nullable Authentication authentication, T invocation) Implement in order to create a root object of the correct type for the supported invocation type.- Parameters:
authentication- the current authentication objectinvocation- the invocation (filter, method, channel)- Returns:
- the object
-
setAuthorizationManagerFactory
public final void setAuthorizationManagerFactory(AuthorizationManagerFactory<T> authorizationManagerFactory) Sets theAuthorizationManagerFactoryto be used. The default isDefaultAuthorizationManagerFactory.- Parameters:
authorizationManagerFactory- theAuthorizationManagerFactoryto use. Cannot be null.- Since:
- 7.0
-
getAuthorizationManagerFactory
-
getDefaultAuthorizationManagerFactory
@Deprecated(since="7.0") protected final DefaultAuthorizationManagerFactory<T> getDefaultAuthorizationManagerFactory()Deprecated.Allows accessing theDefaultAuthorizationManagerFactoryfor getting and setting defaults. This method will be removed in Spring Security 8.- Returns:
- the
DefaultAuthorizationManagerFactory - Throws:
IllegalStateException- if a differentAuthorizationManagerFactorywas already set
-
getRoleHierarchy
Deprecated.UsegetDefaultAuthorizationManagerFactory()instead -
setRoleHierarchy
Deprecated. -
getPermissionEvaluator
-
setPermissionEvaluator
-
getBeanResolver
protected @Nullable org.springframework.expression.BeanResolver getBeanResolver() -
setApplicationContext
public void setApplicationContext(org.springframework.context.ApplicationContext applicationContext) - Specified by:
setApplicationContextin interfaceorg.springframework.context.ApplicationContextAware
-
setAuthorizationManagerFactory(AuthorizationManagerFactory)instead