mirror of
https://github.com/Astatin3/unshell.git
synced 2026-06-08 22:38:01 -06:00
d4100d0604
Move the protocol runtime into unshell-protocol and remote shell leaf code into unshell-leaves so endpoint and TUI roles can compile independently without circular dependencies.
39 lines
1.3 KiB
Rust
39 lines
1.3 KiB
Rust
//! Remote shell endpoint example.
|
|
//!
|
|
//! This binary acts as the single remote-shell endpoint process. It connects to the controller
|
|
//! example over TCP, feeds inbound frames into the `ProcedureRuntime`, and flushes any resulting
|
|
//! protocol frames back to the controller.
|
|
|
|
use std::error::Error;
|
|
use std::net::TcpStream;
|
|
use std::sync::mpsc::RecvTimeoutError;
|
|
use std::time::Duration;
|
|
|
|
use unshell::protocol::tree::Ingress;
|
|
use unshell_leaves::remote_shell;
|
|
|
|
fn main() -> Result<(), Box<dyn Error>> {
|
|
let mut stream = TcpStream::connect(remote_shell::LISTEN_ADDR)?;
|
|
let frame_rx = remote_shell::spawn_frame_reader(stream.try_clone()?);
|
|
let mut runtime = remote_shell::build_agent_runtime();
|
|
|
|
println!("connected to controller at {}", remote_shell::LISTEN_ADDR);
|
|
|
|
loop {
|
|
match frame_rx.recv_timeout(Duration::from_millis(25)) {
|
|
Ok(result) => {
|
|
let frame = result?;
|
|
let outcome = runtime.receive(&Ingress::Parent, frame)?;
|
|
remote_shell::write_frames(&mut stream, &outcome.frames)?;
|
|
}
|
|
Err(RecvTimeoutError::Timeout) => {}
|
|
Err(RecvTimeoutError::Disconnected) => break,
|
|
}
|
|
|
|
let outcome = runtime.poll()?;
|
|
remote_shell::write_frames(&mut stream, &outcome.frames)?;
|
|
}
|
|
|
|
Ok(())
|
|
}
|