-
Notifications
You must be signed in to change notification settings - Fork 0
/
peer.proto
69 lines (53 loc) · 1.45 KB
/
peer.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
67
68
69
syntax = "proto3";
option go_package = "github.com/yousuf64/chord-kv/remote/transport";
import "google/protobuf/empty.proto";
service Peer {
rpc FindSuccessor (FindSuccessorRequest) returns (FindSuccessorReply) {}
rpc SetSuccessor (SetSuccessorRequest) returns (google.protobuf.Empty) {}
rpc SetPredecessor (SetPredecessorRequest) returns (google.protobuf.Empty) {}
rpc Notify (NotifyRequest) returns (NotifyReply) {}
rpc GetPredecessor (google.protobuf.Empty) returns (GetPredecessorReply) {}
rpc Leave(google.protobuf.Empty) returns (google.protobuf.Empty) {}
rpc Healthz(google.protobuf.Empty) returns (google.protobuf.Empty) {}
rpc Insert(InsertRequest) returns (google.protobuf.Empty) {}
rpc Query(QueryRequest) returns (QueryReply) {}
}
message SetSuccessorRequest {
string address = 1;
}
message SetPredecessorRequest {
string address = 1;
}
message FindSuccessorRequest {
uint64 id = 1;
}
message FindSuccessorReply {
string address = 1;
}
message NotifyRequest {
string address = 1;
}
message NotifyReply {
repeated InsertItem items = 1;
}
message GetPredecessorReply {
string address = 1;
}
message InsertRequest {
repeated InsertItem items = 1;
}
message InsertItem {
string index = 1;
string key = 2;
string value = 3;
}
message QueryRequest {
string index = 1;
string query = 2;
}
message QueryReply {
string value = 1;
}
// GRPC Server -- routes to -- Chord
// Chord -- Clients > PeerClient
// Lord of the Ring