1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.globalclock.rule;
19
20 import lombok.Getter;
21 import org.apache.shardingsphere.globalclock.config.GlobalClockRuleConfiguration;
22 import org.apache.shardingsphere.globalclock.provider.GlobalClockProvider;
23 import org.apache.shardingsphere.globalclock.rule.constant.GlobalClockOrder;
24 import org.apache.shardingsphere.infra.rule.scope.GlobalRule;
25 import org.apache.shardingsphere.infra.spi.type.typed.TypedSPILoader;
26
27 import java.util.Optional;
28
29
30
31
32 @Getter
33 public final class GlobalClockRule implements GlobalRule {
34
35 private final GlobalClockRuleConfiguration configuration;
36
37 private final GlobalClockProvider globalClockProvider;
38
39 public GlobalClockRule(final GlobalClockRuleConfiguration ruleConfig) {
40 configuration = ruleConfig;
41 globalClockProvider = ruleConfig.isEnabled()
42 ? TypedSPILoader.getService(GlobalClockProvider.class, String.join(".", ruleConfig.getType(), ruleConfig.getProvider()), configuration.getProps())
43 : null;
44 }
45
46
47
48
49
50
51 public Optional<GlobalClockProvider> getGlobalClockProvider() {
52 return Optional.ofNullable(globalClockProvider);
53 }
54
55 @Override
56 public int getOrder() {
57 return GlobalClockOrder.ORDER;
58 }
59 }