mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-07-13 02:52:49 +00:00
Export all conversations
This commit is contained in:
src
@ -1,9 +1,12 @@
|
||||
//! # Export account API entry
|
||||
//!
|
||||
//! @author Pierre Hubert
|
||||
use std::collections::HashMap;
|
||||
|
||||
use serde::Serialize;
|
||||
|
||||
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::movie_api::MovieAPI;
|
||||
use crate::api_data::post_api::PostAPI;
|
||||
@ -24,6 +27,8 @@ pub struct AccountExportAPI {
|
||||
survey_responses: Vec<SurveyResponseAPI>,
|
||||
movies: Vec<MovieAPI>,
|
||||
all_conversation_messages: Vec<ConversationMessageAPI>,
|
||||
conversations_list: Vec<ConversationAPI>,
|
||||
conversations_messages: HashMap<u64, Vec<ConversationMessageAPI>>,
|
||||
}
|
||||
|
||||
impl AccountExportAPI {
|
||||
@ -38,6 +43,11 @@ impl AccountExportAPI {
|
||||
survey_responses: SurveyResponseAPI::for_list(&export.survey_responses),
|
||||
movies: MovieAPI::for_list(&export.movies),
|
||||
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)
|
||||
|
@ -2,6 +2,7 @@
|
||||
//!
|
||||
//! @author Pierre Hubert
|
||||
use serde::{Serialize, Serializer};
|
||||
|
||||
use crate::api_data::legacy_api_bool::LegacyBool;
|
||||
use crate::data::conversation::Conversation;
|
||||
|
||||
@ -35,7 +36,6 @@ pub struct ConversationAPI {
|
||||
}
|
||||
|
||||
impl ConversationAPI {
|
||||
|
||||
/// Construct a new Conversation instance
|
||||
pub fn new(conv: &Conversation) -> ConversationAPI {
|
||||
ConversationAPI {
|
||||
@ -51,7 +51,11 @@ impl ConversationAPI {
|
||||
// TODO : update when call system is implemented
|
||||
can_have_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()
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user