1. /*
  2. * Copyright 2002-2004 the original author or authors.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package org.springframework.transaction.interceptor;
  17. import java.lang.reflect.Method;
  18. /**
  19. * Interface used by TransactionInterceptor. Implementations know
  20. * how to source transaction attributes, whether from configuration,
  21. * metadata attributes at source level, or anywhere else.
  22. * @author Rod Johnson
  23. * @since 15-Apr-2003
  24. * @version $Id: TransactionAttributeSource.java,v 1.4 2004/03/18 02:46:05 trisberg Exp $
  25. */
  26. public interface TransactionAttributeSource {
  27. /**
  28. * Return the transaction attribute for this method.
  29. * Return null if the method is non-transactional.
  30. * @param method method
  31. * @param targetClass target class. May be null, in which case the declaring
  32. * class of the method must be used.
  33. * @return TransactionAttribute transaction attribute or null.
  34. */
  35. TransactionAttribute getTransactionAttribute(Method method, Class targetClass);
  36. }