aboutsummaryrefslogtreecommitdiffstats
path: root/mumd/src/state/server.rs
diff options
context:
space:
mode:
authorEskil Queseth <eskilq@kth.se>2021-05-19 00:19:40 +0200
committerEskil Queseth <eskilq@kth.se>2021-05-19 00:19:40 +0200
commit6fa328db646a0e1c33b883d387ad95ec971cf2e0 (patch)
tree5eaba435c58cacfbe36bcb97806a76cc8578a23a /mumd/src/state/server.rs
parent6a03656f963bb59c6a6a56e3933f05f9da850ca8 (diff)
downloadmum-6fa328db646a0e1c33b883d387ad95ec971cf2e0.tar.gz
refactor getting of channel data from name
Diffstat (limited to 'mumd/src/state/server.rs')
-rw-r--r--mumd/src/state/server.rs39
1 files changed, 39 insertions, 0 deletions
diff --git a/mumd/src/state/server.rs b/mumd/src/state/server.rs
index c9f8a69..e44d1e8 100644
--- a/mumd/src/state/server.rs
+++ b/mumd/src/state/server.rs
@@ -3,6 +3,7 @@ use crate::state::user::User;
use log::*;
use mumble_protocol::control::msgs;
+use mumlib::error::ChannelIdentifierError;
use serde::{Deserialize, Serialize};
use std::collections::hash_map::Entry;
use std::collections::HashMap;
@@ -88,6 +89,44 @@ impl Server {
&self.channels
}
+ /// Takes a channel name and returns either a tuple with the channel id and a reference to the
+ /// channel struct if the channel name unambiguosly refers to a channel, or an error describing
+ /// if the channel identifier was ambigous or invalid.
+ /*/// note that doctests currently aren't run in binary crates yet (see #50784)
+ /// ```
+ /// use crate::state::channel::Channel;
+ /// let mut server = Server::new();
+ /// let channel = Channel {
+ /// name: "Foobar".to_owned(),
+ /// ..Default::default(),
+ /// };
+ /// server.channels.insert(0, channel.clone);
+ /// assert_eq!(server.channel_name("Foobar"), Ok((0, &channel)));
+ /// ```*/
+ pub fn channel_name(&self, channel_name: &str) -> Result<(u32, &Channel), ChannelIdentifierError> {
+ let matches = self.channels
+ .iter()
+ .map(|e| ((*e.0, e.1), e.1.path(&self.channels)))
+ .filter(|e| e.1.ends_with(channel_name))
+ .collect::<Vec<_>>();
+ Ok(match matches.len() {
+ 0 => {
+ let soft_matches = self.channels
+ .iter()
+ .map(|e| ((*e.0, e.1), e.1.path(&self.channels).to_lowercase()))
+ .filter(|e| e.1.ends_with(&channel_name.to_lowercase()))
+ .collect::<Vec<_>>();
+ match soft_matches.len() {
+ 0 => return Err(ChannelIdentifierError::Invalid),
+ 1 => soft_matches.get(0).unwrap().0,
+ _ => return Err(ChannelIdentifierError::Ambiguous),
+ }
+ }
+ 1 => matches.get(0).unwrap().0,
+ _ => return Err(ChannelIdentifierError::Ambiguous),
+ })
+ }
+
pub fn host_mut(&mut self) -> &mut Option<String> {
&mut self.host
}