mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-07-14 11:28:03 +00:00
Can search for virtual directory
This commit is contained in:
src
@ -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))
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user