mirror of
				https://gitlab.com/comunic/comunicapiv3
				synced 2025-11-04 01:24:04 +00:00 
			
		
		
		
	Can search for virtual directory
This commit is contained in:
		@@ -13,3 +13,4 @@ pub mod current_user_id;
 | 
			
		||||
pub mod user_info;
 | 
			
		||||
pub mod custom_emoji;
 | 
			
		||||
pub mod res_find_user_by_virtual_directory;
 | 
			
		||||
pub mod res_find_virtual_directory;
 | 
			
		||||
							
								
								
									
										29
									
								
								src/api_data/res_find_virtual_directory.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								src/api_data/res_find_virtual_directory.rs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
//! Find virtual directory result
 | 
			
		||||
//!
 | 
			
		||||
//! @author Pierre Hubert
 | 
			
		||||
 | 
			
		||||
use serde::{Serialize};
 | 
			
		||||
use crate::data::error::ResultBoxError;
 | 
			
		||||
use crate::data::user::User;
 | 
			
		||||
 | 
			
		||||
#[derive(Serialize)]
 | 
			
		||||
pub struct ResultFindVirtualDirectory {
 | 
			
		||||
    kind: String,
 | 
			
		||||
    id: u64,
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
impl ResultFindVirtualDirectory {
 | 
			
		||||
    /// Construct a new instance
 | 
			
		||||
    pub fn new(user: ResultBoxError<User>, group: ResultBoxError<u64>) -> ResultFindVirtualDirectory {
 | 
			
		||||
        match (user, group) {
 | 
			
		||||
 | 
			
		||||
            // User
 | 
			
		||||
            (Ok(u), _) => ResultFindVirtualDirectory { kind: "user".to_string(), id: u.id as u64 },
 | 
			
		||||
 | 
			
		||||
            // Group
 | 
			
		||||
            (_, Ok(g)) => ResultFindVirtualDirectory { kind: "group".to_string(), id: g },
 | 
			
		||||
 | 
			
		||||
            _ => unreachable!()
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -23,6 +23,9 @@ pub mod database_tables_names {
 | 
			
		||||
 | 
			
		||||
    /// Likes table
 | 
			
		||||
    pub const LIKES_TABLE: &str = "aime";
 | 
			
		||||
 | 
			
		||||
    /// Groups list table
 | 
			
		||||
    pub const GROUPS_LIST_TABLE: &str = "comunic_groups";
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// The account image to show for user who do not have any
 | 
			
		||||
 
 | 
			
		||||
@@ -4,8 +4,9 @@
 | 
			
		||||
 | 
			
		||||
use crate::data::http_request_handler::HttpRequestHandler;
 | 
			
		||||
use crate::controllers::routes::RequestResult;
 | 
			
		||||
use crate::helpers::user_helper;
 | 
			
		||||
use crate::helpers::{user_helper, groups_helper};
 | 
			
		||||
use crate::api_data::res_find_user_by_virtual_directory::FindUserByVirtualDirectoryAPIResult;
 | 
			
		||||
use crate::api_data::res_find_virtual_directory::ResultFindVirtualDirectory;
 | 
			
		||||
 | 
			
		||||
/// Find a user by its virtual directory
 | 
			
		||||
pub fn find_user(r: &mut HttpRequestHandler) -> RequestResult {
 | 
			
		||||
@@ -21,5 +22,18 @@ pub fn find_user(r: &mut HttpRequestHandler) -> RequestResult {
 | 
			
		||||
 | 
			
		||||
/// Search for user / group with a given virtual directory
 | 
			
		||||
pub fn find(r: &mut HttpRequestHandler) -> RequestResult {
 | 
			
		||||
    r.success("implement me")
 | 
			
		||||
    let directory = r.post_virtual_directory("directory")?;
 | 
			
		||||
 | 
			
		||||
    let user = user_helper::find_user_by_virtual_directory(&directory);
 | 
			
		||||
    let group = groups_helper::find_by_virtual_directory(&directory);
 | 
			
		||||
 | 
			
		||||
    if user.is_err() && group.is_err() {
 | 
			
		||||
        println!("Find virtual directory errors:\n* User: {}\n* Group: {}",
 | 
			
		||||
                 user.unwrap_err(), group.unwrap_err());
 | 
			
		||||
        r.not_found("Specified user / group virtual directory not found !".to_string())
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    else {
 | 
			
		||||
        r.set_response(ResultFindVirtualDirectory::new(user, group))
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										15
									
								
								src/helpers/groups_helper.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/helpers/groups_helper.rs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,15 @@
 | 
			
		||||
//! # Groups helper
 | 
			
		||||
//!
 | 
			
		||||
//! @author Pierre Hubert
 | 
			
		||||
 | 
			
		||||
use crate::data::error::ResultBoxError;
 | 
			
		||||
use crate::helpers::database;
 | 
			
		||||
use crate::constants::database_tables_names::GROUPS_LIST_TABLE;
 | 
			
		||||
 | 
			
		||||
/// Find a group id by virtual directory
 | 
			
		||||
pub fn find_by_virtual_directory(dir: &str) -> ResultBoxError<u64> {
 | 
			
		||||
    database::QueryInfo::new(GROUPS_LIST_TABLE)
 | 
			
		||||
        .cond("virtual_directory", dir)
 | 
			
		||||
        .add_field("id")
 | 
			
		||||
        .query_row(|res| res.get_u64("id"))
 | 
			
		||||
}
 | 
			
		||||
@@ -7,3 +7,4 @@ pub mod friends_helper;
 | 
			
		||||
pub mod custom_emojies_helper;
 | 
			
		||||
pub mod background_image_helper;
 | 
			
		||||
pub mod likes_helper;
 | 
			
		||||
pub mod groups_helper;
 | 
			
		||||
		Reference in New Issue
	
	Block a user