diff options
| author | Eskil Queseth <eskilq@kth.se> | 2020-10-17 01:19:45 +0200 |
|---|---|---|
| committer | Eskil Queseth <eskilq@kth.se> | 2020-10-17 01:19:45 +0200 |
| commit | 1974db9d719640f5cd5a8b51fa1b97f801f5a809 (patch) | |
| tree | 47d1b1a92a836ef0f69e45a543b96c11451ab380 /mumd | |
| parent | e2f5c15e17d0ddcde88830194410c387793c045f (diff) | |
| download | mum-1974db9d719640f5cd5a8b51fa1b97f801f5a809.tar.gz | |
change connecting with channel name instead of id
Diffstat (limited to 'mumd')
| -rw-r--r-- | mumd/src/state.rs | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/mumd/src/state.rs b/mumd/src/state.rs index 82d671e..d3f9a8e 100644 --- a/mumd/src/state.rs +++ b/mumd/src/state.rs @@ -53,18 +53,25 @@ impl State { command: Command, ) -> (bool, mumlib::error::Result<Option<CommandResponse>>) { match command { - Command::ChannelJoin { channel_id } => { + Command::ChannelJoin { channel_identifier } => { if !matches!(*self.phase_receiver().borrow(), StatePhase::Connected) { return (false, Err(Error::DisconnectedError)); } - if let Some(server) = &self.server { - if !server.channels().contains_key(&channel_id) { - return (false, Err(Error::InvalidChannelIdError(channel_id))); - } - } + + let channels = self.server() + .unwrap() + .channels(); + let mut idents = channels.iter() + .map(|e| (e.0, e.1.path(channels))); + + let id = match idents.find(|e| e.1.ends_with(&channel_identifier)) { + Some(v) => *v.0, + None => return (false, Err(Error::InvalidChannelIdentifierError(channel_identifier))), + }; + let mut msg = msgs::UserState::new(); msg.set_session(self.session_id.unwrap()); - msg.set_channel_id(channel_id); + msg.set_channel_id(id); self.packet_sender.send(msg.into()).unwrap(); (false, Ok(None)) } @@ -73,7 +80,7 @@ impl State { return (false, Err(Error::DisconnectedError)); } (false, Ok(Some(CommandResponse::ChannelList { - channels: self.server.as_ref().unwrap().channels().clone(), + channels: self.server().unwrap().channels().clone(), })), ) } @@ -188,6 +195,9 @@ impl State { pub fn phase_receiver(&self) -> watch::Receiver<StatePhase> { self.phase_watcher.1.clone() } + pub fn server(&self) -> Option<&Server> { + self.server.as_ref() + } pub fn server_mut(&mut self) -> Option<&mut Server> { self.server.as_mut() } |
