Skip to content

Commit 087789b

Browse files
committed
Merge branch '3.2.x'
Closes gh-40953
2 parents ddcb30c + 211bf95 commit 087789b

File tree

5 files changed

+29
-116
lines changed

5 files changed

+29
-116
lines changed

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jDataAutoConfiguration.java

+28-2
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,7 @@
2020

2121
import org.neo4j.driver.Driver;
2222

23+
import org.springframework.beans.factory.ObjectProvider;
2324
import org.springframework.boot.autoconfigure.AutoConfiguration;
2425
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
2526
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
@@ -29,18 +30,23 @@
2930
import org.springframework.boot.autoconfigure.neo4j.Neo4jAutoConfiguration;
3031
import org.springframework.boot.autoconfigure.transaction.TransactionAutoConfiguration;
3132
import org.springframework.boot.autoconfigure.transaction.TransactionManagerCustomizationAutoConfiguration;
33+
import org.springframework.boot.autoconfigure.transaction.TransactionManagerCustomizers;
3234
import org.springframework.boot.context.properties.EnableConfigurationProperties;
3335
import org.springframework.context.ApplicationContext;
3436
import org.springframework.context.annotation.Bean;
35-
import org.springframework.context.annotation.Import;
3637
import org.springframework.data.neo4j.aot.Neo4jManagedTypes;
3738
import org.springframework.data.neo4j.core.DatabaseSelectionProvider;
39+
import org.springframework.data.neo4j.core.Neo4jClient;
40+
import org.springframework.data.neo4j.core.Neo4jOperations;
41+
import org.springframework.data.neo4j.core.Neo4jTemplate;
3842
import org.springframework.data.neo4j.core.convert.Neo4jConversions;
3943
import org.springframework.data.neo4j.core.mapping.Neo4jMappingContext;
4044
import org.springframework.data.neo4j.core.schema.Node;
4145
import org.springframework.data.neo4j.core.schema.RelationshipProperties;
4246
import org.springframework.data.neo4j.core.transaction.Neo4jTransactionManager;
47+
import org.springframework.data.neo4j.repository.config.Neo4jRepositoryConfigurationExtension;
4348
import org.springframework.transaction.PlatformTransactionManager;
49+
import org.springframework.transaction.TransactionManager;
4450

