3 * Licensed to the Apache Software Foundation (ASF) under one
4 * or more contributor license agreements. See the NOTICE file
5 * distributed with this work for additional information
6 * regarding copyright ownership. The ASF licenses this file
7 * to you under the Apache License, Version 2.0 (the
8 * "License"); you may not use this file except in compliance
9 * with the License. You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
19 package org
.apache
.hadoop
.hbase
.thrift2
;
21 import static org
.apache
.hadoop
.hbase
.util
.Bytes
.getBytes
;
23 import java
.io
.IOException
;
24 import java
.nio
.ByteBuffer
;
25 import java
.util
.ArrayList
;
26 import java
.util
.Collections
;
27 import java
.util
.List
;
29 import java
.util
.NavigableSet
;
31 import java
.util
.stream
.Collectors
;
33 import org
.apache
.hadoop
.hbase
.Cell
;
34 import org
.apache
.hadoop
.hbase
.CellBuilderFactory
;
35 import org
.apache
.hadoop
.hbase
.CellBuilderType
;
36 import org
.apache
.hadoop
.hbase
.CellUtil
;
37 import org
.apache
.hadoop
.hbase
.CompareOperator
;
38 import org
.apache
.hadoop
.hbase
.ExtendedCellBuilder
;
39 import org
.apache
.hadoop
.hbase
.ExtendedCellBuilderFactory
;
40 import org
.apache
.hadoop
.hbase
.HConstants
;
41 import org
.apache
.hadoop
.hbase
.HRegionLocation
;
42 import org
.apache
.hadoop
.hbase
.HTableDescriptor
;
43 import org
.apache
.hadoop
.hbase
.KeepDeletedCells
;
44 import org
.apache
.hadoop
.hbase
.NamespaceDescriptor
;
45 import org
.apache
.hadoop
.hbase
.PrivateCellUtil
;
46 import org
.apache
.hadoop
.hbase
.ServerName
;
47 import org
.apache
.hadoop
.hbase
.TableName
;
48 import org
.apache
.hadoop
.hbase
.client
.Append
;
49 import org
.apache
.hadoop
.hbase
.client
.ColumnFamilyDescriptor
;
50 import org
.apache
.hadoop
.hbase
.client
.ColumnFamilyDescriptorBuilder
;
51 import org
.apache
.hadoop
.hbase
.client
.Consistency
;
52 import org
.apache
.hadoop
.hbase
.client
.Delete
;
53 import org
.apache
.hadoop
.hbase
.client
.Durability
;
54 import org
.apache
.hadoop
.hbase
.client
.Get
;
55 import org
.apache
.hadoop
.hbase
.client
.Increment
;
56 import org
.apache
.hadoop
.hbase
.client
.Mutation
;
57 import org
.apache
.hadoop
.hbase
.client
.OperationWithAttributes
;
58 import org
.apache
.hadoop
.hbase
.client
.Put
;
59 import org
.apache
.hadoop
.hbase
.client
.RegionInfo
;
60 import org
.apache
.hadoop
.hbase
.client
.Result
;
61 import org
.apache
.hadoop
.hbase
.client
.RowMutations
;
62 import org
.apache
.hadoop
.hbase
.client
.Scan
;
63 import org
.apache
.hadoop
.hbase
.client
.Scan
.ReadType
;
64 import org
.apache
.hadoop
.hbase
.client
.SlowLogQueryFilter
;
65 import org
.apache
.hadoop
.hbase
.client
.SlowLogRecord
;
66 import org
.apache
.hadoop
.hbase
.client
.TableDescriptor
;
67 import org
.apache
.hadoop
.hbase
.client
.TableDescriptorBuilder
;
68 import org
.apache
.hadoop
.hbase
.exceptions
.DeserializationException
;
69 import org
.apache
.hadoop
.hbase
.filter
.Filter
;
70 import org
.apache
.hadoop
.hbase
.filter
.ParseFilter
;
71 import org
.apache
.hadoop
.hbase
.io
.TimeRange
;
72 import org
.apache
.hadoop
.hbase
.io
.compress
.Compression
;
73 import org
.apache
.hadoop
.hbase
.io
.encoding
.DataBlockEncoding
;
74 import org
.apache
.hadoop
.hbase
.regionserver
.BloomType
;
75 import org
.apache
.hadoop
.hbase
.security
.visibility
.Authorizations
;
76 import org
.apache
.hadoop
.hbase
.security
.visibility
.CellVisibility
;
77 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TAppend
;
78 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TAuthorization
;
79 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TBloomFilterType
;
80 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TCellVisibility
;
81 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TColumn
;
82 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TColumnFamilyDescriptor
;
83 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TColumnIncrement
;
84 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TColumnValue
;
85 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TCompareOperator
;
86 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TCompressionAlgorithm
;
87 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TConsistency
;
88 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TDataBlockEncoding
;
89 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TDelete
;
90 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TDeleteType
;
91 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TDurability
;
92 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TGet
;
93 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.THRegionInfo
;
94 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.THRegionLocation
;
95 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TIncrement
;
96 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TKeepDeletedCells
;
97 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TMutation
;
98 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TNamespaceDescriptor
;
99 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TPut
;
100 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TReadType
;
101 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TResult
;
102 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TRowMutations
;
103 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TScan
;
104 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TServerName
;
105 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TSlowLogQueryFilter
;
106 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TSlowLogRecord
;
107 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TTableDescriptor
;
108 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TTableName
;
109 import org
.apache
.hadoop
.hbase
.thrift2
.generated
.TTimeRange
;
110 import org
.apache
.hadoop
.hbase
.util
.Bytes
;
111 import org
.apache
.hbase
.thirdparty
.org
.apache
.commons
.collections4
.CollectionUtils
;
112 import org
.apache
.yetus
.audience
.InterfaceAudience
;
114 import org
.apache
.hbase
.thirdparty
.org
.apache
.commons
.collections4
.MapUtils
;
116 import org
.apache
.hadoop
.hbase
.shaded
.protobuf
.ProtobufUtil
;
117 import org
.apache
.hadoop
.hbase
.shaded
.protobuf
.generated
.FilterProtos
;
119 @InterfaceAudience.Private
120 public final class ThriftUtilities
{
122 private final static Cell
[] EMPTY_CELL_ARRAY
= new Cell
[]{};
123 private final static Result EMPTY_RESULT
= Result
.create(EMPTY_CELL_ARRAY
);
124 private final static Result EMPTY_RESULT_STALE
= Result
.create(EMPTY_CELL_ARRAY
, null, true);
128 private ThriftUtilities() {
129 throw new UnsupportedOperationException("Can't initialize class");
133 * Creates a {@link Get} (HBase) from a {@link TGet} (Thrift).
135 * This ignores any timestamps set on {@link TColumn} objects.
137 * @param in the <code>TGet</code> to convert
139 * @return <code>Get</code> object
141 * @throws IOException if an invalid time range or max version parameter is given
143 public static Get
getFromThrift(TGet in
) throws IOException
{
144 Get out
= new Get(in
.getRow());
146 // Timestamp overwrites time range if both are set
147 if (in
.isSetTimestamp()) {
148 out
.setTimestamp(in
.getTimestamp());
149 } else if (in
.isSetTimeRange()) {
150 out
.setTimeRange(in
.getTimeRange().getMinStamp(), in
.getTimeRange().getMaxStamp());
153 if (in
.isSetMaxVersions()) {
154 out
.readVersions(in
.getMaxVersions());
157 if (in
.isSetFilterString()) {
158 ParseFilter parseFilter
= new ParseFilter();
159 out
.setFilter(parseFilter
.parseFilterString(in
.getFilterString()));
162 if (in
.isSetAttributes()) {
163 addAttributes(out
,in
.getAttributes());
166 if (in
.isSetAuthorizations()) {
167 out
.setAuthorizations(new Authorizations(in
.getAuthorizations().getLabels()));
170 if (in
.isSetConsistency()) {
171 out
.setConsistency(consistencyFromThrift(in
.getConsistency()));
174 if (in
.isSetTargetReplicaId()) {
175 out
.setReplicaId(in
.getTargetReplicaId());
178 if (in
.isSetCacheBlocks()) {
179 out
.setCacheBlocks(in
.isCacheBlocks());
181 if (in
.isSetStoreLimit()) {
182 out
.setMaxResultsPerColumnFamily(in
.getStoreLimit());
184 if (in
.isSetStoreOffset()) {
185 out
.setRowOffsetPerColumnFamily(in
.getStoreOffset());
187 if (in
.isSetExistence_only()) {
188 out
.setCheckExistenceOnly(in
.isExistence_only());
191 if (in
.isSetColumns()) {
192 for (TColumn column
: in
.getColumns()) {
193 if (column
.isSetQualifier()) {
194 out
.addColumn(column
.getFamily(), column
.getQualifier());
196 out
.addFamily(column
.getFamily());
201 if (in
.isSetFilterBytes()) {
202 out
.setFilter(filterFromThrift(in
.getFilterBytes()));
208 * Converts multiple {@link TGet}s (Thrift) into a list of {@link Get}s (HBase).
210 * @param in list of <code>TGet</code>s to convert
212 * @return list of <code>Get</code> objects
214 * @throws IOException if an invalid time range or max version parameter is given
215 * @see #getFromThrift(TGet)
217 public static List
<Get
> getsFromThrift(List
<TGet
> in
) throws IOException
{
218 List
<Get
> out
= new ArrayList
<>(in
.size());
219 for (TGet get
: in
) {
220 out
.add(getFromThrift(get
));
226 * Creates a {@link TResult} (Thrift) from a {@link Result} (HBase).
228 * @param in the <code>Result</code> to convert
230 * @return converted result, returns an empty result if the input is <code>null</code>
232 public static TResult
resultFromHBase(Result in
) {
233 Cell
[] raw
= in
.rawCells();
234 TResult out
= new TResult();
235 byte[] row
= in
.getRow();
237 out
.setRow(in
.getRow());
239 List
<TColumnValue
> columnValues
= new ArrayList
<>(raw
.length
);
240 for (Cell kv
: raw
) {
241 TColumnValue col
= new TColumnValue();
242 col
.setFamily(CellUtil
.cloneFamily(kv
));
243 col
.setQualifier(CellUtil
.cloneQualifier(kv
));
244 col
.setTimestamp(kv
.getTimestamp());
245 col
.setValue(CellUtil
.cloneValue(kv
));
246 col
.setType(kv
.getType().getCode());
247 if (kv
.getTagsLength() > 0) {
248 col
.setTags(PrivateCellUtil
.cloneTags(kv
));
250 columnValues
.add(col
);
252 out
.setColumnValues(columnValues
);
254 out
.setStale(in
.isStale());
256 out
.setPartial(in
.mayHaveMoreCellsInRow());
261 * Converts multiple {@link Result}s (HBase) into a list of {@link TResult}s (Thrift).
263 * @param in array of <code>Result</code>s to convert
265 * @return list of converted <code>TResult</code>s
267 * @see #resultFromHBase(Result)
269 public static List
<TResult
> resultsFromHBase(Result
[] in
) {
270 List
<TResult
> out
= new ArrayList
<>(in
.length
);
271 for (Result result
: in
) {
272 out
.add(resultFromHBase(result
));
278 * Creates a {@link Put} (HBase) from a {@link TPut} (Thrift)
280 * @param in the <code>TPut</code> to convert
282 * @return converted <code>Put</code>
284 public static Put
putFromThrift(TPut in
) {
287 if (in
.isSetTimestamp()) {
288 out
= new Put(in
.getRow(), in
.getTimestamp());
290 out
= new Put(in
.getRow());
293 if (in
.isSetDurability()) {
294 out
.setDurability(durabilityFromThrift(in
.getDurability()));
297 for (TColumnValue columnValue
: in
.getColumnValues()) {
299 if (columnValue
.isSetTimestamp()) {
300 out
.add(CellBuilderFactory
.create(CellBuilderType
.DEEP_COPY
)
301 .setRow(out
.getRow())
302 .setFamily(columnValue
.getFamily())
303 .setQualifier(columnValue
.getQualifier())
304 .setTimestamp(columnValue
.getTimestamp())
305 .setType(Cell
.Type
.Put
)
306 .setValue(columnValue
.getValue())
309 out
.add(CellBuilderFactory
.create(CellBuilderType
.DEEP_COPY
)
310 .setRow(out
.getRow())
311 .setFamily(columnValue
.getFamily())
312 .setQualifier(columnValue
.getQualifier())
313 .setTimestamp(out
.getTimestamp())
314 .setType(Cell
.Type
.Put
)
315 .setValue(columnValue
.getValue())
318 } catch (IOException e
) {
319 throw new IllegalArgumentException((e
));
323 if (in
.isSetAttributes()) {
324 addAttributes(out
,in
.getAttributes());
327 if (in
.getCellVisibility() != null) {
328 out
.setCellVisibility(new CellVisibility(in
.getCellVisibility().getExpression()));
335 * Converts multiple {@link TPut}s (Thrift) into a list of {@link Put}s (HBase).
337 * @param in list of <code>TPut</code>s to convert
339 * @return list of converted <code>Put</code>s
341 * @see #putFromThrift(TPut)
343 public static List
<Put
> putsFromThrift(List
<TPut
> in
) {
344 List
<Put
> out
= new ArrayList
<>(in
.size());
345 for (TPut put
: in
) {
346 out
.add(putFromThrift(put
));
352 * Creates a {@link Delete} (HBase) from a {@link TDelete} (Thrift).
354 * @param in the <code>TDelete</code> to convert
356 * @return converted <code>Delete</code>
358 public static Delete
deleteFromThrift(TDelete in
) {
361 if (in
.isSetColumns()) {
362 out
= new Delete(in
.getRow());
363 for (TColumn column
: in
.getColumns()) {
364 if (in
.isSetDeleteType()) {
365 switch (in
.getDeleteType()) {
367 if (column
.isSetTimestamp()) {
368 out
.addColumn(column
.getFamily(), column
.getQualifier(), column
.getTimestamp());
370 out
.addColumn(column
.getFamily(), column
.getQualifier());
374 if (column
.isSetTimestamp()) {
375 out
.addColumns(column
.getFamily(), column
.getQualifier(), column
.getTimestamp());
377 out
.addColumns(column
.getFamily(), column
.getQualifier());
381 if (column
.isSetTimestamp()) {
382 out
.addFamily(column
.getFamily(), column
.getTimestamp());
384 out
.addFamily(column
.getFamily());
387 case DELETE_FAMILY_VERSION
:
388 if (column
.isSetTimestamp()) {
389 out
.addFamilyVersion(column
.getFamily(), column
.getTimestamp());
391 throw new IllegalArgumentException(
392 "Timestamp is required for TDelete with DeleteFamilyVersion type");
396 throw new IllegalArgumentException("DeleteType is required for TDelete");
399 throw new IllegalArgumentException("DeleteType is required for TDelete");
403 if (in
.isSetTimestamp()) {
404 out
= new Delete(in
.getRow(), in
.getTimestamp());
406 out
= new Delete(in
.getRow());
410 if (in
.isSetAttributes()) {
411 addAttributes(out
,in
.getAttributes());
414 if (in
.isSetDurability()) {
415 out
.setDurability(durabilityFromThrift(in
.getDurability()));
422 * Converts multiple {@link TDelete}s (Thrift) into a list of {@link Delete}s (HBase).
424 * @param in list of <code>TDelete</code>s to convert
426 * @return list of converted <code>Delete</code>s
428 * @see #deleteFromThrift(TDelete)
431 public static List
<Delete
> deletesFromThrift(List
<TDelete
> in
) {
432 List
<Delete
> out
= new ArrayList
<>(in
.size());
433 for (TDelete delete
: in
) {
434 out
.add(deleteFromThrift(delete
));
439 public static TDeleteType
deleteTypeFromHBase(Cell
.Type type
) {
441 case Delete
: return TDeleteType
.DELETE_COLUMN
;
442 case DeleteColumn
: return TDeleteType
.DELETE_COLUMNS
;
443 case DeleteFamily
: return TDeleteType
.DELETE_FAMILY
;
444 case DeleteFamilyVersion
: return TDeleteType
.DELETE_FAMILY_VERSION
;
445 default: throw new IllegalArgumentException("Unknow delete type " + type
);
448 public static TDelete
deleteFromHBase(Delete in
) {
449 TDelete out
= new TDelete(ByteBuffer
.wrap(in
.getRow()));
451 List
<TColumn
> columns
= new ArrayList
<>(in
.getFamilyCellMap().entrySet().size());
452 long rowTimestamp
= in
.getTimestamp();
453 if (rowTimestamp
!= HConstants
.LATEST_TIMESTAMP
) {
454 out
.setTimestamp(rowTimestamp
);
457 for (Map
.Entry
<String
, byte[]> attribute
: in
.getAttributesMap().entrySet()) {
458 out
.putToAttributes(ByteBuffer
.wrap(Bytes
.toBytes(attribute
.getKey())),
459 ByteBuffer
.wrap(attribute
.getValue()));
461 if (in
.getDurability() != Durability
.USE_DEFAULT
) {
462 out
.setDurability(durabilityFromHBase(in
.getDurability()));
464 // Delete the whole row
465 if (in
.getFamilyCellMap().size() == 0) {
468 TDeleteType type
= null;
469 for (Map
.Entry
<byte[], List
<Cell
>> familyEntry
:
470 in
.getFamilyCellMap().entrySet()) {
471 byte[] family
= familyEntry
.getKey();
472 TColumn column
= new TColumn(ByteBuffer
.wrap(familyEntry
.getKey()));
473 for (Cell cell
: familyEntry
.getValue()) {
474 TDeleteType cellDeleteType
= deleteTypeFromHBase(cell
.getType());
476 type
= cellDeleteType
;
477 } else if (type
!= cellDeleteType
){
478 throw new RuntimeException("Only the same delete type is supported, but two delete type "
479 + "is founded, one is " + type
+ " the other one is " + cellDeleteType
);
481 byte[] qualifier
= CellUtil
.cloneQualifier(cell
);
482 long timestamp
= cell
.getTimestamp();
483 column
.setFamily(family
);
484 if (qualifier
!= null) {
485 column
.setQualifier(qualifier
);
487 if (timestamp
!= HConstants
.LATEST_TIMESTAMP
) {
488 column
.setTimestamp(timestamp
);
493 out
.setColumns(columns
);
494 out
.setDeleteType(type
);
500 * Creates a {@link RowMutations} (HBase) from a {@link TRowMutations} (Thrift)
502 * @param in the <code>TRowMutations</code> to convert
504 * @return converted <code>RowMutations</code>
506 public static RowMutations
rowMutationsFromThrift(TRowMutations in
) throws IOException
{
507 List
<TMutation
> mutations
= in
.getMutations();
508 RowMutations out
= new RowMutations(in
.getRow(), mutations
.size());
509 for (TMutation mutation
: mutations
) {
510 if (mutation
.isSetPut()) {
511 out
.add(putFromThrift(mutation
.getPut()));
513 if (mutation
.isSetDeleteSingle()) {
514 out
.add(deleteFromThrift(mutation
.getDeleteSingle()));
520 public static Scan
scanFromThrift(TScan in
) throws IOException
{
521 Scan out
= new Scan();
523 if (in
.isSetStartRow()) {
524 out
.withStartRow(in
.getStartRow());
526 if (in
.isSetStopRow()) {
527 out
.setStopRow(in
.getStopRow());
529 if (in
.isSetCaching()) {
530 out
.setCaching(in
.getCaching());
532 if (in
.isSetMaxVersions()) {
533 out
.setMaxVersions(in
.getMaxVersions());
536 if (in
.isSetColumns()) {
537 for (TColumn column
: in
.getColumns()) {
538 if (column
.isSetQualifier()) {
539 out
.addColumn(column
.getFamily(), column
.getQualifier());
541 out
.addFamily(column
.getFamily());
546 TTimeRange timeRange
= in
.getTimeRange();
547 if (timeRange
!= null &&
548 timeRange
.isSetMinStamp() && timeRange
.isSetMaxStamp()) {
549 out
.setTimeRange(timeRange
.getMinStamp(), timeRange
.getMaxStamp());
552 if (in
.isSetBatchSize()) {
553 out
.setBatch(in
.getBatchSize());
556 if (in
.isSetFilterString()) {
557 ParseFilter parseFilter
= new ParseFilter();
558 out
.setFilter(parseFilter
.parseFilterString(in
.getFilterString()));
561 if (in
.isSetAttributes()) {
562 addAttributes(out
,in
.getAttributes());
565 if (in
.isSetAuthorizations()) {
566 out
.setAuthorizations(new Authorizations(in
.getAuthorizations().getLabels()));
569 if (in
.isSetReversed()) {
570 out
.setReversed(in
.isReversed());
573 if (in
.isSetCacheBlocks()) {
574 out
.setCacheBlocks(in
.isCacheBlocks());
577 if (in
.isSetColFamTimeRangeMap()) {
578 Map
<ByteBuffer
, TTimeRange
> colFamTimeRangeMap
= in
.getColFamTimeRangeMap();
579 if (MapUtils
.isNotEmpty(colFamTimeRangeMap
)) {
580 for (Map
.Entry
<ByteBuffer
, TTimeRange
> entry
: colFamTimeRangeMap
.entrySet()) {
581 out
.setColumnFamilyTimeRange(Bytes
.toBytes(entry
.getKey()),
582 entry
.getValue().getMinStamp(), entry
.getValue().getMaxStamp());
587 if (in
.isSetReadType()) {
588 out
.setReadType(readTypeFromThrift(in
.getReadType()));
591 if (in
.isSetLimit()) {
592 out
.setLimit(in
.getLimit());
595 if (in
.isSetConsistency()) {
596 out
.setConsistency(consistencyFromThrift(in
.getConsistency()));
599 if (in
.isSetTargetReplicaId()) {
600 out
.setReplicaId(in
.getTargetReplicaId());
603 if (in
.isSetFilterBytes()) {
604 out
.setFilter(filterFromThrift(in
.getFilterBytes()));
610 public static byte[] filterFromHBase(Filter filter
) throws IOException
{
611 FilterProtos
.Filter filterPB
= ProtobufUtil
.toFilter(filter
);
612 return filterPB
.toByteArray();
615 public static Filter
filterFromThrift(byte[] filterBytes
) throws IOException
{
616 FilterProtos
.Filter filterPB
= FilterProtos
.Filter
.parseFrom(filterBytes
);
617 return ProtobufUtil
.toFilter(filterPB
);
620 public static TScan
scanFromHBase(Scan in
) throws IOException
{
621 TScan out
= new TScan();
622 out
.setStartRow(in
.getStartRow());
623 out
.setStopRow(in
.getStopRow());
624 out
.setCaching(in
.getCaching());
625 out
.setMaxVersions(in
.getMaxVersions());
626 for (Map
.Entry
<byte[], NavigableSet
<byte[]>> family
: in
.getFamilyMap().entrySet()) {
628 if (family
.getValue() != null && !family
.getValue().isEmpty()) {
629 for (byte[] qualifier
: family
.getValue()) {
630 TColumn column
= new TColumn();
631 column
.setFamily(family
.getKey());
632 column
.setQualifier(qualifier
);
633 out
.addToColumns(column
);
636 TColumn column
= new TColumn();
637 column
.setFamily(family
.getKey());
638 out
.addToColumns(column
);
641 TTimeRange tTimeRange
= new TTimeRange();
642 tTimeRange
.setMinStamp(in
.getTimeRange().getMin()).setMaxStamp(in
.getTimeRange().getMax());
643 out
.setTimeRange(tTimeRange
);
644 out
.setBatchSize(in
.getBatch());
646 for (Map
.Entry
<String
, byte[]> attribute
: in
.getAttributesMap().entrySet()) {
647 out
.putToAttributes(ByteBuffer
.wrap(Bytes
.toBytes(attribute
.getKey())),
648 ByteBuffer
.wrap(attribute
.getValue()));
652 Authorizations authorizations
= in
.getAuthorizations();
653 if (authorizations
!= null) {
654 TAuthorization tAuthorization
= new TAuthorization();
655 tAuthorization
.setLabels(authorizations
.getLabels());
656 out
.setAuthorizations(tAuthorization
);
658 } catch (DeserializationException e
) {
659 throw new RuntimeException(e
);
662 out
.setReversed(in
.isReversed());
663 out
.setCacheBlocks(in
.getCacheBlocks());
664 out
.setReadType(readTypeFromHBase(in
.getReadType()));
665 out
.setLimit(in
.getLimit());
666 out
.setConsistency(consistencyFromHBase(in
.getConsistency()));
667 out
.setTargetReplicaId(in
.getReplicaId());
668 for (Map
.Entry
<byte[], TimeRange
> entry
: in
.getColumnFamilyTimeRange().entrySet()) {
669 if (entry
.getValue() != null) {
670 TTimeRange timeRange
= new TTimeRange();
671 timeRange
.setMinStamp(entry
.getValue().getMin()).setMaxStamp(entry
.getValue().getMax());
672 out
.putToColFamTimeRangeMap(ByteBuffer
.wrap(entry
.getKey()), timeRange
);
675 if (in
.getFilter() != null) {
677 out
.setFilterBytes(filterFromHBase(in
.getFilter()));
678 } catch (IOException ioE
) {
679 throw new RuntimeException(ioE
);
685 public static Increment
incrementFromThrift(TIncrement in
) throws IOException
{
686 Increment out
= new Increment(in
.getRow());
687 for (TColumnIncrement column
: in
.getColumns()) {
688 out
.addColumn(column
.getFamily(), column
.getQualifier(), column
.getAmount());
691 if (in
.isSetAttributes()) {
692 addAttributes(out
,in
.getAttributes());
695 if (in
.isSetDurability()) {
696 out
.setDurability(durabilityFromThrift(in
.getDurability()));
699 if(in
.getCellVisibility() != null) {
700 out
.setCellVisibility(new CellVisibility(in
.getCellVisibility().getExpression()));
703 if (in
.isSetReturnResults()) {
704 out
.setReturnResults(in
.isReturnResults());
710 public static Append
appendFromThrift(TAppend append
) throws IOException
{
711 Append out
= new Append(append
.getRow());
712 for (TColumnValue column
: append
.getColumns()) {
713 out
.addColumn(column
.getFamily(), column
.getQualifier(), column
.getValue());
716 if (append
.isSetAttributes()) {
717 addAttributes(out
, append
.getAttributes());
720 if (append
.isSetDurability()) {
721 out
.setDurability(durabilityFromThrift(append
.getDurability()));
724 if(append
.getCellVisibility() != null) {
725 out
.setCellVisibility(new CellVisibility(append
.getCellVisibility().getExpression()));
728 if (append
.isSetReturnResults()) {
729 out
.setReturnResults(append
.isReturnResults());
735 public static THRegionLocation
regionLocationFromHBase(HRegionLocation hrl
) {
736 RegionInfo hri
= hrl
.getRegion();
737 ServerName serverName
= hrl
.getServerName();
739 THRegionInfo thRegionInfo
= new THRegionInfo();
740 THRegionLocation thRegionLocation
= new THRegionLocation();
741 TServerName tServerName
= new TServerName();
743 tServerName
.setHostName(serverName
.getHostname());
744 tServerName
.setPort(serverName
.getPort());
745 tServerName
.setStartCode(serverName
.getStartcode());
747 thRegionInfo
.setTableName(hri
.getTable().getName());
748 thRegionInfo
.setEndKey(hri
.getEndKey());
749 thRegionInfo
.setStartKey(hri
.getStartKey());
750 thRegionInfo
.setOffline(hri
.isOffline());
751 thRegionInfo
.setSplit(hri
.isSplit());
752 thRegionInfo
.setReplicaId(hri
.getReplicaId());
754 thRegionLocation
.setRegionInfo(thRegionInfo
);
755 thRegionLocation
.setServerName(tServerName
);
757 return thRegionLocation
;
760 public static List
<THRegionLocation
> regionLocationsFromHBase(List
<HRegionLocation
> locations
) {
761 List
<THRegionLocation
> tlocations
= new ArrayList
<>(locations
.size());
762 for (HRegionLocation hrl
:locations
) {
763 tlocations
.add(regionLocationFromHBase(hrl
));
769 * Adds all the attributes into the Operation object
771 private static void addAttributes(OperationWithAttributes op
,
772 Map
<ByteBuffer
, ByteBuffer
> attributes
) {
773 if (attributes
== null || attributes
.isEmpty()) {
776 for (Map
.Entry
<ByteBuffer
, ByteBuffer
> entry
: attributes
.entrySet()) {
777 String name
= Bytes
.toStringBinary(getBytes(entry
.getKey()));
778 byte[] value
= getBytes(entry
.getValue());
779 op
.setAttribute(name
, value
);
783 private static Durability
durabilityFromThrift(TDurability tDurability
) {
784 switch (tDurability
.getValue()) {
785 case 0: return Durability
.USE_DEFAULT
;
786 case 1: return Durability
.SKIP_WAL
;
787 case 2: return Durability
.ASYNC_WAL
;
788 case 3: return Durability
.SYNC_WAL
;
789 case 4: return Durability
.FSYNC_WAL
;
790 default: return Durability
.USE_DEFAULT
;
794 public static CompareOperator
compareOpFromThrift(TCompareOperator tCompareOp
) {
795 switch (tCompareOp
.getValue()) {
796 case 0: return CompareOperator
.LESS
;
797 case 1: return CompareOperator
.LESS_OR_EQUAL
;
798 case 2: return CompareOperator
.EQUAL
;
799 case 3: return CompareOperator
.NOT_EQUAL
;
800 case 4: return CompareOperator
.GREATER_OR_EQUAL
;
801 case 5: return CompareOperator
.GREATER
;
802 case 6: return CompareOperator
.NO_OP
;
803 default: return null;
807 private static ReadType
readTypeFromThrift(TReadType tReadType
) {
808 switch (tReadType
.getValue()) {
809 case 1: return ReadType
.DEFAULT
;
810 case 2: return ReadType
.STREAM
;
811 case 3: return ReadType
.PREAD
;
812 default: return null;
816 private static TReadType
readTypeFromHBase(ReadType readType
) {
818 case DEFAULT
: return TReadType
.DEFAULT
;
819 case STREAM
: return TReadType
.STREAM
;
820 case PREAD
: return TReadType
.PREAD
;
821 default: return TReadType
.DEFAULT
;
825 private static Consistency
consistencyFromThrift(TConsistency tConsistency
) {
826 switch (tConsistency
.getValue()) {
827 case 1: return Consistency
.STRONG
;
828 case 2: return Consistency
.TIMELINE
;
829 default: return Consistency
.STRONG
;
833 public static TableName
tableNameFromThrift(TTableName tableName
) {
834 return TableName
.valueOf(tableName
.getNs(), tableName
.getQualifier());
837 public static TableName
[] tableNamesArrayFromThrift(List
<TTableName
> tableNames
) {
838 TableName
[] out
= new TableName
[tableNames
.size()];
840 for (TTableName tableName
: tableNames
) {
841 out
[index
++] = tableNameFromThrift(tableName
);
846 public static List
<TableName
> tableNamesFromThrift(List
<TTableName
> tableNames
) {
847 List
<TableName
> out
= new ArrayList
<>(tableNames
.size());
848 for (TTableName tableName
: tableNames
) {
849 out
.add(tableNameFromThrift(tableName
));
854 public static TTableName
tableNameFromHBase(TableName table
) {
855 TTableName tableName
= new TTableName();
856 tableName
.setNs(table
.getNamespace());
857 tableName
.setQualifier(table
.getQualifier());
861 public static List
<TTableName
> tableNamesFromHBase(List
<TableName
> in
) {
862 List
<TTableName
> out
= new ArrayList
<>(in
.size());
863 for (TableName tableName
: in
) {
864 out
.add(tableNameFromHBase(tableName
));
869 public static List
<TTableName
> tableNamesFromHBase(TableName
[] in
) {
870 List
<TTableName
> out
= new ArrayList
<>(in
.length
);
871 for (TableName tableName
: in
) {
872 out
.add(tableNameFromHBase(tableName
));
877 public static byte[][] splitKeyFromThrift(List
<ByteBuffer
> in
) {
878 if (in
== null || in
.size() == 0) {
881 byte[][] out
= new byte[in
.size()][];
883 for (ByteBuffer key
: in
) {
884 out
[index
++] = key
.array();
889 public static BloomType
bloomFilterFromThrift(TBloomFilterType in
) {
890 switch (in
.getValue()) {
891 case 0: return BloomType
.NONE
;
892 case 1: return BloomType
.ROW
;
893 case 2: return BloomType
.ROWCOL
;
894 case 3: return BloomType
.ROWPREFIX_FIXED_LENGTH
;
895 default: return BloomType
.ROW
;
899 public static Compression
.Algorithm
compressionAlgorithmFromThrift(TCompressionAlgorithm in
) {
900 switch (in
.getValue()) {
901 case 0: return Compression
.Algorithm
.LZO
;
902 case 1: return Compression
.Algorithm
.GZ
;
903 case 2: return Compression
.Algorithm
.NONE
;
904 case 3: return Compression
.Algorithm
.SNAPPY
;
905 case 4: return Compression
.Algorithm
.LZ4
;
906 case 5: return Compression
.Algorithm
.BZIP2
;
907 case 6: return Compression
.Algorithm
.ZSTD
;
908 default: return Compression
.Algorithm
.NONE
;
912 public static DataBlockEncoding
dataBlockEncodingFromThrift(TDataBlockEncoding in
) {
913 switch (in
.getValue()) {
914 case 0: return DataBlockEncoding
.NONE
;
915 case 2: return DataBlockEncoding
.PREFIX
;
916 case 3: return DataBlockEncoding
.DIFF
;
917 case 4: return DataBlockEncoding
.FAST_DIFF
;
918 case 7: return DataBlockEncoding
.ROW_INDEX_V1
;
919 default: return DataBlockEncoding
.NONE
;
923 public static KeepDeletedCells
keepDeletedCellsFromThrift(TKeepDeletedCells in
) {
924 switch (in
.getValue()) {
925 case 0: return KeepDeletedCells
.FALSE
;
926 case 1: return KeepDeletedCells
.TRUE
;
927 case 2: return KeepDeletedCells
.TTL
;
928 default: return KeepDeletedCells
.FALSE
;
932 public static ColumnFamilyDescriptor
columnFamilyDescriptorFromThrift(
933 TColumnFamilyDescriptor in
) {
934 ColumnFamilyDescriptorBuilder builder
= ColumnFamilyDescriptorBuilder
935 .newBuilder(in
.getName());
937 if (in
.isSetAttributes()) {
938 for (Map
.Entry
<ByteBuffer
, ByteBuffer
> attribute
: in
.getAttributes().entrySet()) {
939 builder
.setValue(attribute
.getKey().array(), attribute
.getValue().array());
942 if (in
.isSetConfiguration()) {
943 for (Map
.Entry
<String
, String
> conf
: in
.getConfiguration().entrySet()) {
944 builder
.setConfiguration(conf
.getKey(), conf
.getValue());
947 if (in
.isSetBlockSize()) {
948 builder
.setBlocksize(in
.getBlockSize());
950 if (in
.isSetBloomnFilterType()) {
951 builder
.setBloomFilterType(bloomFilterFromThrift(in
.getBloomnFilterType()));
953 if (in
.isSetCompressionType()) {
954 builder
.setCompressionType(compressionAlgorithmFromThrift(in
.getCompressionType()));
956 if (in
.isSetDfsReplication()) {
957 builder
.setDFSReplication(in
.getDfsReplication());
959 if (in
.isSetDataBlockEncoding()) {
960 builder
.setDataBlockEncoding(dataBlockEncodingFromThrift(in
.getDataBlockEncoding()));
962 if (in
.isSetKeepDeletedCells()) {
963 builder
.setKeepDeletedCells(keepDeletedCellsFromThrift(in
.getKeepDeletedCells()));
965 if (in
.isSetMaxVersions()) {
966 builder
.setMaxVersions(in
.getMaxVersions());
968 if (in
.isSetMinVersions()) {
969 builder
.setMinVersions(in
.getMinVersions());
971 if (in
.isSetScope()) {
972 builder
.setScope(in
.getScope());
974 if (in
.isSetTimeToLive()) {
975 builder
.setTimeToLive(in
.getTimeToLive());
977 if (in
.isSetBlockCacheEnabled()) {
978 builder
.setBlockCacheEnabled(in
.isBlockCacheEnabled());
980 if (in
.isSetCacheBloomsOnWrite()) {
981 builder
.setCacheBloomsOnWrite(in
.isCacheBloomsOnWrite());
983 if (in
.isSetCacheDataOnWrite()) {
984 builder
.setCacheDataOnWrite(in
.isCacheDataOnWrite());
986 if (in
.isSetCacheIndexesOnWrite()) {
987 builder
.setCacheIndexesOnWrite(in
.isCacheIndexesOnWrite());
989 if (in
.isSetCompressTags()) {
990 builder
.setCompressTags(in
.isCompressTags());
992 if (in
.isSetEvictBlocksOnClose()) {
993 builder
.setEvictBlocksOnClose(in
.isEvictBlocksOnClose());
995 if (in
.isSetInMemory()) {
996 builder
.setInMemory(in
.isInMemory());
1000 return builder
.build();
1003 public static NamespaceDescriptor
namespaceDescriptorFromThrift(TNamespaceDescriptor in
) {
1004 NamespaceDescriptor
.Builder builder
= NamespaceDescriptor
.create(in
.getName());
1005 if (in
.isSetConfiguration()) {
1006 for (Map
.Entry
<String
, String
> conf
: in
.getConfiguration().entrySet()) {
1007 builder
.addConfiguration(conf
.getKey(), conf
.getValue());
1010 return builder
.build();
1013 public static TNamespaceDescriptor
namespaceDescriptorFromHBase(NamespaceDescriptor in
) {
1014 TNamespaceDescriptor out
= new TNamespaceDescriptor();
1015 out
.setName(in
.getName());
1016 for (Map
.Entry
<String
, String
> conf
: in
.getConfiguration().entrySet()) {
1017 out
.putToConfiguration(conf
.getKey(), conf
.getValue());
1022 public static List
<TNamespaceDescriptor
> namespaceDescriptorsFromHBase(
1023 NamespaceDescriptor
[] in
) {
1024 List
<TNamespaceDescriptor
> out
= new ArrayList
<>(in
.length
);
1025 for (NamespaceDescriptor descriptor
: in
) {
1026 out
.add(namespaceDescriptorFromHBase(descriptor
));
1031 public static TableDescriptor
tableDescriptorFromThrift(TTableDescriptor in
) {
1032 TableDescriptorBuilder builder
= TableDescriptorBuilder
1033 .newBuilder(tableNameFromThrift(in
.getTableName()));
1034 for (TColumnFamilyDescriptor column
: in
.getColumns()) {
1035 builder
.setColumnFamily(columnFamilyDescriptorFromThrift(column
));
1037 if (in
.isSetAttributes()) {
1038 for (Map
.Entry
<ByteBuffer
, ByteBuffer
> attribute
: in
.getAttributes().entrySet()) {
1039 builder
.setValue(attribute
.getKey().array(), attribute
.getValue().array());
1042 if (in
.isSetDurability()) {
1043 builder
.setDurability(durabilityFromThrift(in
.getDurability()));
1045 return builder
.build();
1048 public static HTableDescriptor
hTableDescriptorFromThrift(TTableDescriptor in
) {
1049 return new HTableDescriptor(tableDescriptorFromThrift(in
));
1052 public static HTableDescriptor
[] hTableDescriptorsFromThrift(List
<TTableDescriptor
> in
) {
1053 HTableDescriptor
[] out
= new HTableDescriptor
[in
.size()];
1055 for (TTableDescriptor tTableDescriptor
: in
) {
1056 out
[index
++] = hTableDescriptorFromThrift(tTableDescriptor
);
1062 public static List
<TableDescriptor
> tableDescriptorsFromThrift(List
<TTableDescriptor
> in
) {
1063 List
<TableDescriptor
> out
= new ArrayList
<>();
1064 for (TTableDescriptor tableDescriptor
: in
) {
1065 out
.add(tableDescriptorFromThrift(tableDescriptor
));
1070 private static TDurability
durabilityFromHBase(Durability durability
) {
1071 switch (durability
) {
1072 case USE_DEFAULT
: return TDurability
.USE_DEFAULT
;
1073 case SKIP_WAL
: return TDurability
.SKIP_WAL
;
1074 case ASYNC_WAL
: return TDurability
.ASYNC_WAL
;
1075 case SYNC_WAL
: return TDurability
.SYNC_WAL
;
1076 case FSYNC_WAL
: return TDurability
.FSYNC_WAL
;
1077 default: return null;
1081 public static TTableDescriptor
tableDescriptorFromHBase(TableDescriptor in
) {
1082 TTableDescriptor out
= new TTableDescriptor();
1083 out
.setTableName(tableNameFromHBase(in
.getTableName()));
1084 Map
<Bytes
, Bytes
> attributes
= in
.getValues();
1085 for (Map
.Entry
<Bytes
, Bytes
> attribute
: attributes
.entrySet()) {
1086 out
.putToAttributes(ByteBuffer
.wrap(attribute
.getKey().get()),
1087 ByteBuffer
.wrap(attribute
.getValue().get()));
1089 for (ColumnFamilyDescriptor column
: in
.getColumnFamilies()) {
1090 out
.addToColumns(columnFamilyDescriptorFromHBase(column
));
1092 out
.setDurability(durabilityFromHBase(in
.getDurability()));
1096 public static List
<TTableDescriptor
> tableDescriptorsFromHBase(List
<TableDescriptor
> in
) {
1097 List
<TTableDescriptor
> out
= new ArrayList
<>(in
.size());
1098 for (TableDescriptor descriptor
: in
) {
1099 out
.add(tableDescriptorFromHBase(descriptor
));
1104 public static List
<TTableDescriptor
> tableDescriptorsFromHBase(TableDescriptor
[] in
) {
1105 List
<TTableDescriptor
> out
= new ArrayList
<>(in
.length
);
1106 for (TableDescriptor descriptor
: in
) {
1107 out
.add(tableDescriptorFromHBase(descriptor
));
1113 public static TBloomFilterType
bloomFilterFromHBase(BloomType in
) {
1115 case NONE
: return TBloomFilterType
.NONE
;
1116 case ROW
: return TBloomFilterType
.ROW
;
1117 case ROWCOL
: return TBloomFilterType
.ROWCOL
;
1118 case ROWPREFIX_FIXED_LENGTH
: return TBloomFilterType
.ROWPREFIX_FIXED_LENGTH
;
1119 default: return TBloomFilterType
.ROW
;
1123 public static TCompressionAlgorithm
compressionAlgorithmFromHBase(Compression
.Algorithm in
) {
1125 case LZO
: return TCompressionAlgorithm
.LZO
;
1126 case GZ
: return TCompressionAlgorithm
.GZ
;
1127 case NONE
: return TCompressionAlgorithm
.NONE
;
1128 case SNAPPY
: return TCompressionAlgorithm
.SNAPPY
;
1129 case LZ4
: return TCompressionAlgorithm
.LZ4
;
1130 case BZIP2
: return TCompressionAlgorithm
.BZIP2
;
1131 case ZSTD
: return TCompressionAlgorithm
.ZSTD
;
1132 default: return TCompressionAlgorithm
.NONE
;
1136 public static TDataBlockEncoding
dataBlockEncodingFromHBase(DataBlockEncoding in
) {
1138 case NONE
: return TDataBlockEncoding
.NONE
;
1139 case PREFIX
: return TDataBlockEncoding
.PREFIX
;
1140 case DIFF
: return TDataBlockEncoding
.DIFF
;
1141 case FAST_DIFF
: return TDataBlockEncoding
.FAST_DIFF
;
1142 case ROW_INDEX_V1
: return TDataBlockEncoding
.ROW_INDEX_V1
;
1143 default: return TDataBlockEncoding
.NONE
;
1147 public static TKeepDeletedCells
keepDeletedCellsFromHBase(KeepDeletedCells in
) {
1149 case FALSE
: return TKeepDeletedCells
.FALSE
;
1150 case TRUE
: return TKeepDeletedCells
.TRUE
;
1151 case TTL
: return TKeepDeletedCells
.TTL
;
1152 default: return TKeepDeletedCells
.FALSE
;
1156 public static TColumnFamilyDescriptor
columnFamilyDescriptorFromHBase(
1157 ColumnFamilyDescriptor in
) {
1158 TColumnFamilyDescriptor out
= new TColumnFamilyDescriptor();
1159 out
.setName(in
.getName());
1160 for (Map
.Entry
<Bytes
, Bytes
> attribute
: in
.getValues().entrySet()) {
1161 out
.putToAttributes(ByteBuffer
.wrap(attribute
.getKey().get()),
1162 ByteBuffer
.wrap(attribute
.getValue().get()));
1164 for (Map
.Entry
<String
, String
> conf
: in
.getConfiguration().entrySet()) {
1165 out
.putToConfiguration(conf
.getKey(), conf
.getValue());
1167 out
.setBlockSize(in
.getBlocksize());
1168 out
.setBloomnFilterType(bloomFilterFromHBase(in
.getBloomFilterType()));
1169 out
.setCompressionType(compressionAlgorithmFromHBase(in
.getCompressionType()));
1170 out
.setDfsReplication(in
.getDFSReplication());
1171 out
.setDataBlockEncoding(dataBlockEncodingFromHBase(in
.getDataBlockEncoding()));
1172 out
.setKeepDeletedCells(keepDeletedCellsFromHBase(in
.getKeepDeletedCells()));
1173 out
.setMaxVersions(in
.getMaxVersions());
1174 out
.setMinVersions(in
.getMinVersions());
1175 out
.setScope(in
.getScope());
1176 out
.setTimeToLive(in
.getTimeToLive());
1177 out
.setBlockCacheEnabled(in
.isBlockCacheEnabled());
1178 out
.setCacheBloomsOnWrite(in
.isCacheBloomsOnWrite());
1179 out
.setCacheDataOnWrite(in
.isCacheDataOnWrite());
1180 out
.setCacheIndexesOnWrite(in
.isCacheIndexesOnWrite());
1181 out
.setCompressTags(in
.isCompressTags());
1182 out
.setEvictBlocksOnClose(in
.isEvictBlocksOnClose());
1183 out
.setInMemory(in
.isInMemory());
1188 private static TConsistency
consistencyFromHBase(Consistency consistency
) {
1189 switch (consistency
) {
1190 case STRONG
: return TConsistency
.STRONG
;
1191 case TIMELINE
: return TConsistency
.TIMELINE
;
1192 default: return TConsistency
.STRONG
;
1196 public static TGet
getFromHBase(Get in
) {
1197 TGet out
= new TGet();
1198 out
.setRow(in
.getRow());
1200 TTimeRange tTimeRange
= new TTimeRange();
1201 tTimeRange
.setMaxStamp(in
.getTimeRange().getMax()).setMinStamp(in
.getTimeRange().getMin());
1202 out
.setTimeRange(tTimeRange
);
1203 out
.setMaxVersions(in
.getMaxVersions());
1205 for (Map
.Entry
<String
, byte[]> attribute
: in
.getAttributesMap().entrySet()) {
1206 out
.putToAttributes(ByteBuffer
.wrap(Bytes
.toBytes(attribute
.getKey())),
1207 ByteBuffer
.wrap(attribute
.getValue()));
1210 Authorizations authorizations
= in
.getAuthorizations();
1211 if (authorizations
!= null) {
1212 TAuthorization tAuthorization
= new TAuthorization();
1213 tAuthorization
.setLabels(authorizations
.getLabels());
1214 out
.setAuthorizations(tAuthorization
);
1216 } catch (DeserializationException e
) {
1217 throw new RuntimeException(e
);
1219 out
.setConsistency(consistencyFromHBase(in
.getConsistency()));
1220 out
.setTargetReplicaId(in
.getReplicaId());
1221 out
.setCacheBlocks(in
.getCacheBlocks());
1222 out
.setStoreLimit(in
.getMaxResultsPerColumnFamily());
1223 out
.setStoreOffset(in
.getRowOffsetPerColumnFamily());
1224 out
.setExistence_only(in
.isCheckExistenceOnly());
1225 for (Map
.Entry
<byte[], NavigableSet
<byte[]>> family
: in
.getFamilyMap().entrySet()) {
1227 if (family
.getValue() != null && !family
.getValue().isEmpty()) {
1228 for (byte[] qualifier
: family
.getValue()) {
1229 TColumn column
= new TColumn();
1230 column
.setFamily(family
.getKey());
1231 column
.setQualifier(qualifier
);
1232 out
.addToColumns(column
);
1235 TColumn column
= new TColumn();
1236 column
.setFamily(family
.getKey());
1237 out
.addToColumns(column
);
1240 if (in
.getFilter() != null) {
1242 out
.setFilterBytes(filterFromHBase(in
.getFilter()));
1243 } catch (IOException ioE
) {
1244 throw new RuntimeException(ioE
);
1250 public static Cell
toCell(ExtendedCellBuilder cellBuilder
, byte[] row
, TColumnValue columnValue
) {
1251 return cellBuilder
.clear()
1253 .setFamily(columnValue
.getFamily())
1254 .setQualifier(columnValue
.getQualifier())
1255 .setTimestamp(columnValue
.getTimestamp())
1256 .setType(columnValue
.getType())
1257 .setValue(columnValue
.getValue())
1258 .setTags(columnValue
.getTags())
1268 public static Result
resultFromThrift(TResult in
) {
1272 if (!in
.isSetColumnValues() || in
.getColumnValues().isEmpty()){
1273 return in
.isStale() ? EMPTY_RESULT_STALE
: EMPTY_RESULT
;
1275 List
<Cell
> cells
= new ArrayList
<>(in
.getColumnValues().size());
1276 ExtendedCellBuilder builder
= ExtendedCellBuilderFactory
.create(CellBuilderType
.SHALLOW_COPY
);
1277 for (TColumnValue columnValue
: in
.getColumnValues()) {
1278 cells
.add(toCell(builder
, in
.getRow(), columnValue
));
1280 return Result
.create(cells
, null, in
.isStale(), in
.isPartial());
1283 public static TPut
putFromHBase(Put in
) {
1284 TPut out
= new TPut();
1285 out
.setRow(in
.getRow());
1286 if (in
.getTimestamp() != HConstants
.LATEST_TIMESTAMP
) {
1287 out
.setTimestamp(in
.getTimestamp());
1289 if (in
.getDurability() != Durability
.USE_DEFAULT
) {
1290 out
.setDurability(durabilityFromHBase(in
.getDurability()));
1292 for (Map
.Entry
<byte [], List
<Cell
>> entry
: in
.getFamilyCellMap().entrySet()) {
1293 byte[] family
= entry
.getKey();
1294 for (Cell cell
: entry
.getValue()) {
1295 TColumnValue columnValue
= new TColumnValue();
1296 columnValue
.setFamily(family
)
1297 .setQualifier(CellUtil
.cloneQualifier(cell
))
1298 .setType(cell
.getType().getCode())
1299 .setTimestamp(cell
.getTimestamp())
1300 .setValue(CellUtil
.cloneValue(cell
));
1301 if (cell
.getTagsLength() != 0) {
1302 columnValue
.setTags(PrivateCellUtil
.cloneTags(cell
));
1304 out
.addToColumnValues(columnValue
);
1307 for (Map
.Entry
<String
, byte[]> attribute
: in
.getAttributesMap().entrySet()) {
1308 out
.putToAttributes(ByteBuffer
.wrap(Bytes
.toBytes(attribute
.getKey())),
1309 ByteBuffer
.wrap(attribute
.getValue()));
1312 CellVisibility cellVisibility
= in
.getCellVisibility();
1313 if (cellVisibility
!= null) {
1314 TCellVisibility tCellVisibility
= new TCellVisibility();
1315 tCellVisibility
.setExpression(cellVisibility
.getExpression());
1316 out
.setCellVisibility(tCellVisibility
);
1318 } catch (DeserializationException e
) {
1319 throw new RuntimeException(e
);
1324 public static List
<TPut
> putsFromHBase(List
<Put
> in
) {
1325 List
<TPut
> out
= new ArrayList
<>(in
.size());
1326 for (Put put
: in
) {
1327 out
.add(putFromHBase(put
));
1332 public static NamespaceDescriptor
[] namespaceDescriptorsFromThrift(
1333 List
<TNamespaceDescriptor
> in
) {
1334 NamespaceDescriptor
[] out
= new NamespaceDescriptor
[in
.size()];
1336 for (TNamespaceDescriptor descriptor
: in
) {
1337 out
[index
++] = namespaceDescriptorFromThrift(descriptor
);
1342 public static List
<TDelete
> deletesFromHBase(List
<Delete
> in
) {
1343 List
<TDelete
> out
= new ArrayList
<>(in
.size());
1344 for (Delete delete
: in
) {
1345 out
.add(deleteFromHBase(delete
));
1350 public static TAppend
appendFromHBase(Append in
) throws IOException
{
1351 TAppend out
= new TAppend();
1352 out
.setRow(in
.getRow());
1354 if (in
.getDurability() != Durability
.USE_DEFAULT
) {
1355 out
.setDurability(durabilityFromHBase(in
.getDurability()));
1357 for (Map
.Entry
<byte [], List
<Cell
>> entry
: in
.getFamilyCellMap().entrySet()) {
1358 byte[] family
= entry
.getKey();
1359 for (Cell cell
: entry
.getValue()) {
1360 TColumnValue columnValue
= new TColumnValue();
1361 columnValue
.setFamily(family
)
1362 .setQualifier(CellUtil
.cloneQualifier(cell
))
1363 .setType(cell
.getType().getCode())
1364 .setTimestamp(cell
.getTimestamp())
1365 .setValue(CellUtil
.cloneValue(cell
));
1366 if (cell
.getTagsLength() != 0) {
1367 columnValue
.setTags(PrivateCellUtil
.cloneTags(cell
));
1369 out
.addToColumns(columnValue
);
1372 for (Map
.Entry
<String
, byte[]> attribute
: in
.getAttributesMap().entrySet()) {
1373 out
.putToAttributes(ByteBuffer
.wrap(Bytes
.toBytes(attribute
.getKey())),
1374 ByteBuffer
.wrap(attribute
.getValue()));
1377 CellVisibility cellVisibility
= in
.getCellVisibility();
1378 if (cellVisibility
!= null) {
1379 TCellVisibility tCellVisibility
= new TCellVisibility();
1380 tCellVisibility
.setExpression(cellVisibility
.getExpression());
1381 out
.setCellVisibility(tCellVisibility
);
1383 } catch (DeserializationException e
) {
1384 throw new RuntimeException(e
);
1386 out
.setReturnResults(in
.isReturnResults());
1390 public static TIncrement
incrementFromHBase(Increment in
) throws IOException
{
1391 TIncrement out
= new TIncrement();
1392 out
.setRow(in
.getRow());
1394 if (in
.getDurability() != Durability
.USE_DEFAULT
) {
1395 out
.setDurability(durabilityFromHBase(in
.getDurability()));
1397 for (Map
.Entry
<byte [], List
<Cell
>> entry
: in
.getFamilyCellMap().entrySet()) {
1398 byte[] family
= entry
.getKey();
1399 for (Cell cell
: entry
.getValue()) {
1400 TColumnIncrement columnValue
= new TColumnIncrement();
1401 columnValue
.setFamily(family
).setQualifier(CellUtil
.cloneQualifier(cell
));
1402 columnValue
.setAmount(
1403 Bytes
.toLong(cell
.getValueArray(), cell
.getValueOffset(), cell
.getValueLength()));
1404 out
.addToColumns(columnValue
);
1407 for (Map
.Entry
<String
, byte[]> attribute
: in
.getAttributesMap().entrySet()) {
1408 out
.putToAttributes(ByteBuffer
.wrap(Bytes
.toBytes(attribute
.getKey())),
1409 ByteBuffer
.wrap(attribute
.getValue()));
1412 CellVisibility cellVisibility
= in
.getCellVisibility();
1413 if (cellVisibility
!= null) {
1414 TCellVisibility tCellVisibility
= new TCellVisibility();
1415 tCellVisibility
.setExpression(cellVisibility
.getExpression());
1416 out
.setCellVisibility(tCellVisibility
);
1418 } catch (DeserializationException e
) {
1419 throw new RuntimeException(e
);
1421 out
.setReturnResults(in
.isReturnResults());
1425 public static TRowMutations
rowMutationsFromHBase(RowMutations in
) {
1426 TRowMutations tRowMutations
= new TRowMutations();
1427 tRowMutations
.setRow(in
.getRow());
1428 for (Mutation mutation
: in
.getMutations()) {
1429 TMutation tMutation
= new TMutation();
1430 if (mutation
instanceof Put
) {
1431 tMutation
.setPut(ThriftUtilities
.putFromHBase((Put
)mutation
));
1432 } else if (mutation
instanceof Delete
) {
1433 tMutation
.setDeleteSingle(ThriftUtilities
.deleteFromHBase((Delete
)mutation
));
1435 throw new IllegalArgumentException(
1436 "Only Put and Delete is supported in mutateRow, but muation=" + mutation
);
1438 tRowMutations
.addToMutations(tMutation
);
1440 return tRowMutations
;
1443 public static TCompareOperator
compareOpFromHBase(CompareOperator compareOp
) {
1444 switch (compareOp
) {
1445 case LESS
: return TCompareOperator
.LESS
;
1446 case LESS_OR_EQUAL
: return TCompareOperator
.LESS_OR_EQUAL
;
1447 case EQUAL
: return TCompareOperator
.EQUAL
;
1448 case NOT_EQUAL
: return TCompareOperator
.NOT_EQUAL
;
1449 case GREATER_OR_EQUAL
: return TCompareOperator
.GREATER_OR_EQUAL
;
1450 case GREATER
: return TCompareOperator
.GREATER
;
1451 case NO_OP
: return TCompareOperator
.NO_OP
;
1452 default: return null;
1455 public static List
<ByteBuffer
> splitKeyFromHBase(byte[][] in
) {
1456 if (in
== null || in
.length
== 0) {
1459 List
<ByteBuffer
> out
= new ArrayList
<>(in
.length
);
1460 for (byte[] key
: in
) {
1461 out
.add(ByteBuffer
.wrap(key
));
1466 public static Result
[] resultsFromThrift(List
<TResult
> in
) {
1467 Result
[] out
= new Result
[in
.size()];
1469 for (TResult tResult
: in
) {
1470 out
[index
++] = resultFromThrift(tResult
);
1475 public static List
<TGet
> getsFromHBase(List
<Get
> in
) {
1476 List
<TGet
> out
= new ArrayList
<>(in
.size());
1477 for (Get get
: in
) {
1478 out
.add(getFromHBase(get
));
1483 public static Set
<TServerName
> getServerNamesFromHBase(Set
<ServerName
> serverNames
) {
1484 if (CollectionUtils
.isEmpty(serverNames
)) {
1485 return Collections
.emptySet();
1487 return serverNames
.stream().map(serverName
-> {
1488 TServerName tServerName
= new TServerName();
1489 tServerName
.setHostName(serverName
.getHostname());
1490 tServerName
.setPort(serverName
.getPort());
1491 tServerName
.setStartCode(serverName
.getStartcode());
1493 }).collect(Collectors
.toSet());
1496 public static Set
<ServerName
> getServerNamesFromThrift(Set
<TServerName
> tServerNames
) {
1497 if (CollectionUtils
.isEmpty(tServerNames
)) {
1498 return Collections
.emptySet();
1500 return tServerNames
.stream().map(tServerName
->
1501 ServerName
.valueOf(tServerName
.getHostName(),
1502 tServerName
.getPort(),
1503 tServerName
.getStartCode()))
1504 .collect(Collectors
.toSet());
1507 public static TSlowLogQueryFilter
getSlowLogQueryFromHBase(
1508 SlowLogQueryFilter slowLogQueryFilter
) {
1509 TSlowLogQueryFilter tSlowLogQueryFilter
= new TSlowLogQueryFilter();
1510 tSlowLogQueryFilter
.setRegionName(slowLogQueryFilter
.getRegionName());
1511 tSlowLogQueryFilter
.setClientAddress(slowLogQueryFilter
.getClientAddress());
1512 tSlowLogQueryFilter
.setTableName(slowLogQueryFilter
.getTableName());
1513 tSlowLogQueryFilter
.setUserName(slowLogQueryFilter
.getUserName());
1514 tSlowLogQueryFilter
.setLimit(slowLogQueryFilter
.getLimit());
1515 return tSlowLogQueryFilter
;
1518 public static SlowLogQueryFilter
getSlowLogQueryFromThrift(
1519 TSlowLogQueryFilter tSlowLogQueryFilter
) {
1520 SlowLogQueryFilter slowLogQueryFilter
= new SlowLogQueryFilter();
1521 slowLogQueryFilter
.setRegionName(tSlowLogQueryFilter
.getRegionName());
1522 slowLogQueryFilter
.setClientAddress(tSlowLogQueryFilter
.getClientAddress());
1523 slowLogQueryFilter
.setTableName(tSlowLogQueryFilter
.getTableName());
1524 slowLogQueryFilter
.setUserName(tSlowLogQueryFilter
.getUserName());
1525 slowLogQueryFilter
.setLimit(tSlowLogQueryFilter
.getLimit());
1526 return slowLogQueryFilter
;
1529 public static List
<TSlowLogRecord
> getSlowLogRecordsFromHBase(
1530 List
<SlowLogRecord
> slowLogRecords
) {
1531 if (CollectionUtils
.isEmpty(slowLogRecords
)) {
1532 return Collections
.emptyList();
1534 return slowLogRecords
.stream()
1535 .map(slowLogRecord
-> {
1536 TSlowLogRecord tSlowLogRecord
= new TSlowLogRecord();
1537 tSlowLogRecord
.setCallDetails(slowLogRecord
.getCallDetails());
1538 tSlowLogRecord
.setClientAddress(slowLogRecord
.getClientAddress());
1539 tSlowLogRecord
.setMethodName(slowLogRecord
.getMethodName());
1540 tSlowLogRecord
.setMultiGetsCount(slowLogRecord
.getMultiGetsCount());
1541 tSlowLogRecord
.setMultiMutationsCount(slowLogRecord
.getMultiMutationsCount());
1542 tSlowLogRecord
.setMultiServiceCalls(slowLogRecord
.getMultiServiceCalls());
1543 tSlowLogRecord
.setParam(slowLogRecord
.getParam());
1544 tSlowLogRecord
.setProcessingTime(slowLogRecord
.getProcessingTime());
1545 tSlowLogRecord
.setQueueTime(slowLogRecord
.getQueueTime());
1546 tSlowLogRecord
.setRegionName(slowLogRecord
.getRegionName());
1547 tSlowLogRecord
.setResponseSize(slowLogRecord
.getResponseSize());
1548 tSlowLogRecord
.setServerClass(slowLogRecord
.getServerClass());
1549 tSlowLogRecord
.setStartTime(slowLogRecord
.getStartTime());
1550 tSlowLogRecord
.setUserName(slowLogRecord
.getUserName());
1551 return tSlowLogRecord
;
1552 }).collect(Collectors
.toList());
1555 public static List
<SlowLogRecord
> getSlowLogRecordsFromThrift(
1556 List
<TSlowLogRecord
> tSlowLogRecords
) {
1557 if (CollectionUtils
.isEmpty(tSlowLogRecords
)) {
1558 return Collections
.emptyList();
1560 return tSlowLogRecords
.stream()
1561 .map(tSlowLogRecord
-> new SlowLogRecord
.SlowLogRecordBuilder()
1562 .setCallDetails(tSlowLogRecord
.getCallDetails())
1563 .setClientAddress(tSlowLogRecord
.getClientAddress())
1564 .setMethodName(tSlowLogRecord
.getMethodName())
1565 .setMultiGetsCount(tSlowLogRecord
.getMultiGetsCount())
1566 .setMultiMutationsCount(tSlowLogRecord
.getMultiMutationsCount())
1567 .setMultiServiceCalls(tSlowLogRecord
.getMultiServiceCalls())
1568 .setParam(tSlowLogRecord
.getParam())
1569 .setProcessingTime(tSlowLogRecord
.getProcessingTime())
1570 .setQueueTime(tSlowLogRecord
.getQueueTime())
1571 .setRegionName(tSlowLogRecord
.getRegionName())
1572 .setResponseSize(tSlowLogRecord
.getResponseSize())
1573 .setServerClass(tSlowLogRecord
.getServerClass())
1574 .setStartTime(tSlowLogRecord
.getStartTime())
1575 .setUserName(tSlowLogRecord
.getUserName())
1577 .collect(Collectors
.toList());