/*
* Copyright 2002-2007 the original author or authors.
*
* 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 org.springframework.aop.support;
import org.springframework.aop.Pointcut;
/**
* Concrete BeanFactory-based PointcutAdvisor that allows for any Advice
* to be configured as reference to an Advice bean in the BeanFactory,
* as well as the Pointcut to be configured through a bean property.
*
* <p>Specifying the name of an advice bean instead of the advice object itself
* (if running within a BeanFactory) increases loose coupling at initialization time,
* in order to not initialize the advice object until the pointcut actually matches.
*
* @author Juergen Hoeller
* @since 2.0.2
* @see #setPointcut
* @see #setAdviceBeanName
*/
public class DefaultBeanFactoryPointcutAdvisor extends AbstractBeanFactoryPointcutAdvisor {
private Pointcut pointcut = Pointcut.TRUE;
/**
* Specify the pointcut targeting the advice.
* <p>Default is <code>Pointcut.TRUE</code>.
* @see #setAdviceBeanName
*/
public void setPointcut(Pointcut pointcut) {
this.pointcut = (pointcut != null ? pointcut : Pointcut.TRUE);
}
public Pointcut getPointcut() {
return this.pointcut;
}
@Override
public String toString() {
return getClass().getName() + ": pointcut [" + getPointcut() + "]; advice bean '" + getAdviceBeanName() + "'";
}
}
|