1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.hadoop.hbase.client;
19
20 import java.util.Map;
21
22 import org.apache.hadoop.hbase.classification.InterfaceAudience;
23 import org.apache.hadoop.hbase.classification.InterfaceStability;
24 import org.apache.hadoop.hbase.exceptions.DeserializationException;
25 import org.apache.hadoop.hbase.filter.Filter;
26 import org.apache.hadoop.hbase.protobuf.ProtobufUtil;
27 import org.apache.hadoop.hbase.security.access.AccessControlConstants;
28 import org.apache.hadoop.hbase.security.access.Permission;
29 import org.apache.hadoop.hbase.security.visibility.Authorizations;
30 import org.apache.hadoop.hbase.security.visibility.VisibilityConstants;
31 import com.google.common.collect.ArrayListMultimap;
32 import com.google.common.collect.ListMultimap;
33
34 @InterfaceAudience.Public
35 @InterfaceStability.Evolving
36 public abstract class Query extends OperationWithAttributes {
37 private static final String ISOLATION_LEVEL = "_isolationlevel_";
38 protected Filter filter = null;
39 protected int targetReplicaId = -1;
40 protected Consistency consistency = Consistency.STRONG;
41
42
43
44
45 public Filter getFilter() {
46 return filter;
47 }
48
49
50
51
52
53
54
55
56 public Query setFilter(Filter filter) {
57 this.filter = filter;
58 return this;
59 }
60
61
62
63
64
65 public Query setAuthorizations(Authorizations authorizations) {
66 this.setAttribute(VisibilityConstants.VISIBILITY_LABELS_ATTR_KEY, ProtobufUtil
67 .toAuthorizations(authorizations).toByteArray());
68 return this;
69 }
70
71
72
73
74
75 public Authorizations getAuthorizations() throws DeserializationException {
76 byte[] authorizationsBytes = this.getAttribute(VisibilityConstants.VISIBILITY_LABELS_ATTR_KEY);
77 if (authorizationsBytes == null) return null;
78 return ProtobufUtil.toAuthorizations(authorizationsBytes);
79 }
80
81
82
83
84 public byte[] getACL() {
85 return getAttribute(AccessControlConstants.OP_ATTRIBUTE_ACL);
86 }
87
88
89
90
91
92 public Query setACL(String user, Permission perms) {
93 setAttribute(AccessControlConstants.OP_ATTRIBUTE_ACL,
94 ProtobufUtil.toUsersAndPermissions(user, perms).toByteArray());
95 return this;
96 }
97
98
99
100
101 public Query setACL(Map<String, Permission> perms) {
102 ListMultimap<String, Permission> permMap = ArrayListMultimap.create();
103 for (Map.Entry<String, Permission> entry : perms.entrySet()) {
104 permMap.put(entry.getKey(), entry.getValue());
105 }
106 setAttribute(AccessControlConstants.OP_ATTRIBUTE_ACL,
107 ProtobufUtil.toUsersAndPermissions(permMap).toByteArray());
108 return this;
109 }
110
111
112
113
114
115 public Consistency getConsistency() {
116 return consistency;
117 }
118
119
120
121
122
123 public Query setConsistency(Consistency consistency) {
124 this.consistency = consistency;
125 return this;
126 }
127
128
129
130
131
132
133
134
135 public Query setReplicaId(int Id) {
136 this.targetReplicaId = Id;
137 return this;
138 }
139
140
141
142
143
144 public int getReplicaId() {
145 return this.targetReplicaId;
146 }
147
148
149
150
151
152
153
154
155
156
157
158
159 public Query setIsolationLevel(IsolationLevel level) {
160 setAttribute(ISOLATION_LEVEL, level.toBytes());
161 return this;
162 }
163
164
165
166
167
168
169
170 public IsolationLevel getIsolationLevel() {
171 byte[] attr = getAttribute(ISOLATION_LEVEL);
172 return attr == null ? IsolationLevel.READ_COMMITTED :
173 IsolationLevel.fromBytes(attr);
174 }
175 }