1
0
mirror of https://gitlab.com/comunic/comunicapiv3 synced 2024-12-28 14:38:52 +00:00

Can get advanced information about a group

This commit is contained in:
Pierre HUBERT 2020-06-25 13:39:37 +02:00
parent 63c792d497
commit e82f2f7c59
5 changed files with 55 additions and 1 deletions

View File

@ -0,0 +1,37 @@
//! # Advanced group information
//!
//! @author Pierre Hubert
use serde::Serialize;
use crate::api_data::group_api::GroupApi;
use crate::data::error::ResultBoxError;
use crate::data::group::Group;
use crate::data::user::UserID;
use crate::helpers::likes_helper;
use crate::helpers::likes_helper::LikeType;
#[derive(Serialize)]
pub struct AdvancedGroupApi {
#[serde(flatten)]
base_info: GroupApi,
time_create: u64,
description: String,
url: String,
number_likes: u64,
is_liking: bool,
}
impl AdvancedGroupApi {
/// Construct a new advanced group membership instance
pub fn new(g: &Group, user_id: Option<UserID>) -> ResultBoxError<AdvancedGroupApi> {
Ok(AdvancedGroupApi {
base_info: GroupApi::new(g, user_id.clone())?,
time_create: g.time_create,
description: g.description.clone().unwrap_or("null".to_string()),
url: g.url.clone().unwrap_or("null".to_string()),
number_likes: likes_helper::count(g.id.id(), LikeType::GROUP)? as u64,
is_liking: likes_helper::is_liking(&user_id.unwrap_or(UserID::invalid()), g.id.id(), LikeType::GROUP)?,
})
}
}

View File

@ -24,4 +24,5 @@ pub mod res_count_unread_conversations;
pub mod list_unread_conversations_api;
pub mod global_search_result_api;
pub mod res_create_group;
pub mod group_api;
pub mod group_api;
pub mod advanced_group_api;

View File

@ -12,6 +12,7 @@ use crate::data::group_id::GroupID;
use crate::data::http_request_handler::HttpRequestHandler;
use crate::data::new_group::NewGroup;
use crate::helpers::groups_helper;
use crate::api_data::advanced_group_api::AdvancedGroupApi;
/// Create a new group
pub fn create(r: &mut HttpRequestHandler) -> RequestResult {
@ -63,4 +64,12 @@ pub fn get_info_multiple(r: &mut HttpRequestHandler) -> RequestResult {
}
r.set_response(list)
}
/// Get advanced information about a user
pub fn get_advanced_info(r: &mut HttpRequestHandler) -> RequestResult {
let group_id = r.post_group_id_with_access("id", GroupAccessLevel::VIEW_ACCESS)?;
let group = groups_helper::get_info(&group_id)?;
r.set_response(AdvancedGroupApi::new(&group, r.user_id_opt())?)
}

View File

@ -136,6 +136,8 @@ pub fn get_routes() -> Vec<Route> {
Route::post("/groups/get_multiple_info", Box::new(groups_controller::get_info_multiple)),
Route::post("/groups/get_advanced_info", Box::new(groups_controller::get_advanced_info)),
// Virtual directory controller
Route::post("/user/findbyfolder", Box::new(virtual_directory_controller::find_user)),

View File

@ -12,6 +12,11 @@ impl UserID {
UserID(id)
}
/// Create a new invalid user id
pub fn invalid() -> UserID {
UserID(0)
}
/// Get the current ID stored in this structure
pub fn id(&self) -> u64 {
self.0