Class AdvisedSupport

  • All Implemented Interfaces:
    Serializable, Advised, TargetClassAware
    Direct Known Subclasses:
    ProxyCreatorSupport

    public class AdvisedSupport
    extends ProxyConfig
    implements Advised
    Base class for AOP proxy configuration managers. These are not themselves AOP proxies, but subclasses of this class are normally factories from which AOP proxy instances are obtained directly.

    This class frees subclasses of the housekeeping of Advices and Advisors, but doesn't actually implement proxy creation methods, which are provided by subclasses.

    This class is serializable; subclasses need not be. This class is used to hold snapshots of proxies.

    Author:
    Rod Johnson, Juergen Hoeller
    See Also:
    AopProxy, Serialized Form
    • Field Detail

      • EMPTY_TARGET_SOURCE

        public static final TargetSource EMPTY_TARGET_SOURCE
        Canonical TargetSource when there's no target, and behavior is supplied by the advisors.
    • Constructor Detail

      • AdvisedSupport

        public AdvisedSupport()
        No-arg constructor for use as a JavaBean.
      • AdvisedSupport

        public AdvisedSupport​(Class<?>... interfaces)
        Create a AdvisedSupport instance with the given parameters.
        Parameters:
        interfaces - the proxied interfaces
    • Method Detail

      • setTargetSource

        public void setTargetSource​(TargetSource targetSource)
        Description copied from interface: Advised
        Change the TargetSource used by this Advised object.

        Only works if the configuration isn't frozen.

        Specified by:
        setTargetSource in interface Advised
        Parameters:
        targetSource - new TargetSource to use
      • setTargetClass

        public void setTargetClass​(Class<?> targetClass)
        Set a target class to be proxied, indicating that the proxy should be castable to the given class.

        Internally, an EmptyTargetSource for the given target class will be used. The kind of proxy needed will be determined on actual creation of the proxy.

        This is a replacement for setting a "targetSource" or "target", for the case where we want a proxy based on a target class (which can be an interface or a concrete class) without having a fully capable TargetSource available.

        See Also:
        setTargetSource(org.springframework.aop.TargetSource), setTarget(java.lang.Object)
      • setPreFiltered

        public void setPreFiltered​(boolean preFiltered)
        Description copied from interface: Advised
        Set whether this proxy configuration is pre-filtered so that it only contains applicable advisors (matching this proxy's target class).

        Default is "false". Set this to "true" if the advisors have been pre-filtered already, meaning that the ClassFilter check can be skipped when building the actual advisor chain for proxy invocations.

        Specified by:
        setPreFiltered in interface Advised
        See Also:
        ClassFilter
      • isPreFiltered

        public boolean isPreFiltered()
        Description copied from interface: Advised
        Return whether this proxy configuration is pre-filtered so that it only contains applicable advisors (matching this proxy's target class).
        Specified by:
        isPreFiltered in interface Advised
      • setInterfaces

        public void setInterfaces​(Class<?>... interfaces)
        Set the interfaces to be proxied.
      • addInterface

        public void addInterface​(Class<?> intf)
        Add a new proxied interface.
        Parameters:
        intf - the additional interface to proxy
      • removeInterface

        public boolean removeInterface​(Class<?> intf)
        Remove a proxied interface.

        Does nothing if the given interface isn't proxied.

        Parameters:
        intf - the interface to remove from the proxy
        Returns:
        true if the interface was removed; false if the interface was not found and hence could not be removed
      • getAdvisors

        public final Advisor[] getAdvisors()
        Description copied from interface: Advised
        Return the advisors applying to this proxy.
        Specified by:
        getAdvisors in interface Advised
        Returns:
        a list of Advisors applying to this proxy (never null)
      • addAdvisor

        public void addAdvisor​(Advisor advisor)
        Description copied from interface: Advised
        Add an advisor at the end of the advisor chain.

        The Advisor may be an IntroductionAdvisor, in which new interfaces will be available when a proxy is next obtained from the relevant factory.

        Specified by:
        addAdvisor in interface Advised
        Parameters:
        advisor - the advisor to add to the end of the chain
      • addAdvisor

        public void addAdvisor​(int pos,
                               Advisor advisor)
                        throws AopConfigException
        Description copied from interface: Advised
        Add an Advisor at the specified position in the chain.
        Specified by:
        addAdvisor in interface Advised
        Parameters:
        pos - position in chain (0 is head). Must be valid.
        advisor - the advisor to add at the specified position in the chain
        Throws:
        AopConfigException - in case of invalid advice
      • removeAdvisor

        public boolean removeAdvisor​(Advisor advisor)
        Description copied from interface: Advised
        Remove the given advisor.
        Specified by:
        removeAdvisor in interface Advised
        Parameters:
        advisor - the advisor to remove
        Returns:
        true if the advisor was removed; false if the advisor was not found and hence could not be removed
      • indexOf

        public int indexOf​(Advisor advisor)
        Description copied from interface: Advised
        Return the index (from 0) of the given advisor, or -1 if no such advisor applies to this proxy.

        The return value of this method can be used to index into the advisors array.

        Specified by:
        indexOf in interface Advised
        Parameters:
        advisor - the advisor to search for
        Returns:
        index from 0 of this advisor, or -1 if there's no such advisor
      • replaceAdvisor

        public boolean replaceAdvisor​(Advisor a,
                                      Advisor b)
                               throws AopConfigException
        Description copied from interface: Advised
        Replace the given advisor.

        Note: If the advisor is an IntroductionAdvisor and the replacement is not or implements different interfaces, the proxy will need to be re-obtained or the old interfaces won't be supported and the new interface won't be implemented.

        Specified by:
        replaceAdvisor in interface Advised
        Parameters:
        a - the advisor to replace
        b - the advisor to replace it with
        Returns:
        whether it was replaced. If the advisor wasn't found in the list of advisors, this method returns false and does nothing.
        Throws:
        AopConfigException - in case of invalid advice
      • addAdvisors

        public void addAdvisors​(Advisor... advisors)
        Add all of the given advisors to this proxy configuration.
        Parameters:
        advisors - the advisors to register
      • addAdvisors

        public void addAdvisors​(Collection<Advisor> advisors)
        Add all of the given advisors to this proxy configuration.
        Parameters:
        advisors - the advisors to register
      • updateAdvisorArray

        protected final void updateAdvisorArray()
        Bring the array up to date with the list.
      • addAdvice

        public void addAdvice​(Advice advice)
                       throws AopConfigException
        Description copied from interface: Advised
        Add the given AOP Alliance advice to the tail of the advice (interceptor) chain.

        This will be wrapped in a DefaultPointcutAdvisor with a pointcut that always applies, and returned from the getAdvisors() method in this wrapped form.

        Note that the given advice will apply to all invocations on the proxy, even to the toString() method! Use appropriate advice implementations or specify appropriate pointcuts to apply to a narrower set of methods.

        Specified by:
        addAdvice in interface Advised
        Parameters:
        advice - advice to add to the tail of the chain
        Throws:
        AopConfigException - in case of invalid advice
        See Also:
        Advised.addAdvice(int, Advice), DefaultPointcutAdvisor
      • addAdvice

        public void addAdvice​(int pos,
                              Advice advice)
                       throws AopConfigException
        Cannot add introductions this way unless the advice implements IntroductionInfo.
        Specified by:
        addAdvice in interface Advised
        Parameters:
        pos - index from 0 (head)
        advice - advice to add at the specified position in the advice chain
        Throws:
        AopConfigException - in case of invalid advice
      • indexOf

        public int indexOf​(Advice advice)
        Description copied from interface: Advised
        Return the index (from 0) of the given AOP Alliance Advice, or -1 if no such advice is an advice for this proxy.

        The return value of this method can be used to index into the advisors array.

        Specified by:
        indexOf in interface Advised
        Parameters:
        advice - AOP Alliance advice to search for
        Returns:
        index from 0 of this advice, or -1 if there's no such advice
      • adviceIncluded

        public boolean adviceIncluded​(Advice advice)
        Is the given advice included in any advisor within this proxy configuration?
        Parameters:
        advice - the advice to check inclusion of
        Returns:
        whether this advice instance is included
      • countAdvicesOfType

        public int countAdvicesOfType​(Class<?> adviceClass)
        Count advices of the given class.
        Parameters:
        adviceClass - the advice class to check
        Returns:
        the count of the interceptors of this class or subclasses
      • getInterceptorsAndDynamicInterceptionAdvice

        public List<ObjectgetInterceptorsAndDynamicInterceptionAdvice​(Method method,
                                                                        Class<?> targetClass)
        Determine a list of MethodInterceptor objects for the given method, based on this configuration.
        Parameters:
        method - the proxied method
        targetClass - the target class
        Returns:
        a List of MethodInterceptors (may also include InterceptorAndDynamicMethodMatchers)
      • adviceChanged

        protected void adviceChanged()
        Invoked when advice has changed.
      • copyConfigurationFrom

        protected void copyConfigurationFrom​(AdvisedSupport other)
        Call this method on a new instance created by the no-arg constructor to create an independent copy of the configuration from the given object.
        Parameters:
        other - the AdvisedSupport object to copy configuration from
      • copyConfigurationFrom

        protected void copyConfigurationFrom​(AdvisedSupport other,
                                             TargetSource targetSource,
                                             List<Advisor> advisors)
        Copy the AOP configuration from the given AdvisedSupport object, but allow substitution of a fresh TargetSource and a given interceptor chain.
        Parameters:
        other - the AdvisedSupport object to take proxy configuration from
        targetSource - the new TargetSource
        advisors - the Advisors for the chain
      • toProxyConfigString

        public String toProxyConfigString()
        Description copied from interface: Advised
        As toString() will normally be delegated to the target, this returns the equivalent for the AOP proxy.
        Specified by:
        toProxyConfigString in interface Advised
        Returns:
        a string description of the proxy configuration