-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnode.proto
66 lines (58 loc) · 1.19 KB
/
node.proto
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
syntax = "proto3";
message VoteRequest {
int32 candidate_id = 1;
int32 term = 2;
int32 log_length = 3;
int32 last_term = 4;
}
message VoteResponse {
int32 voter_id = 1;
int32 term = 2;
bool vote_granted = 3;
float old_leader_lease_duration = 4;
}
message LogRequest{
message LogItem {
string command = 1;
string key = 2;
string value = 3;
int32 term = 4;
}
int32 leader_id = 1;
int32 term = 2;
int32 prefixLen = 3;
int32 prefixTerm = 4;
int32 leaderCommit = 5;
repeated LogItem suffix = 6;
int32 follower_id = 7;
float leader_lease = 8;
}
message LogResponse{
int32 node_id = 1;
int32 term = 2;
int32 ack = 3;
bool success = 4;
}
//Client operations
message SetValRequest {
string key = 1;
string value = 2;
}
message SetValResponse {
bool success = 1;
int32 current_leader = 2;
}
message GetValRequest {
string key = 1;
}
message GetValResponse {
string value = 1;
bool success = 2;
int32 current_leader = 3;
}
service Node {
rpc Log(LogRequest) returns (LogResponse);
rpc Vote(VoteRequest) returns (VoteResponse);
rpc SetVal(SetValRequest) returns (SetValResponse);
rpc GetVal(GetValRequest) returns (GetValResponse);
}