forked from oceanbase/obkv-table-client-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathObTableMetaRequest.java
More file actions
86 lines (73 loc) · 2.91 KB
/
ObTableMetaRequest.java
File metadata and controls
86 lines (73 loc) · 2.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*-
* #%L
* com.oceanbase:obkv-table-client
* %%
* Copyright (C) 2021 - 2025 OceanBase
* %%
* OBKV Table Client Framework is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* #L%
*/
package com.alipay.oceanbase.rpc.meta;
import com.alipay.oceanbase.rpc.protocol.payload.AbstractPayload;
import com.alipay.oceanbase.rpc.protocol.payload.Credentialable;
import com.alipay.oceanbase.rpc.protocol.payload.Pcodes;
import com.alipay.oceanbase.rpc.util.ObBytesString;
import com.alipay.oceanbase.rpc.util.Serialization;
import static com.alipay.oceanbase.rpc.util.Serialization.encodeObUniVersionHeader;
import static com.alipay.oceanbase.rpc.util.Serialization.getObUniVersionHeaderLength;
public class ObTableMetaRequest extends AbstractPayload implements Credentialable {
private ObBytesString credential;
private ObTableRpcMetaType metaType;
private String data;
@Override
public void setCredential(ObBytesString credential) {
this.credential = credential;
}
@Override
public int getPcode() {
return Pcodes.OB_TABLE_API_META_INFO_EXECUTE;
}
@Override
public byte[] encode() {
byte[] bytes = new byte[(int) getPayloadSize()];
int idx = 0;
// 0. encode header
int headerLen = (int) getObUniVersionHeaderLength(getVersion(), getPayloadContentSize());
System.arraycopy(encodeObUniVersionHeader(getVersion(), getPayloadContentSize()), 0, bytes,
idx, headerLen);
idx += headerLen;
int len = Serialization.getNeedBytes(credential);
System.arraycopy(Serialization.encodeBytesString(credential), 0, bytes, idx, len);
idx += len;
len = Serialization.getNeedBytes(metaType.getType());
System.arraycopy(Serialization.encodeI8((short)metaType.getType()), 0, bytes, idx, len);
idx += len;
len = Serialization.getNeedBytes(data);
System.arraycopy(Serialization.encodeVString(data), 0, bytes, idx, len);
return bytes;
}
@Override
public long getPayloadContentSize() {
return Serialization.getNeedBytes(credential)
+ Serialization.getNeedBytes(metaType.getType()) + Serialization.getNeedBytes(data);
}
public void setMetaType(ObTableRpcMetaType metaType) {
this.metaType = metaType;
}
public ObTableRpcMetaType getMetaType() {
return metaType;
}
public void setData(String data) {
this.data = data;
}
public String getData() {
return data;
}
}