Skip to content

Commit

Permalink
feat: [torrust#658] new database method to get all user profiles
Browse files Browse the repository at this point in the history
  • Loading branch information
mario-nt committed Dec 14, 2024
1 parent 2de8313 commit 02d233d
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 1 deletion.
3 changes: 3 additions & 0 deletions src/databases/database.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,9 @@ pub trait Database: Sync + Send {
/// Get `UserProfile` from `username`.
async fn get_user_profile_from_username(&self, username: &str) -> Result<UserProfile, Error>;

/// Get all user profiles as `Vec<UserProfile>`.
async fn get_user_profiles(&self) -> Result<Vec<UserProfile>, Error>;

/// Get `UserCompact` from `user_id`.
async fn get_user_compact_from_id(&self, user_id: i64) -> Result<UserCompact, Error>;

Expand Down
9 changes: 8 additions & 1 deletion src/databases/mysql.rs
Original file line number Diff line number Diff line change
Expand Up @@ -148,13 +148,20 @@ impl Database for Mysql {
}

async fn get_user_profile_from_username(&self, username: &str) -> Result<UserProfile, database::Error> {
query_as::<_, UserProfile>(r#"SELECT user_id, username, COALESCE(email, "") as email, email_verified, COALESCE(bio, "") as bio, COALESCE(avatar, "") as avatar FROM torrust_user_profiles WHERE username = ?"#)
query_as::<_, UserProfile>(r#"SELECT user_id, username, COALESCE(email, "") as email FROM torrust_user_profiles"#)
.bind(username)
.fetch_one(&self.pool)
.await
.map_err(|_| database::Error::UserNotFound)
}

async fn get_user_profiles(&self) -> Result<Vec<UserProfile>, database::Error> {
query_as::<_, UserProfile>(r#"SELECT * FROM torrust_user_profiles"#)
.fetch_all(&self.pool)
.await
.map_err(|_| database::Error::Error)
}

async fn get_user_compact_from_id(&self, user_id: i64) -> Result<UserCompact, database::Error> {
query_as::<_, UserCompact>("SELECT tu.user_id, tp.username, tu.administrator FROM torrust_users tu INNER JOIN torrust_user_profiles tp ON tu.user_id = tp.user_id WHERE tu.user_id = ?")
.bind(user_id)
Expand Down
7 changes: 7 additions & 0 deletions src/databases/sqlite.rs
Original file line number Diff line number Diff line change
Expand Up @@ -156,6 +156,13 @@ impl Database for Sqlite {
.map_err(|_| database::Error::UserNotFound)
}

async fn get_user_profiles(&self) -> Result<Vec<UserProfile>, database::Error> {
query_as::<_, UserProfile>("SELECT * FROM torrust_user_profiles")
.fetch_all(&self.pool)
.await
.map_err(|_| database::Error::Error)
}

async fn get_user_compact_from_id(&self, user_id: i64) -> Result<UserCompact, database::Error> {
query_as::<_, UserCompact>("SELECT tu.user_id, tp.username, tu.administrator FROM torrust_users tu INNER JOIN torrust_user_profiles tp ON tu.user_id = tp.user_id WHERE tu.user_id = ?")
.bind(user_id)
Expand Down

0 comments on commit 02d233d

Please sign in to comment.