mirror of
				https://gitlab.com/comunic/comunicapiv3
				synced 2025-11-04 09:34:04 +00:00 
			
		
		
		
	Can get security questions
This commit is contained in:
		@@ -44,4 +44,5 @@ pub mod notification_api;
 | 
			
		||||
pub mod user_membership_api;
 | 
			
		||||
mod type_container_api;
 | 
			
		||||
pub mod res_check_email_exists;
 | 
			
		||||
pub mod res_check_security_questions_exists;
 | 
			
		||||
pub mod res_check_security_questions_exists;
 | 
			
		||||
pub mod res_get_security_questions;
 | 
			
		||||
							
								
								
									
										21
									
								
								src/api_data/res_get_security_questions.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/api_data/res_get_security_questions.rs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,21 @@
 | 
			
		||||
//! # Get security questions results
 | 
			
		||||
//!
 | 
			
		||||
//! @author Pierre Hubert
 | 
			
		||||
use serde::Serialize;
 | 
			
		||||
 | 
			
		||||
use crate::data::user::User;
 | 
			
		||||
 | 
			
		||||
#[derive(Serialize)]
 | 
			
		||||
pub struct ResGetSecurityQuestions {
 | 
			
		||||
    questions: Vec<String>
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
impl ResGetSecurityQuestions {
 | 
			
		||||
    pub fn new(user: &User) -> ResGetSecurityQuestions {
 | 
			
		||||
        let mut questions = Vec::new();
 | 
			
		||||
        questions.push(user.security_question_1.clone().unwrap_or(String::new()));
 | 
			
		||||
        questions.push(user.security_question_2.clone().unwrap_or(String::new()));
 | 
			
		||||
 | 
			
		||||
        ResGetSecurityQuestions { questions }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
@@ -2,6 +2,7 @@ use crate::api_data::current_user_id::CurrentUserID;
 | 
			
		||||
use crate::api_data::login_success::LoginSuccess;
 | 
			
		||||
use crate::api_data::res_check_email_exists::ResCheckEmailExists;
 | 
			
		||||
use crate::api_data::res_check_security_questions_exists::ResCheckSecurityQuestionsExists;
 | 
			
		||||
use crate::api_data::res_get_security_questions::ResGetSecurityQuestions;
 | 
			
		||||
use crate::controllers::routes::RequestResult;
 | 
			
		||||
use crate::data::error::ResultBoxError;
 | 
			
		||||
use crate::data::http_request_handler::HttpRequestHandler;
 | 
			
		||||
@@ -81,4 +82,15 @@ pub fn has_security_questions(r: &mut HttpRequestHandler) -> RequestResult {
 | 
			
		||||
    let user = r.post_user_info_from_email("email")?;
 | 
			
		||||
 | 
			
		||||
    r.set_response(ResCheckSecurityQuestionsExists::new(user.has_security_questions()))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Get the security questions of a user
 | 
			
		||||
pub fn get_security_questions(r: &mut HttpRequestHandler) -> RequestResult {
 | 
			
		||||
    let user = r.post_user_info_from_email("email")?;
 | 
			
		||||
 | 
			
		||||
    if !user.has_security_questions() {
 | 
			
		||||
        r.forbidden("Specified user has not defined security questions!".to_string())?;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    r.set_response(ResGetSecurityQuestions::new(&user))
 | 
			
		||||
}
 | 
			
		||||
@@ -76,6 +76,7 @@ pub fn get_routes() -> Vec<Route> {
 | 
			
		||||
        Route::post("/user/getCurrentUserID", Box::new(account_controller::user_id)),
 | 
			
		||||
        Route::post_without_login("/account/exists_email", Box::new(account_controller::exists_mail)),
 | 
			
		||||
        Route::post_without_login("/account/has_security_questions", Box::new(account_controller::has_security_questions)),
 | 
			
		||||
        Route::post_without_login("/account/get_security_questions", Box::new(account_controller::get_security_questions)),
 | 
			
		||||
 | 
			
		||||
        // User controller
 | 
			
		||||
        Route::post_without_login("/user/getInfo", Box::new(user_controller::get_single)),
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user