0
0
mirror of https://github.com/tursodatabase/libsql.git synced 2025-05-17 18:17:01 +00:00
Files
libsql/libsql-storage/proto/storage.proto
Avinash Sajjanshetty 3460edce12 Add storage server RPC client (#1430)
* Add storage server RPC client

* Address review comments

- Use `#[tracing::instrument]` wherever appropriate
- Remove `Mutex` for `client` and `clone` it wherever required
- Avoid reading env variable inside the lib, rather take a config object
- Make the private methods of `DurableWal` async
- Don't try to create a runtime, instead assume it always exists. Let the caller create it
- Update proto:
	- remove `max_frame_no` from `InsertFramesRequest`
	- make `page_no` to `u32` in the proto
- Update storage server to have `page_no` as `u32`
2024-06-04 11:26:50 +00:00

78 lines
1.4 KiB
Protocol Buffer

syntax = "proto3";
package storage;
message Frame {
uint32 page_no = 1;
bytes data = 2;
}
message InsertFramesRequest {
string namespace = 1;
repeated Frame frames = 2;
}
message InsertFramesResponse {
uint32 num_frames = 1;
}
message FindFrameRequest {
string namespace = 1;
uint32 page_no = 2;
uint64 max_frame_no = 3;
}
message FindFrameResponse {
optional uint64 frame_no = 1;
}
message ReadFrameRequest {
string namespace = 1;
uint64 frame_no = 2;
}
message ReadFrameResponse {
optional bytes frame = 1;
}
message DbSizeRequest {
string namespace = 1;
}
message DbSizeResponse {
uint64 size = 1;
}
message FramesInWALRequest {
string namespace = 1;
}
message FramesInWALResponse {
uint64 count = 1;
}
message FramePageNumRequest {
string namespace = 1;
uint64 frame_no = 2;
}
message FramePageNumResponse {
uint32 page_no = 1;
}
message DestroyRequest {
string namespace = 1;
}
message DestroyResponse {}
service Storage {
rpc InsertFrames(InsertFramesRequest) returns (InsertFramesResponse) {}
rpc FindFrame(FindFrameRequest) returns (FindFrameResponse) {}
rpc ReadFrame(ReadFrameRequest) returns (ReadFrameResponse) {}
rpc DbSize(DbSizeRequest) returns (DbSizeResponse) {}
rpc FramesInWAL(FramesInWALRequest) returns (FramesInWALResponse) {}
rpc FramePageNum(FramePageNumRequest) returns (FramePageNumResponse) {}
rpc Destroy(DestroyRequest) returns (DestroyResponse) {}
}