2023-05-19 06:22:32 -05:00
|
|
|
use glam::Mat4;
|
2023-05-19 19:32:32 -05:00
|
|
|
use shipyard::{Component, EntityId, Unique, AllStoragesView, UniqueView, NonSendSync, View, ViewMut, Get, IntoIter};
|
2023-02-11 18:32:59 -06:00
|
|
|
use hashbrown::HashMap;
|
2023-05-19 19:32:32 -05:00
|
|
|
use uflow::SendMode;
|
2023-03-08 20:30:37 -06:00
|
|
|
use std::net::SocketAddr;
|
2023-05-19 06:22:32 -05:00
|
|
|
use kubi_shared::{
|
|
|
|
networking::{
|
|
|
|
client::{ClientIdMap, Client},
|
2023-05-19 19:32:32 -05:00
|
|
|
messages::{ClientToServerMessage, ServerToClientMessage, C_POSITION_CHANGED},
|
|
|
|
channels::CHANNEL_MOVE
|
2023-05-19 06:22:32 -05:00
|
|
|
},
|
|
|
|
transform::Transform
|
|
|
|
};
|
|
|
|
use crate::{
|
|
|
|
server::{ServerEvents, UdpServer},
|
|
|
|
util::check_message_auth
|
2023-05-19 00:02:20 -05:00
|
|
|
};
|
2023-02-11 17:37:24 -06:00
|
|
|
|
2023-03-08 20:30:37 -06:00
|
|
|
#[derive(Component, Clone, Copy)]
|
|
|
|
pub struct ClientAddress(pub SocketAddr);
|
2023-02-11 18:32:59 -06:00
|
|
|
|
2023-03-08 20:30:37 -06:00
|
|
|
#[derive(Unique, Default)]
|
|
|
|
pub struct ClientAddressMap(pub HashMap<SocketAddr, EntityId>);
|
|
|
|
impl ClientAddressMap {
|
|
|
|
pub fn new() -> Self { Self::default() }
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn init_client_maps(
|
|
|
|
storages: AllStoragesView
|
|
|
|
) {
|
|
|
|
storages.add_unique(ClientIdMap::new());
|
|
|
|
storages.add_unique(ClientAddressMap::new());
|
|
|
|
}
|
2023-05-19 00:02:20 -05:00
|
|
|
|
|
|
|
pub fn sync_client_positions(
|
|
|
|
server: NonSendSync<UniqueView<UdpServer>>,
|
|
|
|
events: UniqueView<ServerEvents>,
|
|
|
|
addr_map: UniqueView<ClientAddressMap>,
|
|
|
|
clients: View<Client>,
|
2023-05-19 19:32:32 -05:00
|
|
|
mut transforms: ViewMut<Transform>,
|
|
|
|
addrs: View<ClientAddress>,
|
2023-05-19 00:02:20 -05:00
|
|
|
) {
|
|
|
|
for event in &events.0 {
|
2023-05-19 06:22:32 -05:00
|
|
|
let Some(message) = check_message_auth::<C_POSITION_CHANGED>(&server, event, &clients, &addr_map) else {
|
|
|
|
continue;
|
2023-05-19 00:02:20 -05:00
|
|
|
};
|
2023-05-19 06:22:32 -05:00
|
|
|
let ClientToServerMessage::PositionChanged { position, velocity: _, direction } = message.message else {
|
2023-05-19 00:02:20 -05:00
|
|
|
unreachable!()
|
|
|
|
};
|
2023-05-19 19:32:32 -05:00
|
|
|
|
|
|
|
//log movement (annoying duh)
|
|
|
|
log::debug!("dbg: player moved id: {} coords: {} quat: {}", message.client_id, position, direction);
|
|
|
|
|
|
|
|
//Apply position to server-side client
|
2023-05-19 06:22:32 -05:00
|
|
|
let mut trans = (&mut transforms).get(message.entity_id).unwrap();
|
|
|
|
trans.0 = Mat4::from_rotation_translation(direction, position);
|
2023-05-19 00:02:20 -05:00
|
|
|
|
2023-05-19 19:32:32 -05:00
|
|
|
//Transmit the change to other players
|
|
|
|
for (other_client, other_client_address) in (&clients, &addrs).iter() {
|
|
|
|
if other_client.0 == message.client_id {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
let Some(client) = server.0.client(&other_client_address.0) else {
|
|
|
|
log::error!("Client with address not found");
|
|
|
|
continue
|
|
|
|
};
|
|
|
|
client.borrow_mut().send(
|
|
|
|
postcard::to_allocvec(
|
|
|
|
&ServerToClientMessage::PlayerPositionChanged {
|
|
|
|
client_id: message.client_id,
|
|
|
|
position,
|
|
|
|
direction
|
|
|
|
}
|
|
|
|
).unwrap().into_boxed_slice(),
|
|
|
|
CHANNEL_MOVE,
|
|
|
|
SendMode::Reliable
|
|
|
|
);
|
|
|
|
}
|
2023-05-19 00:02:20 -05:00
|
|
|
}
|
|
|
|
}
|