1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.infra.session.connection.transaction;
19
20 import lombok.Getter;
21 import lombok.Setter;
22
23 import java.util.Optional;
24 import java.util.concurrent.atomic.AtomicReference;
25
26
27
28
29 @Getter
30 public final class TransactionConnectionContext implements AutoCloseable {
31
32 private volatile String transactionType;
33
34 private volatile boolean inTransaction;
35
36 @Setter
37 private volatile long beginMillis;
38
39 @Setter
40 private volatile boolean exceptionOccur;
41
42 @Setter
43 private volatile String readWriteSplitReplicaRoute;
44
45 private AtomicReference<TransactionManager> transactionManager;
46
47
48
49
50
51
52
53 public void beginTransaction(final String transactionType, final TransactionManager transactionManager) {
54 this.transactionType = transactionType;
55 inTransaction = true;
56 this.transactionManager = new AtomicReference<>(transactionManager);
57 }
58
59
60
61
62
63
64 public boolean isInDistributedTransaction() {
65 return inTransaction && ("XA".equals(transactionType) || "BASE".equals(transactionType));
66 }
67
68
69
70
71
72
73 public Optional<String> getTransactionType() {
74 return Optional.ofNullable(transactionType);
75 }
76
77
78
79
80
81
82 public Optional<String> getReadWriteSplitReplicaRoute() {
83 return Optional.ofNullable(readWriteSplitReplicaRoute);
84 }
85
86
87
88
89
90
91 public Optional<TransactionManager> getTransactionManager() {
92 return null == transactionManager ? Optional.empty() : Optional.ofNullable(transactionManager.get());
93 }
94
95 @Override
96 public void close() {
97 transactionType = null;
98 inTransaction = false;
99 beginMillis = 0L;
100 exceptionOccur = false;
101 readWriteSplitReplicaRoute = null;
102 transactionManager = null;
103 }
104 }