2019-10-11 16:08:50 +03:00
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
package go.micro.store;
|
|
|
|
|
|
|
|
service Store {
|
2019-10-24 00:05:39 +03:00
|
|
|
rpc List(ListRequest) returns (stream ListResponse) {};
|
2019-10-11 16:08:50 +03:00
|
|
|
rpc Read(ReadRequest) returns (ReadResponse) {};
|
|
|
|
rpc Write(WriteRequest) returns (WriteResponse) {};
|
|
|
|
rpc Delete(DeleteRequest) returns (DeleteResponse) {};
|
|
|
|
}
|
|
|
|
|
|
|
|
message Record {
|
|
|
|
// key of the record
|
|
|
|
string key = 1;
|
|
|
|
// value in the record
|
|
|
|
bytes value = 2;
|
|
|
|
// timestamp in unix seconds
|
|
|
|
int64 expiry = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message ReadRequest {
|
|
|
|
repeated string keys = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message ReadResponse {
|
|
|
|
repeated Record records = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message WriteRequest {
|
|
|
|
repeated Record records = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message WriteResponse {}
|
|
|
|
|
|
|
|
message DeleteRequest {
|
|
|
|
repeated string keys = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message DeleteResponse {}
|
|
|
|
|
2019-10-24 00:05:39 +03:00
|
|
|
message ListRequest {
|
2019-10-11 16:08:50 +03:00
|
|
|
// optional key
|
|
|
|
string key = 1;
|
|
|
|
}
|
|
|
|
|
2019-10-24 00:05:39 +03:00
|
|
|
message ListResponse {
|
2019-10-11 16:08:50 +03:00
|
|
|
repeated Record records = 1;
|
|
|
|
}
|