4551
/**
4652
* {@link EnableAutoConfiguration Auto-configuration} for Spring Data Neo4j.
@@ -58,7 +64,6 @@
5864
@ConditionalOnClass({ Driver.class, Neo4jTransactionManager.class, PlatformTransactionManager.class })
5965
@EnableConfigurationProperties(Neo4jDataProperties.class)
6066
@ConditionalOnBean(Driver.class)
61-
@Import({ Neo4jTransactionManagerConfiguration.class, Neo4jTransactionalComponentsConfiguration.class })
6267
public class Neo4jDataAutoConfiguration {
6368

6469
@Bean
@@ -91,4 +96,25 @@ public DatabaseSelectionProvider databaseSelectionProvider(Neo4jDataProperties p
9196
: DatabaseSelectionProvider.getDefaultSelectionProvider();
9297
}
9398

99+
@Bean(Neo4jRepositoryConfigurationExtension.DEFAULT_NEO4J_CLIENT_BEAN_NAME)
100+
@ConditionalOnMissingBean
101+
public Neo4jClient neo4jClient(Driver driver, DatabaseSelectionProvider databaseNameProvider) {
102+
return Neo4jClient.create(driver, databaseNameProvider);
103+
}
104+
105+
@Bean(Neo4jRepositoryConfigurationExtension.DEFAULT_NEO4J_TEMPLATE_BEAN_NAME)
106+
@ConditionalOnMissingBean(Neo4jOperations.class)
107+
public Neo4jTemplate neo4jTemplate(Neo4jClient neo4jClient, Neo4jMappingContext neo4jMappingContext) {
108+
return new Neo4jTemplate(neo4jClient, neo4jMappingContext);
109+
}
110+
111+
@Bean(Neo4jRepositoryConfigurationExtension.DEFAULT_TRANSACTION_MANAGER_BEAN_NAME)
112+
@ConditionalOnMissingBean(TransactionManager.class)
113+
public Neo4jTransactionManager transactionManager(Driver driver, DatabaseSelectionProvider databaseNameProvider,
114+
ObjectProvider<TransactionManagerCustomizers> optionalCustomizers) {
115+
Neo4jTransactionManager transactionManager = new Neo4jTransactionManager(driver, databaseNameProvider);
116+
optionalCustomizers.ifAvailable((customizer) -> customizer.customize((TransactionManager) transactionManager));
117+
return transactionManager;
118+
}
119+
94120
}

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jReactiveDataAutoConfiguration.java

+1-9
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2012-2024 the original author or authors.
2+
* Copyright 2012-2022 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -30,7 +30,6 @@
3030
import org.springframework.data.neo4j.core.ReactiveNeo4jOperations;
3131
import org.springframework.data.neo4j.core.ReactiveNeo4jTemplate;
3232
import org.springframework.data.neo4j.core.mapping.Neo4jMappingContext;
33-
import org.springframework.data.neo4j.core.transaction.ReactiveNeo4jTransactionManager;
3433
import org.springframework.data.neo4j.repository.config.ReactiveNeo4jRepositoryConfigurationExtension;
3534
import org.springframework.transaction.ReactiveTransactionManager;
3635

@@ -69,11 +68,4 @@ public ReactiveNeo4jTemplate reactiveNeo4jTemplate(ReactiveNeo4jClient neo4jClie
6968
return new ReactiveNeo4jTemplate(neo4jClient, neo4jMappingContext);
7069
}
7170

72-
@Bean(ReactiveNeo4jRepositoryConfigurationExtension.DEFAULT_TRANSACTION_MANAGER_BEAN_NAME)
73-
@ConditionalOnMissingBean(ReactiveTransactionManager.class)
74-
ReactiveNeo4jTransactionManager reactiveNeo4jTransactionManager(Driver driver,
75-
ReactiveDatabaseSelectionProvider databaseNameProvider) {
76-
return new ReactiveNeo4jTransactionManager(driver, databaseNameProvider);
77-
}
78-
7971
}

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jRepositoriesAutoConfiguration.java

-3
Original file line numberDiff line numberDiff line change
@@ -20,13 +20,11 @@
2020

2121
import org.springframework.boot.autoconfigure.AutoConfiguration;
2222
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
23-
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
2423
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
2524
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
2625
import org.springframework.boot.autoconfigure.data.ConditionalOnRepositoryType;
2726
import org.springframework.boot.autoconfigure.data.RepositoryType;
2827
import org.springframework.context.annotation.Import;
29-
import org.springframework.data.neo4j.core.Neo4jTemplate;
3028
import org.springframework.data.neo4j.repository.Neo4jRepository;
3129
import org.springframework.data.neo4j.repository.config.EnableNeo4jRepositories;
3230
import org.springframework.data.neo4j.repository.config.Neo4jRepositoryConfigurationExtension;
@@ -54,7 +52,6 @@
5452
@AutoConfiguration(after = Neo4jDataAutoConfiguration.class)
5553
@ConditionalOnClass({ Driver.class, Neo4jRepository.class })
5654
@ConditionalOnMissingBean({ Neo4jRepositoryFactoryBean.class, Neo4jRepositoryConfigurationExtension.class })
57-
@ConditionalOnBean(Neo4jTemplate.class)
5855
@ConditionalOnRepositoryType(store = "neo4j", type = RepositoryType.IMPERATIVE)
5956
@Import(Neo4jRepositoriesRegistrar.class)
6057
public class Neo4jRepositoriesAutoConfiguration {

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jTransactionManagerConfiguration.java

-48
This file was deleted.

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/neo4j/Neo4jTransactionalComponentsConfiguration.java

-54
This file was deleted.

0 commit comments

Comments
 (0)