1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.sharding.api.config;
19
20 import com.cedarsoftware.util.CaseInsensitiveSet;
21 import lombok.Getter;
22 import lombok.Setter;
23 import org.apache.shardingsphere.infra.algorithm.core.config.AlgorithmConfiguration;
24 import org.apache.shardingsphere.infra.config.rule.function.DistributedRuleConfiguration;
25 import org.apache.shardingsphere.infra.config.rule.scope.DatabaseRuleConfiguration;
26 import org.apache.shardingsphere.sharding.api.config.cache.ShardingCacheConfiguration;
27 import org.apache.shardingsphere.sharding.api.config.rule.ShardingAutoTableRuleConfiguration;
28 import org.apache.shardingsphere.sharding.api.config.rule.ShardingTableReferenceRuleConfiguration;
29 import org.apache.shardingsphere.sharding.api.config.rule.ShardingTableRuleConfiguration;
30 import org.apache.shardingsphere.sharding.api.config.strategy.audit.ShardingAuditStrategyConfiguration;
31 import org.apache.shardingsphere.sharding.api.config.strategy.keygen.KeyGenerateStrategyConfiguration;
32 import org.apache.shardingsphere.sharding.api.config.strategy.sharding.ShardingStrategyConfiguration;
33
34 import java.util.Collection;
35 import java.util.LinkedHashMap;
36 import java.util.LinkedList;
37 import java.util.Map;
38 import java.util.stream.Collectors;
39
40
41
42
43 @Getter
44 @Setter
45 public final class ShardingRuleConfiguration implements DatabaseRuleConfiguration, DistributedRuleConfiguration {
46
47 private Collection<ShardingTableRuleConfiguration> tables = new LinkedList<>();
48
49 private Collection<ShardingAutoTableRuleConfiguration> autoTables = new LinkedList<>();
50
51 private Collection<ShardingTableReferenceRuleConfiguration> bindingTableGroups = new LinkedList<>();
52
53 private ShardingStrategyConfiguration defaultDatabaseShardingStrategy;
54
55 private ShardingStrategyConfiguration defaultTableShardingStrategy;
56
57 private KeyGenerateStrategyConfiguration defaultKeyGenerateStrategy;
58
59 private ShardingAuditStrategyConfiguration defaultAuditStrategy;
60
61 private String defaultShardingColumn;
62
63 private Map<String, AlgorithmConfiguration> shardingAlgorithms = new LinkedHashMap<>();
64
65 private Map<String, AlgorithmConfiguration> keyGenerators = new LinkedHashMap<>();
66
67 private Map<String, AlgorithmConfiguration> auditors = new LinkedHashMap<>();
68
69 private ShardingCacheConfiguration shardingCache;
70
71 @Override
72 public Collection<String> getLogicTableNames() {
73 return new CaseInsensitiveSet<>(tables.stream().map(ShardingTableRuleConfiguration::getLogicTable).collect(Collectors.toList()));
74 }
75 }