|
17 | 17 |
|
18 | 18 | import java.lang.annotation.Annotation;
|
19 | 19 |
|
20 |
| -import org.springframework.beans.factory.FactoryBean; |
21 | 20 | import org.springframework.beans.factory.config.BeanDefinition;
|
22 | 21 | import org.springframework.beans.factory.support.AbstractBeanDefinition;
|
23 | 22 | import org.springframework.beans.factory.support.BeanDefinitionBuilder;
|
24 | 23 | import org.springframework.beans.factory.support.BeanDefinitionRegistry;
|
25 | 24 | import org.springframework.context.annotation.ImportBeanDefinitionRegistrar;
|
26 |
| -import org.springframework.core.type.AnnotationMetadata; |
27 | 25 | import org.springframework.data.auditing.IsNewAwareAuditingHandler;
|
28 | 26 | import org.springframework.data.auditing.config.AuditingBeanDefinitionRegistrarSupport;
|
29 | 27 | import org.springframework.data.auditing.config.AuditingConfiguration;
|
30 | 28 | import org.springframework.data.config.ParsingUtils;
|
31 |
| -import org.springframework.data.elasticsearch.core.convert.MappingElasticsearchConverter; |
32 | 29 | import org.springframework.data.elasticsearch.core.event.AuditingEntityCallback;
|
33 |
| -import org.springframework.data.elasticsearch.core.event.ReactiveAuditingEntityCallback; |
34 |
| -import org.springframework.data.elasticsearch.core.mapping.ElasticsearchPersistentEntity; |
35 |
| -import org.springframework.data.elasticsearch.core.mapping.ElasticsearchPersistentProperty; |
36 |
| -import org.springframework.data.mapping.context.MappingContext; |
37 |
| -import org.springframework.data.repository.util.ReactiveWrappers; |
38 | 30 | import org.springframework.util.Assert;
|
39 | 31 |
|
40 | 32 | /**
|
|
45 | 37 | */
|
46 | 38 | class ElasticsearchAuditingRegistrar extends AuditingBeanDefinitionRegistrarSupport {
|
47 | 39 |
|
48 |
| - /* |
49 |
| - * (non-Javadoc) |
50 |
| - * @see org.springframework.data.auditing.config.AuditingBeanDefinitionRegistrarSupport#getAnnotation() |
51 |
| - */ |
52 | 40 | @Override
|
53 | 41 | protected Class<? extends Annotation> getAnnotation() {
|
54 | 42 | return EnableElasticsearchAuditing.class;
|
55 | 43 | }
|
56 | 44 |
|
57 |
| - /* |
58 |
| - * (non-Javadoc) |
59 |
| - * @see org.springframework.data.auditing.config.AuditingBeanDefinitionRegistrarSupport#getAuditingHandlerBeanName() |
60 |
| - */ |
61 | 45 | @Override
|
62 | 46 | protected String getAuditingHandlerBeanName() {
|
63 | 47 | return "elasticsearchAuditingHandler";
|
64 | 48 | }
|
65 | 49 |
|
66 |
| - /* |
67 |
| - * (non-Javadoc) |
68 |
| - * @see org.springframework.data.auditing.config.AuditingBeanDefinitionRegistrarSupport#registerBeanDefinitions(org.springframework.core.type.AnnotationMetadata, org.springframework.beans.factory.support.BeanDefinitionRegistry) |
69 |
| - */ |
70 |
| - @Override |
71 |
| - public void registerBeanDefinitions(AnnotationMetadata annotationMetadata, BeanDefinitionRegistry registry) { |
72 |
| - |
73 |
| - Assert.notNull(annotationMetadata, "AnnotationMetadata must not be null!"); |
74 |
| - Assert.notNull(registry, "BeanDefinitionRegistry must not be null!"); |
75 |
| - |
76 |
| - super.registerBeanDefinitions(annotationMetadata, registry); |
77 |
| - } |
78 |
| - |
79 |
| - /* |
80 |
| - * (non-Javadoc) |
81 |
| - * @see org.springframework.data.auditing.config.AuditingBeanDefinitionRegistrarSupport#getAuditHandlerBeanDefinitionBuilder(org.springframework.data.auditing.config.AuditingConfiguration) |
82 |
| - */ |
83 | 50 | @Override
|
84 | 51 | protected BeanDefinitionBuilder getAuditHandlerBeanDefinitionBuilder(AuditingConfiguration configuration) {
|
85 | 52 |
|
86 | 53 | Assert.notNull(configuration, "AuditingConfiguration must not be null!");
|
87 | 54 |
|
88 | 55 | BeanDefinitionBuilder builder = BeanDefinitionBuilder.rootBeanDefinition(IsNewAwareAuditingHandler.class);
|
89 | 56 |
|
90 |
| - BeanDefinitionBuilder definition = BeanDefinitionBuilder |
91 |
| - .genericBeanDefinition(ElasticsearchMappingContextLookup.class); |
| 57 | + BeanDefinitionBuilder definition = BeanDefinitionBuilder.genericBeanDefinition(PersistentEntitiesFactoryBean.class); |
92 | 58 | definition.setAutowireMode(AbstractBeanDefinition.AUTOWIRE_CONSTRUCTOR);
|
93 | 59 |
|
94 | 60 | builder.addConstructorArgValue(definition.getBeanDefinition());
|
95 | 61 | return configureDefaultAuditHandlerAttributes(configuration, builder);
|
96 | 62 | }
|
97 | 63 |
|
98 |
| - /* |
99 |
| - * (non-Javadoc) |
100 |
| - * @see org.springframework.data.auditing.config.AuditingBeanDefinitionRegistrarSupport#registerAuditListener(org.springframework.beans.factory.config.BeanDefinition, org.springframework.beans.factory.support.BeanDefinitionRegistry) |
101 |
| - */ |
102 | 64 | @Override
|
103 | 65 | protected void registerAuditListenerBeanDefinition(BeanDefinition auditingHandlerDefinition,
|
104 | 66 | BeanDefinitionRegistry registry) {
|
105 | 67 |
|
106 | 68 | Assert.notNull(auditingHandlerDefinition, "BeanDefinition must not be null!");
|
107 | 69 | Assert.notNull(registry, "BeanDefinitionRegistry must not be null!");
|
108 | 70 |
|
109 |
| - BeanDefinitionBuilder listenerBeanDefinitionBuilder = BeanDefinitionBuilder |
110 |
| - .rootBeanDefinition(AuditingEntityCallback.class); |
111 |
| - listenerBeanDefinitionBuilder |
112 |
| - .addConstructorArgValue(ParsingUtils.getObjectFactoryBeanDefinition(getAuditingHandlerBeanName(), registry)); |
113 |
| - |
114 |
| - registerInfrastructureBeanWithId(listenerBeanDefinitionBuilder.getBeanDefinition(), |
115 |
| - AuditingEntityCallback.class.getName(), registry); |
116 |
| - |
117 |
| - if (ReactiveWrappers.isAvailable(ReactiveWrappers.ReactiveLibrary.PROJECT_REACTOR)) { |
118 |
| - registerReactiveAuditingEntityCallback(registry, auditingHandlerDefinition.getSource()); |
119 |
| - } |
120 |
| - } |
121 |
| - |
122 |
| - private void registerReactiveAuditingEntityCallback(BeanDefinitionRegistry registry, Object source) { |
123 |
| - |
124 |
| - BeanDefinitionBuilder builder = BeanDefinitionBuilder.rootBeanDefinition(ReactiveAuditingEntityCallback.class); |
125 |
| - |
| 71 | + BeanDefinitionBuilder builder = BeanDefinitionBuilder.rootBeanDefinition(AuditingEntityCallback.class); |
126 | 72 | builder.addConstructorArgValue(ParsingUtils.getObjectFactoryBeanDefinition(getAuditingHandlerBeanName(), registry));
|
127 |
| - builder.getRawBeanDefinition().setSource(source); |
128 |
| - |
129 |
| - registerInfrastructureBeanWithId(builder.getBeanDefinition(), ReactiveAuditingEntityCallback.class.getName(), |
130 |
| - registry); |
131 |
| - } |
132 |
| - |
133 |
| - /** |
134 |
| - * Simple helper to be able to wire the {@link MappingContext} from a {@link MappingElasticsearchConverter} bean |
135 |
| - * available in the application context. |
136 |
| - * |
137 |
| - * @author Oliver Gierke |
138 |
| - */ |
139 |
| - static class ElasticsearchMappingContextLookup implements |
140 |
| - FactoryBean<MappingContext<? extends ElasticsearchPersistentEntity<?>, ElasticsearchPersistentProperty>> { |
141 |
| - |
142 |
| - private final MappingElasticsearchConverter converter; |
143 |
| - |
144 |
| - /** |
145 |
| - * Creates a new {@link ElasticsearchMappingContextLookup} for the given {@link MappingElasticsearchConverter}. |
146 |
| - * |
147 |
| - * @param converter must not be {@literal null}. |
148 |
| - */ |
149 |
| - public ElasticsearchMappingContextLookup(MappingElasticsearchConverter converter) { |
150 |
| - this.converter = converter; |
151 |
| - } |
152 |
| - |
153 |
| - /* |
154 |
| - * (non-Javadoc) |
155 |
| - * @see org.springframework.beans.factory.FactoryBean#getObject() |
156 |
| - */ |
157 |
| - @Override |
158 |
| - public MappingContext<? extends ElasticsearchPersistentEntity<?>, ElasticsearchPersistentProperty> getObject() |
159 |
| - throws Exception { |
160 |
| - return converter.getMappingContext(); |
161 |
| - } |
162 |
| - |
163 |
| - /* |
164 |
| - * (non-Javadoc) |
165 |
| - * @see org.springframework.beans.factory.FactoryBean#getObjectType() |
166 |
| - */ |
167 |
| - @Override |
168 |
| - public Class<?> getObjectType() { |
169 |
| - return MappingContext.class; |
170 |
| - } |
171 | 73 |
|
172 |
| - /* |
173 |
| - * (non-Javadoc) |
174 |
| - * @see org.springframework.beans.factory.FactoryBean#isSingleton() |
175 |
| - */ |
176 |
| - @Override |
177 |
| - public boolean isSingleton() { |
178 |
| - return true; |
179 |
| - } |
| 74 | + registerInfrastructureBeanWithId(builder.getBeanDefinition(), AuditingEntityCallback.class.getName(), registry); |
180 | 75 | }
|
181 | 76 | }
|
0 commit comments