2023-02-10 13:36:58 -06:00
|
|
|
use shipyard::{World, AllStoragesView, Unique, Workload, IntoWorkload, UniqueView, UniqueViewMut};
|
2023-02-10 13:26:03 -06:00
|
|
|
use kubi_udp::server::{Server, ServerConfig};
|
|
|
|
use kubi_shared::networking::messages::{ClientToServerMessage, ServerToClientMessage};
|
2023-02-10 15:11:18 -06:00
|
|
|
use std::{thread, time::Duration, net::SocketAddr};
|
|
|
|
|
|
|
|
#[derive(Unique)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ServerAddr(SocketAddr);
|
2023-02-10 13:26:03 -06:00
|
|
|
|
2023-02-10 13:36:58 -06:00
|
|
|
#[derive(Unique)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct UdpServer(Server<ServerToClientMessage, ClientToServerMessage>);
|
|
|
|
|
|
|
|
fn bind_server(
|
|
|
|
storages: AllStoragesView,
|
|
|
|
) {
|
2023-02-10 15:11:18 -06:00
|
|
|
log::info!("Creating server...");
|
|
|
|
let addr = storages.borrow::<UniqueView<SocketAddr>>().expect("No server addr found");
|
2023-02-10 13:36:58 -06:00
|
|
|
let server: Server<ServerToClientMessage, ClientToServerMessage> = Server::bind(
|
2023-02-10 13:26:03 -06:00
|
|
|
"0.0.0.0:1234".parse().unwrap(),
|
|
|
|
ServerConfig::default()
|
|
|
|
).unwrap();
|
2023-02-10 13:36:58 -06:00
|
|
|
storages.add_unique(UdpServer(server));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn update_server(
|
|
|
|
mut server: UniqueViewMut<UdpServer>
|
|
|
|
) {
|
|
|
|
if let Err(error) = server.0.update() {
|
2023-02-10 15:05:10 -06:00
|
|
|
log::error!("Server error: {error:?}")
|
2023-02-10 13:36:58 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn initialize() -> Workload {
|
|
|
|
(
|
|
|
|
bind_server,
|
|
|
|
).into_workload()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn update() -> Workload {
|
|
|
|
(
|
|
|
|
update_server,
|
|
|
|
).into_workload()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
2023-02-10 13:44:34 -06:00
|
|
|
kubi_logging::init();
|
2023-02-10 13:36:58 -06:00
|
|
|
let world = World::new();
|
|
|
|
world.add_workload(initialize);
|
|
|
|
world.add_workload(update);
|
|
|
|
world.run_workload(initialize).unwrap();
|
2023-02-10 15:11:18 -06:00
|
|
|
log::info!("The server is now running");
|
2023-02-10 13:26:03 -06:00
|
|
|
loop {
|
2023-02-10 13:36:58 -06:00
|
|
|
world.run_workload(update).unwrap();
|
2023-02-10 15:05:10 -06:00
|
|
|
thread::sleep(Duration::from_millis(16));
|
2023-02-10 13:26:03 -06:00
|
|
|
}
|
2023-01-29 18:46:22 -06:00
|
|
|
}
|