This trait is a generic type that allows us to get an Option from any type and from another option. It can be used to remove the ugly "do_something", "do_something_optional" that we previously had.
let communities = CommunityQueryBuilder::create(&conn)
.sort(&sort)
- .from_user_id_optional(user_id)
+ .from_user_id(user_id)
.show_nsfw(show_nsfw)
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
// Return the jwt
let comments = CommentQueryBuilder::create(&conn)
.for_post_id(data.id)
- .my_user_id_optional(user_id)
+ .my_user_id(user_id)
.limit(9999)
.list()?;
.listing_type(type_)
.sort(&sort)
.show_nsfw(show_nsfw)
- .for_community_id_optional(data.community_id)
- .my_user_id_optional(user_id)
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .for_community_id(data.community_id)
+ .my_user_id(user_id)
+ .page(data.page)
+ .limit(data.limit)
.list()
{
Ok(posts) => posts,
posts = PostQueryBuilder::create(&conn)
.sort(&sort)
.show_nsfw(true)
- .for_community_id_optional(data.community_id)
+ .for_community_id(data.community_id)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
}
SearchType::Comments => {
comments = CommentQueryBuilder::create(&conn)
.sort(&sort)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
}
SearchType::Communities => {
communities = CommunityQueryBuilder::create(&conn)
.sort(&sort)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
}
SearchType::Users => {
users = UserQueryBuilder::create(&conn)
.sort(&sort)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
}
SearchType::All => {
posts = PostQueryBuilder::create(&conn)
.sort(&sort)
.show_nsfw(true)
- .for_community_id_optional(data.community_id)
+ .for_community_id(data.community_id)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
comments = CommentQueryBuilder::create(&conn)
.sort(&sort)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
communities = CommunityQueryBuilder::create(&conn)
.sort(&sort)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
users = UserQueryBuilder::create(&conn)
.sort(&sort)
.search_term(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
}
SearchType::Url => {
posts = PostQueryBuilder::create(&conn)
.sort(&sort)
.show_nsfw(true)
- .for_community_id_optional(data.community_id)
+ .for_community_id(data.community_id)
.url_search(data.q.to_owned())
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
}
};
.sort(&sort)
.show_nsfw(show_nsfw)
.saved_only(data.saved_only)
- .for_community_id_optional(data.community_id)
- .my_user_id_optional(user_id)
- .page_optional(data.page)
- .limit_optional(data.limit);
+ .for_community_id(data.community_id)
+ .my_user_id(user_id)
+ .page(data.page)
+ .limit(data.limit);
let mut comments_query = CommentQueryBuilder::create(&conn)
.sort(&sort)
.saved_only(data.saved_only)
- .my_user_id_optional(user_id)
- .page_optional(data.page)
- .limit_optional(data.limit);
+ .my_user_id(user_id)
+ .page(data.page)
+ .limit(data.limit);
// If its saved only, you don't care what creator it was
// Or, if its not saved, then you only want it for that specific creator
let replies = ReplyQueryBuilder::create(&conn, user_id)
.sort(&sort)
.unread_only(data.unread_only)
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
Ok(GetRepliesResponse {
let mentions = UserMentionQueryBuilder::create(&conn, user_id)
.sort(&sort)
.unread_only(data.unread_only)
- .page_optional(data.page)
- .limit_optional(data.limit)
+ .page(data.page)
+ .limit(data.limit)
.list()?;
Ok(GetUserMentionsResponse {
self
}
- pub fn for_post_id(mut self, for_post_id: i32) -> Self {
- self.for_post_id = Some(for_post_id);
+ pub fn for_post_id<T: MaybeOptional<i32>>(mut self, for_post_id: T) -> Self {
+ self.for_post_id = for_post_id.get_optional();
self
}
- pub fn for_post_id_optional(mut self, for_post_id: Option<i32>) -> Self {
- self.for_post_id = for_post_id;
+ pub fn for_creator_id<T: MaybeOptional<i32>>(mut self, for_creator_id: T) -> Self {
+ self.for_creator_id = for_creator_id.get_optional();
self
}
- pub fn for_creator_id(mut self, for_creator_id: i32) -> Self {
- self.for_creator_id = Some(for_creator_id);
+ pub fn search_term<T: MaybeOptional<String>>(mut self, search_term: T) -> Self {
+ self.search_term = search_term.get_optional();
self
}
- pub fn for_creator_id_optional(mut self, for_creator_id: Option<i32>) -> Self {
- self.for_creator_id = for_creator_id;
- self
- }
-
- pub fn search_term(mut self, search_term: String) -> Self {
- self.search_term = Some(search_term);
- self
- }
-
- pub fn search_term_optional(mut self, search_term: Option<String>) -> Self {
- self.search_term = search_term;
- self
- }
-
- pub fn my_user_id(mut self, my_user_id: i32) -> Self {
- self.my_user_id = Some(my_user_id);
- self
- }
-
- pub fn my_user_id_optional(mut self, my_user_id: Option<i32>) -> Self {
- self.my_user_id = my_user_id;
+ pub fn my_user_id<T: MaybeOptional<i32>>(mut self, my_user_id: T) -> Self {
+ self.my_user_id = my_user_id.get_optional();
self
}
self
}
- pub fn page(mut self, page: i64) -> Self {
- self.page = Some(page);
+ pub fn page<T: MaybeOptional<i64>>(mut self, page: T) -> Self {
+ self.page = page.get_optional();
self
}
- pub fn page_optional(mut self, page: Option<i64>) -> Self {
- self.page = page;
- self
- }
-
- pub fn limit(mut self, limit: i64) -> Self {
- self.limit = Some(limit);
- self
- }
-
- pub fn limit_optional(mut self, limit: Option<i64>) -> Self {
- self.limit = limit;
+ pub fn limit<T: MaybeOptional<i64>>(mut self, limit: T) -> Self {
+ self.limit = limit.get_optional();
self
}
self
}
- pub fn page(mut self, page: i64) -> Self {
- self.page = Some(page);
- self
- }
-
- pub fn page_optional(mut self, page: Option<i64>) -> Self {
- self.page = page;
- self
- }
-
- pub fn limit(mut self, limit: i64) -> Self {
- self.limit = Some(limit);
+ pub fn page<T: MaybeOptional<i64>>(mut self, page: T) -> Self {
+ self.page = page.get_optional();
self
}
- pub fn limit_optional(mut self, limit: Option<i64>) -> Self {
- self.limit = limit;
+ pub fn limit<T: MaybeOptional<i64>>(mut self, limit: T) -> Self {
+ self.limit = limit.get_optional();
self
}
self
}
- pub fn from_user_id(mut self, from_user_id: i32) -> Self {
- self.from_user_id = Some(from_user_id);
+ pub fn from_user_id<T: MaybeOptional<i32>>(mut self, from_user_id: T) -> Self {
+ self.from_user_id = from_user_id.get_optional();
self
}
- pub fn from_user_id_optional(self, from_user_id: Option<i32>) -> Self {
- match from_user_id {
- Some(from_user_id) => self.from_user_id(from_user_id),
- None => self,
- }
- }
-
pub fn show_nsfw(mut self, show_nsfw: bool) -> Self {
self.show_nsfw = show_nsfw;
self
}
- pub fn search_term(mut self, search_term: String) -> Self {
- self.search_term = Some(search_term);
- self
- }
-
- pub fn search_term_optional(mut self, search_term: Option<String>) -> Self {
- self.search_term = search_term;
- self
- }
-
- pub fn page(mut self, page: i64) -> Self {
- self.page = Some(page);
- self
- }
-
- pub fn page_optional(mut self, page: Option<i64>) -> Self {
- self.page = page;
+ pub fn search_term<T: MaybeOptional<String>>(mut self, search_term: T) -> Self {
+ self.search_term = search_term.get_optional();
self
}
- pub fn limit(mut self, limit: i64) -> Self {
- self.limit = Some(limit);
+ pub fn page<T: MaybeOptional<i64>>(mut self, page: T) -> Self {
+ self.page = page.get_optional();
self
}
- pub fn limit_optional(mut self, limit: Option<i64>) -> Self {
- self.limit = limit;
+ pub fn limit<T: MaybeOptional<i64>>(mut self, limit: T) -> Self {
+ self.limit = limit.get_optional();
self
}
Self: Sized;
}
+pub trait MaybeOptional<T> {
+ fn get_optional(self) -> Option<T>;
+}
+
+impl<T> MaybeOptional<T> for T {
+ fn get_optional(self) -> Option<T> {
+ return Some(self);
+ }
+}
+
+impl<T> MaybeOptional<T> for Option<T> {
+ fn get_optional(self) -> Option<T> {
+ return self;
+ }
+}
+
pub fn establish_connection() -> PgConnection {
let db_url = Settings::get().db_url;
PgConnection::establish(&db_url).expect(&format!("Error connecting to {}", db_url))
self
}
- pub fn for_community_id(mut self, for_community_id: i32) -> Self {
+ pub fn for_community_id<T: MaybeOptional<i32>>(mut self, for_community_id: T) -> Self {
use super::post_view::post_view::dsl::*;
- self.query = self.query.filter(community_id.eq(for_community_id));
- self.query = self.query.then_order_by(stickied.desc());
- self
- }
-
- pub fn for_community_id_optional(self, for_community_id: Option<i32>) -> Self {
- match for_community_id {
- Some(for_community_id) => self.for_community_id(for_community_id),
- None => self,
+ if let Some(for_community_id) = for_community_id.get_optional() {
+ self.query = self.query.filter(community_id.eq(for_community_id));
+ self.query = self.query.then_order_by(stickied.desc());
}
- }
-
- pub fn for_creator_id(mut self, for_creator_id: i32) -> Self {
- self.for_creator_id = Some(for_creator_id);
self
}
- pub fn for_creator_id_optional(self, for_creator_id: Option<i32>) -> Self {
- match for_creator_id {
- Some(for_creator_id) => self.for_creator_id(for_creator_id),
- None => self,
+ pub fn for_creator_id<T: MaybeOptional<i32>>(mut self, for_creator_id: T) -> Self {
+ if let Some(for_creator_id) = for_creator_id.get_optional() {
+ self.for_creator_id = Some(for_creator_id);
}
- }
-
- pub fn search_term(mut self, search_term: String) -> Self {
- use super::post_view::post_view::dsl::*;
- self.query = self.query.filter(name.ilike(fuzzy_search(&search_term)));
self
}
- pub fn search_term_optional(self, search_term: Option<String>) -> Self {
- match search_term {
- Some(search_term) => self.search_term(search_term),
- None => self,
- }
- }
-
- pub fn url_search(mut self, url_search: String) -> Self {
+ pub fn search_term<T: MaybeOptional<String>>(mut self, search_term: T) -> Self {
use super::post_view::post_view::dsl::*;
- self.query = self.query.filter(url.eq(url_search));
+ if let Some(search_term) = search_term.get_optional() {
+ self.query = self.query.filter(name.ilike(fuzzy_search(&search_term)));
+ }
self
}
- pub fn url_search_optional(self, url_search: Option<String>) -> Self {
- match url_search {
- Some(url_search) => self.url_search(url_search),
- None => self,
+ pub fn url_search<T: MaybeOptional<String>>(mut self, url_search: T) -> Self {
+ use super::post_view::post_view::dsl::*;
+ if let Some(url_search) = url_search.get_optional() {
+ self.query = self.query.filter(url.eq(url_search));
}
- }
-
- pub fn my_user_id(mut self, my_user_id: i32) -> Self {
- self.my_user_id = Some(my_user_id);
self
}
- pub fn my_user_id_optional(mut self, my_user_id: Option<i32>) -> Self {
- self.my_user_id = my_user_id;
+ pub fn my_user_id<T: MaybeOptional<i32>>(mut self, my_user_id: T) -> Self {
+ self.my_user_id = my_user_id.get_optional();
self
}
self
}
- pub fn page(mut self, page: i64) -> Self {
- self.page = Some(page);
- self
- }
-
- pub fn page_optional(mut self, page: Option<i64>) -> Self {
- self.page = page;
- self
- }
-
- pub fn limit(mut self, limit: i64) -> Self {
- self.limit = Some(limit);
+ pub fn page<T: MaybeOptional<i64>>(mut self, page: T) -> Self {
+ self.page = page.get_optional();
self
}
- pub fn limit_optional(mut self, limit: Option<i64>) -> Self {
- self.limit = limit;
+ pub fn limit<T: MaybeOptional<i64>>(mut self, limit: T) -> Self {
+ self.limit = limit.get_optional();
self
}
self
}
- pub fn page(mut self, page: i64) -> Self {
- self.page = Some(page);
+ pub fn page<T: MaybeOptional<i64>>(mut self, page: T) -> Self {
+ self.page = page.get_optional();
self
}
- pub fn page_optional(mut self, page: Option<i64>) -> Self {
- self.page = page;
- self
- }
-
- pub fn limit(mut self, limit: i64) -> Self {
- self.limit = Some(limit);
- self
- }
-
- pub fn limit_optional(mut self, limit: Option<i64>) -> Self {
- self.limit = limit;
+ pub fn limit<T: MaybeOptional<i64>>(mut self, limit: T) -> Self {
+ self.limit = limit.get_optional();
self
}
self
}
- pub fn search_term(mut self, search_term: String) -> Self {
+ pub fn search_term<T: MaybeOptional<String>>(mut self, search_term: T) -> Self {
use super::user_view::user_view::dsl::*;
- self.query = self.query.filter(name.ilike(fuzzy_search(&search_term)));
- self
- }
-
- pub fn search_term_optional(self, search_term: Option<String>) -> Self {
- match search_term {
- Some(search_term) => self.search_term(search_term),
- None => self,
+ if let Some(search_term) = search_term.get_optional() {
+ self.query = self.query.filter(name.ilike(fuzzy_search(&search_term)));
}
- }
-
- pub fn page(mut self, page: i64) -> Self {
- self.page = Some(page);
- self
- }
-
- pub fn page_optional(mut self, page: Option<i64>) -> Self {
- self.page = page;
self
}
- pub fn limit(mut self, limit: i64) -> Self {
- self.limit = Some(limit);
+ pub fn page<T: MaybeOptional<i64>>(mut self, page: T) -> Self {
+ self.page = page.get_optional();
self
}
- pub fn limit_optional(mut self, limit: Option<i64>) -> Self {
- self.limit = limit;
+ pub fn limit<T: MaybeOptional<i64>>(mut self, limit: T) -> Self {
+ self.limit = limit.get_optional();
self
}