diff options
| author | Gustav Sörnäs <gustav@sornas.net> | 2021-01-01 17:40:00 +0100 |
|---|---|---|
| committer | Gustav Sörnäs <gustav@sornas.net> | 2021-01-01 17:40:00 +0100 |
| commit | aef5b85b22b916a3a7f84b1b9bbea151544580f3 (patch) | |
| tree | 24c79ff42ce823b29cd94f72d7e567c67a7fc8f0 /mumd/src/command.rs | |
| parent | a32511e0b70288cad6d4915b30956f3eb8728149 (diff) | |
| download | mum-aef5b85b22b916a3a7f84b1b9bbea151544580f3.tar.gz | |
move none-state-fields on state to client
Diffstat (limited to 'mumd/src/command.rs')
| -rw-r--r-- | mumd/src/command.rs | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/mumd/src/command.rs b/mumd/src/command.rs index 330e3fc..e8c92c3 100644 --- a/mumd/src/command.rs +++ b/mumd/src/command.rs @@ -1,13 +1,13 @@ -use crate::state::{ExecutionContext, State}; +use crate::{network::ConnectionInfo, state::{ExecutionContext, State}}; use crate::network::tcp::{TcpEvent, TcpEventCallback}; use ipc_channel::ipc::IpcSender; use log::*; -use mumble_protocol::ping::PongPacket; +use mumble_protocol::{Serverbound, control::ControlPacket, ping::PongPacket}; use mumlib::command::{Command, CommandResponse}; use std::net::SocketAddr; use std::sync::{Arc, Mutex}; -use tokio::sync::{mpsc, oneshot}; +use tokio::sync::{mpsc, oneshot, watch}; pub async fn handle( state: Arc<Mutex<State>>, @@ -17,12 +17,14 @@ pub async fn handle( )>, tcp_event_register_sender: mpsc::UnboundedSender<(TcpEvent, TcpEventCallback)>, ping_request_sender: mpsc::UnboundedSender<(u64, SocketAddr, Box<dyn FnOnce(PongPacket)>)>, + mut packet_sender: mpsc::UnboundedSender<ControlPacket<Serverbound>>, + mut connection_info_sender: watch::Sender<Option<ConnectionInfo>>, ) { debug!("Begin listening for commands"); while let Some((command, response_sender)) = command_receiver.recv().await { debug!("Received command {:?}", command); let mut state = state.lock().unwrap(); - let event = state.handle_command(command); + let event = state.handle_command(command, &mut packet_sender, &mut connection_info_sender); drop(state); match event { ExecutionContext::TcpEvent(event, generator) => { |
