mirror of
				https://gitlab.com/comunic/comunicapiv3
				synced 2025-11-04 01:24:04 +00:00 
			
		
		
		
	Export all conversations
This commit is contained in:
		@@ -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)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -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>>,
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -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)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user