use structopt::StructOpt;
use tracing_subscriber::util::SubscriberInitExt;
use ws_tool::{
codec::{default_handshake_handler, WsBytesCodec},
frame::OpCode,
ServerBuilder,
};
#[derive(StructOpt)]
struct Args {
#[structopt(long, default_value = "127.0.0.1")]
host: String,
#[structopt(short, long, default_value = "9000")]
port: u16,
#[structopt(short, long, default_value = "info")]
level: tracing::Level,
}
fn main() -> Result<(), ()> {
let args = Args::from_args();
tracing_subscriber::fmt::fmt()
.with_max_level(args.level)
.finish()
.try_init()
.expect("failed to init log");
tracing::info!("binding on {}:{}", args.host, args.port);
let listener = std::net::TcpListener::bind(format!("{}:{}", args.host, args.port)).unwrap();
loop {
let (stream, addr) = listener.accept().unwrap();
stream.set_nodelay(true).unwrap();
std::thread::spawn(move || {
tracing::info!("got connect from {:?}", addr);
let mut server =
ServerBuilder::accept(stream, default_handshake_handler, WsBytesCodec::factory)
.unwrap();
loop {
if let Ok(mut msg) = server.receive() {
if msg.code == OpCode::Close {
break;
}
server.send(&mut msg.data[..]).unwrap();
} else {
break;
}
}
tracing::info!("one conn down");
});
}
}