AnnotationDrivenBeanDefinitionParser.java 3.1 KB
Newer Older
A
Arjen Poutsma 已提交
1
/*
2
 * Copyright 2002-2011 the original author or authors.
A
Arjen Poutsma 已提交
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
 *
 * 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.transaction.config;

19 20
import org.w3c.dom.Element;

A
Arjen Poutsma 已提交
21
import org.springframework.aop.config.AopNamespaceUtils;
22 23 24 25 26 27
import org.springframework.beans.factory.config.BeanDefinition;
import org.springframework.beans.factory.config.RuntimeBeanReference;
import org.springframework.beans.factory.parsing.BeanComponentDefinition;
import org.springframework.beans.factory.parsing.CompositeComponentDefinition;
import org.springframework.beans.factory.support.RootBeanDefinition;
import org.springframework.beans.factory.xml.BeanDefinitionParser;
A
Arjen Poutsma 已提交
28
import org.springframework.beans.factory.xml.ParserContext;
29 30
import org.springframework.context.config.AbstractSpecificationBeanDefinitionParser;
import org.springframework.context.config.FeatureSpecification;
31
import org.w3c.dom.Element;
A
Arjen Poutsma 已提交
32 33

/**
34 35 36 37
 * {@link org.springframework.beans.factory.xml.BeanDefinitionParser
 * BeanDefinitionParser} implementation that allows users to easily configure
 * all the infrastructure beans required to enable annotation-driven transaction
 * demarcation.
A
Arjen Poutsma 已提交
38 39 40 41 42 43 44 45 46
 *
 * <p>By default, all proxies are created as JDK proxies. This may cause some
 * problems if you are injecting objects as concrete classes rather than
 * interfaces. To overcome this restriction you can set the
 * '<code>proxy-target-class</code>' attribute to '<code>true</code>', which
 * will result in class-based proxies being created.
 *
 * @author Juergen Hoeller
 * @author Rob Harrop
47
 * @author Chris Beams
A
Arjen Poutsma 已提交
48
 * @since 2.0
49
 * @see TxAnnotationDriven
A
Arjen Poutsma 已提交
50
 */
51
class AnnotationDrivenBeanDefinitionParser implements BeanDefinitionParser {
A
Arjen Poutsma 已提交
52 53 54 55 56

	/**
	 * The bean name of the internally managed transaction advisor (mode="proxy").
	 */
	public static final String TRANSACTION_ADVISOR_BEAN_NAME =
57
			TxAnnotationDrivenExecutor.TRANSACTION_ADVISOR_BEAN_NAME;
A
Arjen Poutsma 已提交
58 59 60 61 62

	/**
	 * The bean name of the internally managed transaction aspect (mode="aspectj").
	 */
	public static final String TRANSACTION_ASPECT_BEAN_NAME =
63
			TxAnnotationDrivenExecutor.TRANSACTION_ASPECT_BEAN_NAME;
A
Arjen Poutsma 已提交
64 65 66


	/**
67
	 * Parses the {@code <tx:annotation-driven/>} tag. Will
A
Arjen Poutsma 已提交
68 69 70
	 * {@link AopNamespaceUtils#registerAutoProxyCreatorIfNecessary register an AutoProxyCreator}
	 * with the container as necessary.
	 */
71 72 73
	@Override
	protected FeatureSpecification doParse(Element element, ParserContext parserContext) {
		return new TxAnnotationDriven(element.getAttribute("transaction-manager"))
74 75
			.order(element.getAttribute("order"))
			.mode(element.getAttribute("mode"))
76
			.proxyTargetClass(Boolean.valueOf(element.getAttribute("proxy-target-class")));
A
Arjen Poutsma 已提交
77 78 79
	}

}