aboutsummaryrefslogtreecommitdiffstats
path: root/mumd
diff options
context:
space:
mode:
authorEskil Queseth <eskilq@kth.se>2020-10-17 01:19:45 +0200
committerEskil Queseth <eskilq@kth.se>2020-10-17 01:19:45 +0200
commit1974db9d719640f5cd5a8b51fa1b97f801f5a809 (patch)
tree47d1b1a92a836ef0f69e45a543b96c11451ab380 /mumd
parente2f5c15e17d0ddcde88830194410c387793c045f (diff)
downloadmum-1974db9d719640f5cd5a8b51fa1b97f801f5a809.tar.gz
change connecting with channel name instead of id
Diffstat (limited to 'mumd')
-rw-r--r--mumd/src/state.rs26
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()
}