mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-06-21 00:45:18 +00:00
Start to return user information
This commit is contained in:
@ -2,4 +2,5 @@ pub mod routes;
|
||||
pub mod server;
|
||||
|
||||
pub mod server_controller;
|
||||
pub mod account_controller;
|
||||
pub mod account_controller;
|
||||
pub mod user_controller;
|
@ -1,7 +1,7 @@
|
||||
use std::error::Error;
|
||||
|
||||
use crate::controllers::routes::Method::{GET, POST};
|
||||
use crate::controllers::{server_controller, account_controller};
|
||||
use crate::controllers::{server_controller, account_controller, user_controller};
|
||||
use crate::data::http_request_handler::HttpRequestHandler;
|
||||
|
||||
/// Project routes
|
||||
@ -77,5 +77,9 @@ pub fn get_routes() -> Vec<Route> {
|
||||
|
||||
Route::post("/account/id", Box::new(account_controller::user_id)),
|
||||
Route::post("/user/getCurrentUserID", Box::new(account_controller::user_id)),
|
||||
|
||||
// User controller
|
||||
Route::post_without_login("/user/getInfo", Box::new(user_controller::get_single)),
|
||||
Route::post_without_login("/user/getInfos", Box::new(user_controller::get_single)),
|
||||
]
|
||||
}
|
25
src/controllers/user_controller.rs
Normal file
25
src/controllers/user_controller.rs
Normal file
@ -0,0 +1,25 @@
|
||||
//! # User controller
|
||||
//!
|
||||
//! This controller handles all the routes related about getting user information
|
||||
//!
|
||||
//! @author Pierre Hubert
|
||||
|
||||
use crate::controllers::routes::RequestResult;
|
||||
use crate::data::http_request_handler::HttpRequestHandler;
|
||||
use crate::helpers::user_helper;
|
||||
use crate::api_data::user_info::APIUserInfo;
|
||||
|
||||
/// Get information about a single user
|
||||
pub fn get_single(request: &mut HttpRequestHandler) -> RequestResult {
|
||||
let user_id = request.post_i64("userID")?;
|
||||
let user = match user_helper::find_user_by_id(user_id) {
|
||||
Ok(user) => user,
|
||||
Err(e) => {
|
||||
println!("Error while getting user info: {}", e);
|
||||
request.not_found("Could not get user information!".to_string())?;
|
||||
unreachable!();
|
||||
}
|
||||
};
|
||||
|
||||
request.set_response(APIUserInfo::new(user))
|
||||
}
|
Reference in New Issue
Block a user