1
0
mirror of https://gitlab.com/comunic/comunicapiv3 synced 2025-06-21 17:05:16 +00:00

Add likes to export

This commit is contained in:
2020-07-13 19:26:19 +02:00
parent 67dd29fe2d
commit 70d5facf4c
8 changed files with 76 additions and 4 deletions

View File

@ -5,7 +5,7 @@ use crate::data::error::{ExecError, ResultBoxError};
use crate::data::new_account::NewAccount;
use crate::data::user::UserID;
use crate::data::user_token::UserAccessToken;
use crate::helpers::{database, user_helper, posts_helper, comments_helper};
use crate::helpers::{database, user_helper, posts_helper, comments_helper, likes_helper};
use crate::helpers::database::{DeleteQuery, InsertQuery, QueryInfo};
use crate::utils::crypt_utils::{crypt_pass, rand_str};
use crate::utils::date_utils::{mysql_date, time};
@ -196,7 +196,8 @@ pub fn export(user_id: &UserID) -> ResultBoxError<AccountExport> {
let data = AccountExport {
user: user_helper::find_user_by_id(user_id)?,
posts: posts_helper::export_all_posts_user(user_id)?,
comments: comments_helper::export_all_user(user_id)?
comments: comments_helper::export_all_user(user_id)?,
likes: likes_helper::export_all_user(user_id)?
};
Ok(data)

View File

@ -5,6 +5,7 @@
use crate::constants::database_tables_names::LIKES_TABLE;
use crate::data::error::ResultBoxError;
use crate::data::user::UserID;
use crate::data::user_like::UserLike;
use crate::helpers::database;
use crate::helpers::database::QueryInfo;
use crate::utils::date_utils::mysql_date;
@ -79,4 +80,22 @@ pub fn delete_all(id: u64, kind: LikeType) -> ResultBoxError {
.cond_u64("ID_type", id)
.cond_str("type", &kind.to_db_type())
.exec()
}
/// Export all the likes mention of the user
pub fn export_all_user(user_id: &UserID) -> ResultBoxError<Vec<UserLike>> {
database::QueryInfo::new(LIKES_TABLE)
.cond_user_id("ID_personne", user_id)
.exec(db_to_user_like)
}
/// Turn a database entry into a like entry
fn db_to_user_like(r: &database::RowResult) -> ResultBoxError<UserLike> {
Ok(UserLike {
id: r.get_u64("ID")?,
user_id: r.get_user_id("ID_personne")?,
time_sent: r.get_date_as_time("Date_envoi")?,
elem_type: r.get_str("type")?,
elem_id: r.get_u64("ID_type")?,
})
}