From aec4fdecc10be35cde5dc42308960f10bc452187 Mon Sep 17 00:00:00 2001 From: Tyler Murphy Date: Wed, 15 Feb 2023 00:01:44 -0500 Subject: make database calls 1 conn --- src/types/post.rs | 43 ++++++++++++++++++++++++------------------- 1 file changed, 24 insertions(+), 19 deletions(-) (limited to 'src/types/post.rs') diff --git a/src/types/post.rs b/src/types/post.rs index 09f2f50..bff68c7 100644 --- a/src/types/post.rs +++ b/src/types/post.rs @@ -2,7 +2,7 @@ use core::fmt; use serde::Serialize; use tracing::instrument; -use crate::database; +use crate::database::Database; use crate::types::http::{ResponseCode, Result}; use super::comment::Comment; @@ -27,57 +27,62 @@ impl fmt::Debug for Post { } impl Post { - #[instrument()] - pub fn from_post_id(self_id: u64, post_id: u64) -> Result { - let Ok(Some(mut post)) = database::posts::get_post(post_id) else { + #[instrument(skip(db))] + pub fn from_post_id(db: &Database, self_id: u64, post_id: u64) -> Result { + let Ok(Some(mut post)) = db.get_post(post_id) else { return Err(ResponseCode::BadRequest.text("Post does not exist")) }; - let liked = database::likes::get_liked(self_id, post.post_id).unwrap_or(false); + let liked = db.get_liked(self_id, post.post_id).unwrap_or(false); post.liked = liked; Ok(post) } - #[instrument()] - pub fn from_post_page(self_id: u64, page: u64) -> Result> { - let Ok(mut posts) = database::posts::get_post_page(page) else { + #[instrument(skip(db))] + pub fn from_post_page(db: &Database, self_id: u64, page: u64) -> Result> { + let Ok(mut posts) = db.get_post_page(page) else { return Err(ResponseCode::BadRequest.text("Failed to fetch posts")) }; for post in &mut posts { - let liked = database::likes::get_liked(self_id, post.post_id).unwrap_or(false); + let liked = db.get_liked(self_id, post.post_id).unwrap_or(false); post.liked = liked; } Ok(posts) } - #[instrument()] - pub fn from_user_post_page(self_id: u64, user_id: u64, page: u64) -> Result> { - let Ok(mut posts) = database::posts::get_users_post_page(user_id, page) else { + #[instrument(skip(db))] + pub fn from_user_post_page( + db: &Database, + self_id: u64, + user_id: u64, + page: u64, + ) -> Result> { + let Ok(mut posts) = db.get_users_post_page(user_id, page) else { return Err(ResponseCode::BadRequest.text("Failed to fetch posts")) }; for post in &mut posts { - let liked = database::likes::get_liked(self_id, post.post_id).unwrap_or(false); + let liked = db.get_liked(self_id, post.post_id).unwrap_or(false); post.liked = liked; } Ok(posts) } - #[instrument()] - pub fn reterieve_all() -> Result> { - let Ok(posts) = database::posts::get_all_posts() else { + #[instrument(skip(db))] + pub fn reterieve_all(db: &Database) -> Result> { + let Ok(posts) = db.get_all_posts() else { return Err(ResponseCode::InternalServerError.text("Failed to fetch posts")) }; Ok(posts) } - #[instrument()] - pub fn new(user_id: u64, content: String) -> Result { - let Ok(post) = database::posts::add_post(user_id, &content) else { + #[instrument(skip(db))] + pub fn new(db: &Database, user_id: u64, content: String) -> Result { + let Ok(post) = db.add_post(user_id, &content) else { tracing::error!("Failed to create post"); return Err(ResponseCode::InternalServerError.text("Failed to create post")) }; -- cgit v1.2.3-freya