|
17 | 17 | package org.springframework.kafka.config;
|
18 | 18 |
|
19 | 19 |
|
| 20 | +import java.util.Arrays; |
| 21 | +import java.util.Collection; |
20 | 22 | import java.util.regex.Pattern;
|
21 | 23 |
|
22 | 24 | import org.springframework.beans.BeanUtils;
|
|
31 | 33 | import org.springframework.kafka.listener.ErrorHandler;
|
32 | 34 | import org.springframework.kafka.listener.GenericErrorHandler;
|
33 | 35 | import org.springframework.kafka.listener.adapter.RecordFilterStrategy;
|
| 36 | +import org.springframework.kafka.support.TopicPartitionInitialOffset; |
34 | 37 | import org.springframework.kafka.support.converter.MessageConverter;
|
35 | 38 | import org.springframework.retry.RecoveryCallback;
|
36 | 39 | import org.springframework.retry.support.RetryTemplate;
|
@@ -241,15 +244,6 @@ public ContainerProperties getContainerProperties() {
|
241 | 244 | public C createListenerContainer(KafkaListenerEndpoint endpoint) {
|
242 | 245 | C instance = createContainerInstance(endpoint);
|
243 | 246 |
|
244 |
| - if (this.autoStartup != null) { |
245 |
| - instance.setAutoStartup(this.autoStartup); |
246 |
| - } |
247 |
| - if (this.phase != null) { |
248 |
| - instance.setPhase(this.phase); |
249 |
| - } |
250 |
| - if (this.applicationEventPublisher != null) { |
251 |
| - instance.setApplicationEventPublisher(this.applicationEventPublisher); |
252 |
| - } |
253 | 247 | if (endpoint.getId() != null) {
|
254 | 248 | instance.setBeanName(endpoint.getId());
|
255 | 249 | }
|
@@ -316,6 +310,57 @@ protected void initializeContainer(C instance) {
|
316 | 310 | if (this.errorHandler != null) {
|
317 | 311 | instance.setGenericErrorHandler(this.errorHandler);
|
318 | 312 | }
|
| 313 | + if (this.autoStartup != null) { |
| 314 | + instance.setAutoStartup(this.autoStartup); |
| 315 | + } |
| 316 | + if (this.phase != null) { |
| 317 | + instance.setPhase(this.phase); |
| 318 | + } |
| 319 | + if (this.applicationEventPublisher != null) { |
| 320 | + instance.setApplicationEventPublisher(this.applicationEventPublisher); |
| 321 | + } |
| 322 | + } |
| 323 | + |
| 324 | + @Override |
| 325 | + public C createContainer(final Collection<TopicPartitionInitialOffset> topicPartitions) { |
| 326 | + C container = createContainerInstance(new KafkaListenerEndpointAdapter() { |
| 327 | + |
| 328 | + @Override |
| 329 | + public Collection<TopicPartitionInitialOffset> getTopicPartitions() { |
| 330 | + return topicPartitions; |
| 331 | + } |
| 332 | + |
| 333 | + }); |
| 334 | + initializeContainer(container); |
| 335 | + return container; |
| 336 | + } |
| 337 | + |
| 338 | + @Override |
| 339 | + public C createContainer(final String... topics) { |
| 340 | + C container = createContainerInstance(new KafkaListenerEndpointAdapter() { |
| 341 | + |
| 342 | + @Override |
| 343 | + public Collection<String> getTopics() { |
| 344 | + return Arrays.asList(topics); |
| 345 | + } |
| 346 | + |
| 347 | + }); |
| 348 | + initializeContainer(container); |
| 349 | + return container; |
| 350 | + } |
| 351 | + |
| 352 | + @Override |
| 353 | + public C createContainer(final Pattern topicPattern) { |
| 354 | + C container = createContainerInstance(new KafkaListenerEndpointAdapter() { |
| 355 | + |
| 356 | + @Override |
| 357 | + public Pattern getTopicPattern() { |
| 358 | + return topicPattern; |
| 359 | + } |
| 360 | + |
| 361 | + }); |
| 362 | + initializeContainer(container); |
| 363 | + return container; |
319 | 364 | }
|
320 | 365 |
|
321 | 366 | }
|
0 commit comments