From 997707cfa933bec05faa281236911d893a8a9ba1 Mon Sep 17 00:00:00 2001 From: Jokler Date: Mon, 19 Mar 2018 16:40:18 +0100 Subject: Fix empty receivers getting accepted by Tell --- src/plugins/tell/mod.rs | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/plugins/tell/mod.rs b/src/plugins/tell/mod.rs index b3c2195..a9c5da8 100644 --- a/src/plugins/tell/mod.rs +++ b/src/plugins/tell/mod.rs @@ -50,9 +50,10 @@ impl Tell { let mut online = Vec::new(); - let receivers = command.tokens[0].split(','); + let receivers = command.tokens[0].split(',').filter(|&s| !s.is_empty()); let sender = command.source; + let mut no_receiver = true; for receiver in receivers { if receiver.eq_ignore_ascii_case(client.current_nickname()) || receiver.eq_ignore_ascii_case(&sender) @@ -89,13 +90,19 @@ impl Tell { message: &message, }; + debug!("Saving tell for {:?}", receiver); try_lock!(self.tells).insert_tell(&tell)?; + no_receiver = false; } - Ok(match online.len() { - 0 => format!("Got it!"), - 1 => format!("{} is currently online.", online[0]), - _ => format!("{} are currently online.", online.join(", ")), + Ok(if no_receiver { + format!("Invalid receiver.") + } else { + match online.len() { + 0 => format!("Got it!"), + 1 => format!("{} is currently online.", online[0]), + _ => format!("{} are currently online.", online.join(", ")), + } }) } -- cgit v1.2.3-70-g09d2