erigon-pulse/ethdb/remote/kv.proto

35 lines
1.0 KiB
Protocol Buffer
Raw Normal View History

2020-07-27 12:15:48 +00:00
syntax = "proto3";
package remote;
option go_package = "./remote;remote";
option java_multiple_files = true;
option java_package = "io.turbo-geth.db";
option java_outer_classname = "KV";
2020-07-29 04:31:46 +00:00
// Provides methods to access key-value data
2020-07-27 12:15:48 +00:00
service KV {
// open a cursor on given position of given bucket
// if streaming requested - streams all data: stops if client's buffer is full, resumes when client read enough from buffer
// if streaming not requested - streams next data only when clients sends message to bi-directional channel
// no full consistency guarantee - server implementation can close/open underlying db transaction at any time
rpc Seek(stream SeekRequest) returns (stream Pair);
}
message SeekRequest {
bytes bucketName = 1;
bytes seekKey = 2; // streaming start from this key
bytes prefix = 3; // streaming stops when see first key without given prefix
bool startSreaming = 4;
}
message Pair {
bytes key = 1;
bytes value = 2;
}
message PairKey {
bytes key = 1;
uint64 vSize = 2;
}