Files
radarflow2-kvm/src/main.rs

57 lines
1.4 KiB
Rust
Raw Normal View History

use std::sync::Arc;
2023-10-31 17:23:15 +01:00
use clap::Parser;
2023-10-31 17:23:15 +01:00
use cli::Cli;
use comms::RadarData;
2023-10-31 17:23:15 +01:00
use tokio::sync::RwLock;
mod cli;
mod structs;
mod enums;
mod comms;
mod dma;
mod websocket;
2023-10-31 17:23:15 +01:00
#[tokio::main]
async fn main() -> anyhow::Result<()> {
let cli: Cli = Cli::parse();
2023-10-31 17:23:15 +01:00
simple_logger::SimpleLogger::new()
.with_level(cli.loglevel.into())
.init()
.expect("Initializing logger");
let radar_data = Arc::new(
2023-10-31 17:23:15 +01:00
RwLock::new(
RadarData::empty(0)
2023-10-31 17:23:15 +01:00
)
);
let radar_clone = radar_data.clone();
2023-10-31 17:23:15 +01:00
let dma_handle = tokio::spawn(async move {
if let Err(err) = dma::run(radar_clone, cli.connector, cli.pcileech_device).await {
log::error!("Error in dma thread: [{}]", err.to_string());
} else {
println!("CS2 Process exited, exiting program...")
2023-10-31 17:23:15 +01:00
}
});
let _websocket_handle = tokio::spawn(async move {
2023-10-31 17:23:15 +01:00
if let Ok(my_local_ip) = local_ip_address::local_ip() {
let address = format!("http://{}:{}", my_local_ip, cli.port);
println!("Launched webserver at {}", address);
} else {
let address = format!("http://0.0.0.0:{}", cli.port);
println!("launched webserver at {}", address);
2023-10-31 17:23:15 +01:00
}
if let Err(err) = websocket::run(cli.web_path, cli.port, radar_data).await {
log::error!("Error in ws server: [{}]", err.to_string());
2023-10-31 17:23:15 +01:00
}
});
dma_handle.await?;
2023-10-31 17:23:15 +01:00
Ok(())
}