summaryrefslogtreecommitdiff
path: root/src/database/posts.rs
diff options
context:
space:
mode:
authorTyler Murphy <tylermurphy534@gmail.com>2023-02-15 00:01:44 -0500
committerTyler Murphy <tylermurphy534@gmail.com>2023-02-15 00:01:44 -0500
commitaec4fdecc10be35cde5dc42308960f10bc452187 (patch)
tree67233229c6839c78d1bd3db0147467da30843f44 /src/database/posts.rs
parentbug fixes (diff)
downloadxssbook-aec4fdecc10be35cde5dc42308960f10bc452187.tar.gz
xssbook-aec4fdecc10be35cde5dc42308960f10bc452187.tar.bz2
xssbook-aec4fdecc10be35cde5dc42308960f10bc452187.zip
make database calls 1 conn
Diffstat (limited to 'src/database/posts.rs')
-rw-r--r--src/database/posts.rs205
1 files changed, 106 insertions, 99 deletions
diff --git a/src/database/posts.rs b/src/database/posts.rs
index c33e7e7..fa0fd3c 100644
--- a/src/database/posts.rs
+++ b/src/database/posts.rs
@@ -3,115 +3,122 @@ use std::time::{Duration, SystemTime, UNIX_EPOCH};
use rusqlite::{OptionalExtension, Row};
use tracing::instrument;
-use crate::database;
use crate::types::post::Post;
-use super::{comments, likes};
+use super::Database;
-pub fn init() -> Result<(), rusqlite::Error> {
- let sql = "
- CREATE TABLE IF NOT EXISTS posts (
- post_id INTEGER PRIMARY KEY AUTOINCREMENT,
- user_id INTEGER NOT NULL,
- content VARCHAR(500) NOT NULL,
- date INTEGER NOT NULL,
- FOREIGN KEY(user_id) REFERENCES users(user_id)
- );
- ";
- let conn = database::connect()?;
- conn.execute(sql, ())?;
- Ok(())
-}
-
-fn post_from_row(row: &Row) -> Result<Post, rusqlite::Error> {
- let post_id = row.get(0)?;
- let user_id = row.get(1)?;
- let content = row.get(2)?;
- let date = row.get(3)?;
+impl Database {
+ pub fn init_posts(&self) -> Result<(), rusqlite::Error> {
+ let sql = "
+ CREATE TABLE IF NOT EXISTS posts (
+ post_id INTEGER PRIMARY KEY AUTOINCREMENT,
+ user_id INTEGER NOT NULL,
+ content VARCHAR(500) NOT NULL,
+ date INTEGER NOT NULL,
+ FOREIGN KEY(user_id) REFERENCES users(user_id)
+ );
+ ";
+ self.0.execute(sql, ())?;
+ Ok(())
+ }
- let comments = comments::get_comments_page(0, post_id).unwrap_or_else(|_| Vec::new());
- let likes = likes::get_like_count(post_id).unwrap_or(None).unwrap_or(0);
+ fn post_from_row(&self, row: &Row) -> Result<Post, rusqlite::Error> {
+ let post_id = row.get(0)?;
+ let user_id = row.get(1)?;
+ let content = row.get(2)?;
+ let date = row.get(3)?;
- Ok(Post {
- post_id,
- user_id,
- content,
- date,
- likes,
- liked: false,
- comments,
- })
-}
+ let comments = self
+ .get_comments_page(0, post_id)
+ .unwrap_or_else(|_| Vec::new());
+ let likes = self.get_like_count(post_id).unwrap_or(None).unwrap_or(0);
-#[instrument()]
-pub fn get_post(post_id: u64) -> Result<Option<Post>, rusqlite::Error> {
- tracing::trace!("Retrieving post");
- let conn = database::connect()?;
- let mut stmt = conn.prepare("SELECT * FROM posts WHERE post_id = ?")?;
- let row = stmt
- .query_row([post_id], |row| {
- let row = post_from_row(row)?;
- Ok(row)
+ Ok(Post {
+ post_id,
+ user_id,
+ content,
+ date,
+ likes,
+ liked: false,
+ comments,
})
- .optional()?;
- Ok(row)
-}
+ }
-#[instrument()]
-pub fn get_post_page(page: u64) -> Result<Vec<Post>, rusqlite::Error> {
- tracing::trace!("Retrieving posts page");
- let page_size = 10;
- let conn = database::connect()?;
- let mut stmt = conn.prepare("SELECT * FROM posts ORDER BY post_id DESC LIMIT ? OFFSET ?")?;
- let row = stmt.query_map([page_size, page_size * page], |row| {
- let row = post_from_row(row)?;
+ #[instrument(skip(self))]
+ pub fn get_post(&self, post_id: u64) -> Result<Option<Post>, rusqlite::Error> {
+ tracing::trace!("Retrieving post");
+ let mut stmt = self.0.prepare("SELECT * FROM posts WHERE post_id = ?")?;
+ let row = stmt
+ .query_row([post_id], |row| {
+ let row = self.post_from_row(row)?;
+ Ok(row)
+ })
+ .optional()?;
Ok(row)
- })?;
- Ok(row.into_iter().flatten().collect())
-}
+ }
-#[instrument()]
-pub fn get_all_posts() -> Result<Vec<Post>, rusqlite::Error> {
- tracing::trace!("Retrieving posts page");
- let conn = database::connect()?;
- let mut stmt = conn.prepare("SELECT * FROM posts ORDER BY post_id DESC")?;
- let row = stmt.query_map([], |row| {
- let row = post_from_row(row)?;
- Ok(row)
- })?;
- Ok(row.into_iter().flatten().collect())
-}
+ #[instrument(skip(self))]
+ pub fn get_post_page(&self, page: u64) -> Result<Vec<Post>, rusqlite::Error> {
+ tracing::trace!("Retrieving posts page");
+ let page_size = 10;
+ let mut stmt = self
+ .0
+ .prepare("SELECT * FROM posts ORDER BY post_id DESC LIMIT ? OFFSET ?")?;
+ let row = stmt.query_map([page_size, page_size * page], |row| {
+ let row = self.post_from_row(row)?;
+ Ok(row)
+ })?;
+ Ok(row.into_iter().flatten().collect())
+ }
-#[instrument()]
-pub fn get_users_post_page(user_id: u64, page: u64) -> Result<Vec<Post>, rusqlite::Error> {
- tracing::trace!("Retrieving users posts");
- let page_size = 10;
- let conn = database::connect()?;
- let mut stmt = conn
- .prepare("SELECT * FROM posts WHERE user_id = ? ORDER BY post_id DESC LIMIT ? OFFSET ?")?;
- let row = stmt.query_map([user_id, page_size, page_size * page], |row| {
- let row = post_from_row(row)?;
- Ok(row)
- })?;
- Ok(row.into_iter().flatten().collect())
-}
+ #[instrument(skip(self))]
+ pub fn get_all_posts(&self) -> Result<Vec<Post>, rusqlite::Error> {
+ tracing::trace!("Retrieving posts page");
+ let mut stmt = self
+ .0
+ .prepare("SELECT * FROM posts ORDER BY post_id DESC")?;
+ let row = stmt.query_map([], |row| {
+ let row = self.post_from_row(row)?;
+ Ok(row)
+ })?;
+ Ok(row.into_iter().flatten().collect())
+ }
-#[instrument()]
-pub fn add_post(user_id: u64, content: &str) -> Result<Post, rusqlite::Error> {
- tracing::trace!("Adding post");
- let date = u64::try_from(
- SystemTime::now()
- .duration_since(UNIX_EPOCH)
- .unwrap_or(Duration::ZERO)
- .as_millis(),
- )
- .unwrap_or(0);
- let conn = database::connect()?;
- let mut stmt =
- conn.prepare("INSERT INTO posts (user_id, content, date) VALUES(?,?,?) RETURNING *;")?;
- let post = stmt.query_row((user_id, content, date), |row| {
- let row = post_from_row(row)?;
- Ok(row)
- })?;
- Ok(post)
+ #[instrument(skip(self))]
+ pub fn get_users_post_page(
+ &self,
+ user_id: u64,
+ page: u64,
+ ) -> Result<Vec<Post>, rusqlite::Error> {
+ tracing::trace!("Retrieving users posts");
+ let page_size = 10;
+ let mut stmt = self.0.prepare(
+ "SELECT * FROM posts WHERE user_id = ? ORDER BY post_id DESC LIMIT ? OFFSET ?",
+ )?;
+ let row = stmt.query_map([user_id, page_size, page_size * page], |row| {
+ let row = self.post_from_row(row)?;
+ Ok(row)
+ })?;
+ Ok(row.into_iter().flatten().collect())
+ }
+
+ #[instrument(skip(self))]
+ pub fn add_post(&self, user_id: u64, content: &str) -> Result<Post, rusqlite::Error> {
+ tracing::trace!("Adding post");
+ let date = u64::try_from(
+ SystemTime::now()
+ .duration_since(UNIX_EPOCH)
+ .unwrap_or(Duration::ZERO)
+ .as_millis(),
+ )
+ .unwrap_or(0);
+ let mut stmt = self
+ .0
+ .prepare("INSERT INTO posts (user_id, content, date) VALUES(?,?,?) RETURNING *;")?;
+ let post = stmt.query_row((user_id, content, date), |row| {
+ let row = self.post_from_row(row)?;
+ Ok(row)
+ })?;
+ Ok(post)
+ }
}