Cap’n Proto RPC serving¶
1 Overview¶
readcon-core provides an optional Cap’n Proto RPC interface (behind
the rpc feature flag) that allows any language with a Cap’n Proto
implementation to request frame parsing and writing over the network.
2 Schema¶
The schema defines a ReadConService interface with two methods:
parseFramesAccepts raw file bytes, returns parsed frame data.
writeFramesAccepts structured frame data, returns serialized file bytes.
The schema file is at schema/ReadCon.capnp.
3 Building¶
# Requires capnproto installed (via pixi or system package)
cargo build --features rpc
# Or via pixi (capnproto is a dependency)
pixi r build-rpc
4 Server¶
// Start a TCP RPC server
#[tokio::main]
async fn main() {
readcon_core::rpc::server::start_server("127.0.0.1:9876")
.await
.unwrap();
}
5 Client¶
use readcon_core::rpc::client::RpcClient;
use std::path::Path;
let client = RpcClient::new("127.0.0.1:9876").unwrap();
let frames = client.parse_file(Path::new("input.con")).unwrap();
let output = client.write_frames(&frames).unwrap();
6 Protocol¶
The RPC uses Cap’n Proto two-party protocol over TCP. The server listens on a configurable host:port and handles one connection per accepted socket using tokio for async I/O.