1
0
mirror of https://gitlab.com/comunic/comunicapiv3 synced 2024-11-26 23:39:22 +00:00

Export all conversations

This commit is contained in:
Pierre HUBERT 2020-07-14 08:07:55 +02:00
parent 30edf5f1a6
commit df7aecc906
4 changed files with 30 additions and 3 deletions

View File

@ -1,9 +1,12 @@
//! # Export account API entry //! # Export account API entry
//! //!
//! @author Pierre Hubert //! @author Pierre Hubert
use std::collections::HashMap;
use serde::Serialize; use serde::Serialize;
use crate::api_data::comment_api::CommentAPI; use crate::api_data::comment_api::CommentAPI;
use crate::api_data::conversation_api::ConversationAPI;
use crate::api_data::conversation_message_api::ConversationMessageAPI; use crate::api_data::conversation_message_api::ConversationMessageAPI;
use crate::api_data::movie_api::MovieAPI; use crate::api_data::movie_api::MovieAPI;
use crate::api_data::post_api::PostAPI; use crate::api_data::post_api::PostAPI;
@ -24,6 +27,8 @@ pub struct AccountExportAPI {
survey_responses: Vec<SurveyResponseAPI>, survey_responses: Vec<SurveyResponseAPI>,
movies: Vec<MovieAPI>, movies: Vec<MovieAPI>,
all_conversation_messages: Vec<ConversationMessageAPI>, all_conversation_messages: Vec<ConversationMessageAPI>,
conversations_list: Vec<ConversationAPI>,
conversations_messages: HashMap<u64, Vec<ConversationMessageAPI>>,
} }
impl AccountExportAPI { impl AccountExportAPI {
@ -38,6 +43,11 @@ impl AccountExportAPI {
survey_responses: SurveyResponseAPI::for_list(&export.survey_responses), survey_responses: SurveyResponseAPI::for_list(&export.survey_responses),
movies: MovieAPI::for_list(&export.movies), movies: MovieAPI::for_list(&export.movies),
all_conversation_messages: ConversationMessageAPI::for_list(&export.all_conversation_messages), all_conversation_messages: ConversationMessageAPI::for_list(&export.all_conversation_messages),
conversations_list: ConversationAPI::for_list(&export.conversations),
conversations_messages: export.conversation_messages
.iter()
.map(|r| (r.0.clone(), ConversationMessageAPI::for_list(r.1)))
.collect(),
}; };
Ok(export) Ok(export)

View File

@ -2,6 +2,7 @@
//! //!
//! @author Pierre Hubert //! @author Pierre Hubert
use serde::{Serialize, Serializer}; use serde::{Serialize, Serializer};
use crate::api_data::legacy_api_bool::LegacyBool; use crate::api_data::legacy_api_bool::LegacyBool;
use crate::data::conversation::Conversation; use crate::data::conversation::Conversation;
@ -35,7 +36,6 @@ pub struct ConversationAPI {
} }
impl ConversationAPI { impl ConversationAPI {
/// Construct a new Conversation instance /// Construct a new Conversation instance
pub fn new(conv: &Conversation) -> ConversationAPI { pub fn new(conv: &Conversation) -> ConversationAPI {
ConversationAPI { ConversationAPI {
@ -51,7 +51,11 @@ impl ConversationAPI {
// TODO : update when call system is implemented // TODO : update when call system is implemented
can_have_call: false, can_have_call: false,
can_have_video_call: false, can_have_video_call: false,
has_call_now: false has_call_now: false,
} }
} }
pub fn for_list(l: &Vec<Conversation>) -> Vec<Self> {
l.iter().map(Self::new).collect()
}
} }

View File

@ -2,7 +2,10 @@
//! //!
//! @author Pierre Hubert //! @author Pierre Hubert
use std::collections::HashMap;
use crate::data::comment::Comment; use crate::data::comment::Comment;
use crate::data::conversation::Conversation;
use crate::data::conversation_message::ConversationMessage; use crate::data::conversation_message::ConversationMessage;
use crate::data::movie::Movie; use crate::data::movie::Movie;
use crate::data::post::Post; use crate::data::post::Post;
@ -18,4 +21,6 @@ pub struct AccountExport {
pub survey_responses: Vec<SurveyResponse>, pub survey_responses: Vec<SurveyResponse>,
pub movies: Vec<Movie>, pub movies: Vec<Movie>,
pub all_conversation_messages: Vec<ConversationMessage>, pub all_conversation_messages: Vec<ConversationMessage>,
pub conversations: Vec<Conversation>,
pub conversation_messages: HashMap<u64, Vec<ConversationMessage>>,
} }

View File

@ -193,7 +193,7 @@ pub fn update_last_activity(user_id: &UserID) -> ResultBoxError {
/// Export an account's data /// Export an account's data
pub fn export(user_id: &UserID) -> ResultBoxError<AccountExport> { pub fn export(user_id: &UserID) -> ResultBoxError<AccountExport> {
let data = AccountExport { let mut data = AccountExport {
user: user_helper::find_user_by_id(user_id)?, user: user_helper::find_user_by_id(user_id)?,
posts: posts_helper::export_all_posts_user(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)?,
@ -201,9 +201,17 @@ pub fn export(user_id: &UserID) -> ResultBoxError<AccountExport> {
survey_responses: survey_helper::export_all_user_responses(user_id)?, survey_responses: survey_helper::export_all_user_responses(user_id)?,
movies: movies_helper::get_list_user(user_id)?, movies: movies_helper::get_list_user(user_id)?,
all_conversation_messages: conversations_helper::export_all_user_messages(user_id)?, all_conversation_messages: conversations_helper::export_all_user_messages(user_id)?,
conversations: conversations_helper::get_list_user(user_id)?,
conversation_messages: Default::default(),
//TODO : add other fields //TODO : add other fields
}; };
// Process conversation messages
for conv in &data.conversations {
data.conversation_messages
.insert(conv.id, conversations_helper::get_all_messages(conv.id)?);
}
Ok(data) Ok(data)
} }