From b1648f896702b6d45fa1099eaf26ac51c5dc053f Mon Sep 17 00:00:00 2001 From: Jokler Date: Sun, 15 Dec 2019 02:16:36 +0100 Subject: Quote: Add search subcommand --- src/plugins/quote/database.rs | 125 +++++++++++++++++++++++++++++++++++++----- 1 file changed, 112 insertions(+), 13 deletions(-) (limited to 'src/plugins/quote/database.rs') diff --git a/src/plugins/quote/database.rs b/src/plugins/quote/database.rs index 3c904df..9e6bb66 100644 --- a/src/plugins/quote/database.rs +++ b/src/plugins/quote/database.rs @@ -45,6 +45,20 @@ pub trait Database: Send + Sync { fn get_channel_quote(&self, channel: &str, idx: i32) -> Result; fn count_user_quotes(&self, quotee: &str, channel: &str) -> Result; fn count_channel_quotes(&self, channel: &str) -> Result; + fn search_user_quote( + &self, + query: &str, + quotee: &str, + channel: &str, + offset: i32, + ) -> Result; + + fn search_channel_quote( + &self, + query: &str, + channel: &str, + offset: i32, + ) -> Result; } // HashMap @@ -70,34 +84,79 @@ impl Database } fn get_user_quote(&self, quotee: &str, channel: &str, idx: i32) -> Result { - Ok(self + let quote = self .get(&(quotee.to_owned(), channel.to_owned(), idx)) .cloned() - .ok_or(ErrorKind::NotFound)?) + .ok_or(ErrorKind::NotFound)?; + + Ok(quote) } fn get_channel_quote(&self, channel: &str, idx: i32) -> Result { - Ok(self + let quote = self .iter() .filter(|&(&(_, ref c, _), _)| c == channel) .nth(idx as usize - 1) .ok_or(ErrorKind::NotFound)? .1 - .clone()) + .clone(); + + Ok(quote) } fn count_user_quotes(&self, quotee: &str, channel: &str) -> Result { - Ok(self + let count = self .iter() - .filter(|&(&(ref n, ref c, _), _)| n == quotee && c == channel) - .count() as i32) + .filter(|&(&(ref q, ref c, _), _)| q == quotee && c == channel) + .count(); + + Ok(count as i32) } fn count_channel_quotes(&self, channel: &str) -> Result { - Ok(self + let count = self .iter() .filter(|&(&(_, ref c, _), _)| c == channel) - .count() as i32) + .count(); + + Ok(count as i32) + } + + fn search_user_quote( + &self, + query: &str, + quotee: &str, + channel: &str, + offset: i32, + ) -> Result { + let quote = self + .iter() + .filter(|&(&(ref q, ref c, _), _)| q == quotee && c == channel) + .filter(|&(&(_, _, _), q)| q.content.to_lowercase().contains(&query.to_lowercase())) + .nth(offset as usize) + .ok_or(ErrorKind::NotFound)? + .1 + .clone(); + + Ok(quote) + } + + fn search_channel_quote( + &self, + query: &str, + channel: &str, + offset: i32, + ) -> Result { + let quote = self + .iter() + .filter(|&(&(_, ref c, _), _)| c == channel) + .filter(|&(&(_, _, _), q)| q.content.contains(query)) + .nth(offset as usize) + .ok_or(ErrorKind::NotFound)? + .1 + .clone(); + + Ok(quote) } } @@ -134,19 +193,23 @@ impl Database for Arc>> { fn get_user_quote(&self, quotee: &str, channel: &str, idx: i32) -> Result { let conn = &*self.get().context(ErrorKind::NoConnection)?; - Ok(quotes::table + let quote = quotes::table .find((quotee, channel, idx)) .first(conn) - .context(ErrorKind::MysqlError)?) + .context(ErrorKind::MysqlError)?; + + Ok(quote) } fn get_channel_quote(&self, channel: &str, idx: i32) -> Result { let conn = &*self.get().context(ErrorKind::NoConnection)?; - Ok(quotes::table + let quote = quotes::table .filter(quotes::columns::channel.eq(channel)) .offset(idx as i64 - 1) .first(conn) - .context(ErrorKind::MysqlError)?) + .context(ErrorKind::MysqlError)?; + + Ok(quote) } fn count_user_quotes(&self, quotee: &str, channel: &str) -> Result { @@ -177,4 +240,40 @@ impl Database for Arc>> { Err(e) => Err(e).context(ErrorKind::MysqlError)?, } } + + fn search_user_quote( + &self, + query: &str, + quotee: &str, + channel: &str, + offset: i32, + ) -> Result { + let conn = &*self.get().context(ErrorKind::NoConnection)?; + let quote = quotes::table + .filter(quotes::columns::channel.eq(channel)) + .filter(quotes::columns::quotee.eq(quotee)) + .filter(quotes::columns::content.like(&format!("%{}%", query))) + .offset(offset as i64) + .first(conn) + .context(ErrorKind::MysqlError)?; + + Ok(quote) + } + + fn search_channel_quote( + &self, + query: &str, + channel: &str, + offset: i32, + ) -> Result { + let conn = &*self.get().context(ErrorKind::NoConnection)?; + let quote = quotes::table + .filter(quotes::columns::channel.eq(channel)) + .filter(quotes::columns::content.like(&format!("%{}%", query))) + .offset(offset as i64) + .first(conn) + .context(ErrorKind::MysqlError)?; + + Ok(quote) + } } -- cgit v1.2.3-70-g09d2