|
24 | 24 | import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; |
25 | 25 | import org.springframework.boot.autoconfigure.condition.ConditionalOnJndi; |
26 | 26 | import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; |
| 27 | +import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; |
27 | 28 | import org.springframework.boot.autoconfigure.condition.ConditionalOnSingleCandidate; |
28 | 29 | import org.springframework.boot.jms.ConnectionFactoryUnwrapper; |
29 | 30 | import org.springframework.context.annotation.Bean; |
30 | 31 | import org.springframework.context.annotation.Configuration; |
31 | 32 | import org.springframework.jms.annotation.EnableJms; |
32 | 33 | import org.springframework.jms.config.DefaultJmsListenerContainerFactory; |
33 | 34 | import org.springframework.jms.config.JmsListenerConfigUtils; |
| 35 | +import org.springframework.jms.config.SimpleJmsListenerContainerFactory; |
34 | 36 | import org.springframework.jms.support.converter.MessageConverter; |
35 | 37 | import org.springframework.jms.support.destination.DestinationResolver; |
36 | 38 | import org.springframework.jms.support.destination.JndiDestinationResolver; |
|
42 | 44 | * @author Phillip Webb |
43 | 45 | * @author Stephane Nicoll |
44 | 46 | * @author Eddú Meléndez |
| 47 | + * @author Vedran Pavic |
45 | 48 | */ |
46 | 49 | @Configuration(proxyBeanMethods = false) |
47 | 50 | @ConditionalOnClass(EnableJms.class) |
48 | 51 | class JmsAnnotationDrivenConfiguration { |
49 | 52 |
|
50 | | - private final ObjectProvider<DestinationResolver> destinationResolver; |
51 | | - |
52 | | - private final ObjectProvider<JtaTransactionManager> transactionManager; |
| 53 | + @Configuration(proxyBeanMethods = false) |
| 54 | + @ConditionalOnProperty(name = "spring.jms.listener.container-type", havingValue = "default", matchIfMissing = true) |
| 55 | + static class DefaultJmsListenerContainerFactoryConfiguration { |
53 | 56 |
|
54 | | - private final ObjectProvider<MessageConverter> messageConverter; |
| 57 | + @Bean |
| 58 | + @ConditionalOnMissingBean |
| 59 | + @SuppressWarnings("removal") |
| 60 | + DefaultJmsListenerContainerFactoryConfigurer jmsListenerContainerFactoryConfigurer( |
| 61 | + ObjectProvider<DestinationResolver> destinationResolver, |
| 62 | + ObjectProvider<JtaTransactionManager> transactionManager, |
| 63 | + ObjectProvider<MessageConverter> messageConverter, ObjectProvider<ExceptionListener> exceptionListener, |
| 64 | + ObjectProvider<ObservationRegistry> observationRegistry, JmsProperties properties) { |
| 65 | + DefaultJmsListenerContainerFactoryConfigurer configurer = new DefaultJmsListenerContainerFactoryConfigurer(); |
| 66 | + configurer.setDestinationResolver(destinationResolver.getIfUnique()); |
| 67 | + configurer.setTransactionManager(transactionManager.getIfUnique()); |
| 68 | + configurer.setMessageConverter(messageConverter.getIfUnique()); |
| 69 | + configurer.setExceptionListener(exceptionListener.getIfUnique()); |
| 70 | + configurer.setObservationRegistry(observationRegistry.getIfUnique()); |
| 71 | + configurer.setJmsProperties(properties); |
| 72 | + return configurer; |
| 73 | + } |
55 | 74 |
|
56 | | - private final ObjectProvider<ExceptionListener> exceptionListener; |
| 75 | + @Bean |
| 76 | + @ConditionalOnSingleCandidate(ConnectionFactory.class) |
| 77 | + @ConditionalOnMissingBean(name = "jmsListenerContainerFactory") |
| 78 | + DefaultJmsListenerContainerFactory jmsListenerContainerFactory( |
| 79 | + DefaultJmsListenerContainerFactoryConfigurer configurer, ConnectionFactory connectionFactory) { |
| 80 | + DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory(); |
| 81 | + configurer.configure(factory, ConnectionFactoryUnwrapper.unwrapCaching(connectionFactory)); |
| 82 | + return factory; |
| 83 | + } |
57 | 84 |
|
58 | | - private final ObjectProvider<ObservationRegistry> observationRegistry; |
| 85 | + } |
59 | 86 |
|
60 | | - private final JmsProperties properties; |
| 87 | + @Configuration(proxyBeanMethods = false) |
| 88 | + @ConditionalOnProperty(name = "spring.jms.listener.container-type", havingValue = "simple") |
| 89 | + static class SimpleJmsListenerContainerFactoryConfiguration { |
61 | 90 |
|
62 | | - JmsAnnotationDrivenConfiguration(ObjectProvider<DestinationResolver> destinationResolver, |
63 | | - ObjectProvider<JtaTransactionManager> transactionManager, ObjectProvider<MessageConverter> messageConverter, |
64 | | - ObjectProvider<ExceptionListener> exceptionListener, |
65 | | - ObjectProvider<ObservationRegistry> observationRegistry, JmsProperties properties) { |
66 | | - this.destinationResolver = destinationResolver; |
67 | | - this.transactionManager = transactionManager; |
68 | | - this.messageConverter = messageConverter; |
69 | | - this.exceptionListener = exceptionListener; |
70 | | - this.observationRegistry = observationRegistry; |
71 | | - this.properties = properties; |
72 | | - } |
| 91 | + @Bean |
| 92 | + @ConditionalOnMissingBean |
| 93 | + SimpleJmsListenerContainerFactoryConfigurer jmsListenerContainerFactoryConfigurer( |
| 94 | + ObjectProvider<DestinationResolver> destinationResolver, |
| 95 | + ObjectProvider<MessageConverter> messageConverter, ObjectProvider<ExceptionListener> exceptionListener, |
| 96 | + ObjectProvider<ObservationRegistry> observationRegistry, JmsProperties properties) { |
| 97 | + SimpleJmsListenerContainerFactoryConfigurer configurer = new SimpleJmsListenerContainerFactoryConfigurer(); |
| 98 | + configurer.setDestinationResolver(destinationResolver.getIfUnique()); |
| 99 | + configurer.setMessageConverter(messageConverter.getIfUnique()); |
| 100 | + configurer.setExceptionListener(exceptionListener.getIfUnique()); |
| 101 | + configurer.setObservationRegistry(observationRegistry.getIfUnique()); |
| 102 | + configurer.setJmsProperties(properties); |
| 103 | + return configurer; |
| 104 | + } |
73 | 105 |
|
74 | | - @Bean |
75 | | - @ConditionalOnMissingBean |
76 | | - @SuppressWarnings("removal") |
77 | | - DefaultJmsListenerContainerFactoryConfigurer jmsListenerContainerFactoryConfigurer() { |
78 | | - DefaultJmsListenerContainerFactoryConfigurer configurer = new DefaultJmsListenerContainerFactoryConfigurer(); |
79 | | - configurer.setDestinationResolver(this.destinationResolver.getIfUnique()); |
80 | | - configurer.setTransactionManager(this.transactionManager.getIfUnique()); |
81 | | - configurer.setMessageConverter(this.messageConverter.getIfUnique()); |
82 | | - configurer.setExceptionListener(this.exceptionListener.getIfUnique()); |
83 | | - configurer.setObservationRegistry(this.observationRegistry.getIfUnique()); |
84 | | - configurer.setJmsProperties(this.properties); |
85 | | - return configurer; |
86 | | - } |
| 106 | + @Bean |
| 107 | + @ConditionalOnSingleCandidate(ConnectionFactory.class) |
| 108 | + @ConditionalOnMissingBean(name = "jmsListenerContainerFactory") |
| 109 | + SimpleJmsListenerContainerFactory jmsListenerContainerFactory( |
| 110 | + SimpleJmsListenerContainerFactoryConfigurer configurer, ConnectionFactory connectionFactory) { |
| 111 | + SimpleJmsListenerContainerFactory factory = new SimpleJmsListenerContainerFactory(); |
| 112 | + configurer.configure(factory, ConnectionFactoryUnwrapper.unwrapCaching(connectionFactory)); |
| 113 | + return factory; |
| 114 | + } |
87 | 115 |
|
88 | | - @Bean |
89 | | - @ConditionalOnSingleCandidate(ConnectionFactory.class) |
90 | | - @ConditionalOnMissingBean(name = "jmsListenerContainerFactory") |
91 | | - DefaultJmsListenerContainerFactory jmsListenerContainerFactory( |
92 | | - DefaultJmsListenerContainerFactoryConfigurer configurer, ConnectionFactory connectionFactory) { |
93 | | - DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory(); |
94 | | - configurer.configure(factory, ConnectionFactoryUnwrapper.unwrapCaching(connectionFactory)); |
95 | | - return factory; |
96 | 116 | } |
97 | 117 |
|
98 | 118 | @Configuration(proxyBeanMethods = false) |
|
0 commit comments