mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2024-11-25 23:09:22 +00:00
Can get current user ID
This commit is contained in:
parent
3b1b377d82
commit
75024dbca6
18
src/api_data/current_user_id.rs
Normal file
18
src/api_data/current_user_id.rs
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
use crate::data::user::UserID;
|
||||||
|
|
||||||
|
/// Current user ID
|
||||||
|
#[derive(Serialize, Deserialize)]
|
||||||
|
#[allow(non_snake_case)]
|
||||||
|
pub struct CurrentUserID {
|
||||||
|
userID: i64
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CurrentUserID {
|
||||||
|
pub fn new(id: UserID) -> CurrentUserID {
|
||||||
|
CurrentUserID {
|
||||||
|
userID: id
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -9,3 +9,4 @@
|
|||||||
|
|
||||||
pub mod http_error;
|
pub mod http_error;
|
||||||
pub mod login_success;
|
pub mod login_success;
|
||||||
|
pub mod current_user_id;
|
@ -2,6 +2,7 @@ use crate::api_data::login_success::LoginSuccess;
|
|||||||
use crate::controllers::routes::RequestResult;
|
use crate::controllers::routes::RequestResult;
|
||||||
use crate::data::http_request_handler::HttpRequestHandler;
|
use crate::data::http_request_handler::HttpRequestHandler;
|
||||||
use crate::helpers::account_helper;
|
use crate::helpers::account_helper;
|
||||||
|
use crate::api_data::current_user_id::CurrentUserID;
|
||||||
|
|
||||||
/// Account controller
|
/// Account controller
|
||||||
///
|
///
|
||||||
@ -29,3 +30,8 @@ pub fn login_user(request: &mut HttpRequestHandler) -> RequestResult {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get current user ID
|
||||||
|
pub fn user_id(request: &mut HttpRequestHandler) -> RequestResult {
|
||||||
|
request.set_response(CurrentUserID::new(request.user_id()?))
|
||||||
|
}
|
@ -51,6 +51,15 @@ impl Route {
|
|||||||
func
|
func
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn post(uri: &'static str, func: RequestProcess) -> Route {
|
||||||
|
Route {
|
||||||
|
method: POST,
|
||||||
|
need_login: true,
|
||||||
|
uri,
|
||||||
|
func
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the list of routes available
|
/// Get the list of routes available
|
||||||
@ -62,5 +71,8 @@ pub fn get_routes() -> Vec<Route> {
|
|||||||
// Account controller
|
// Account controller
|
||||||
Route::post_without_login("/account/login", Box::new(account_controller::login_user)),
|
Route::post_without_login("/account/login", Box::new(account_controller::login_user)),
|
||||||
Route::post_without_login("/user/connectUSER", Box::new(account_controller::login_user)),
|
Route::post_without_login("/user/connectUSER", Box::new(account_controller::login_user)),
|
||||||
|
|
||||||
|
Route::post("/account/id", Box::new(account_controller::user_id)),
|
||||||
|
Route::post("/user/getCurrentUserID", Box::new(account_controller::user_id)),
|
||||||
]
|
]
|
||||||
}
|
}
|
@ -108,6 +108,11 @@ fn process_simple_route(route: &Route, req: &mut HttpRequestHandler) -> RequestR
|
|||||||
// Validate client token
|
// Validate client token
|
||||||
req.check_client_token()?;
|
req.check_client_token()?;
|
||||||
|
|
||||||
|
// Check user token, if required
|
||||||
|
if route.need_login || req.has_post_parameter("userToken1") {
|
||||||
|
req.check_user_token()?;
|
||||||
|
}
|
||||||
|
|
||||||
(route.func)(req)
|
(route.func)(req)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4,12 +4,13 @@ use std::error::Error;
|
|||||||
use serde::Serialize;
|
use serde::Serialize;
|
||||||
use crate::data::error::{ResultBoxError, ExecError};
|
use crate::data::error::{ResultBoxError, ExecError};
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use crate::helpers::api_helper;
|
use crate::helpers::{api_helper, account_helper};
|
||||||
use actix_web::http::{HeaderName, HeaderValue};
|
use actix_web::http::{HeaderName, HeaderValue};
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
use crate::data::config::conf;
|
use crate::data::config::conf;
|
||||||
use crate::data::api_client::APIClient;
|
use crate::data::api_client::APIClient;
|
||||||
use crate::api_data::http_error::HttpError;
|
use crate::api_data::http_error::HttpError;
|
||||||
|
use crate::data::user::UserID;
|
||||||
|
|
||||||
/// Http request handler
|
/// Http request handler
|
||||||
///
|
///
|
||||||
@ -40,6 +41,7 @@ pub struct HttpRequestHandler {
|
|||||||
response: Option<web::HttpResponse>,
|
response: Option<web::HttpResponse>,
|
||||||
headers: HashMap<String, String>,
|
headers: HashMap<String, String>,
|
||||||
client: Option<APIClient>,
|
client: Option<APIClient>,
|
||||||
|
curr_user_id: Option<UserID>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl HttpRequestHandler {
|
impl HttpRequestHandler {
|
||||||
@ -51,6 +53,7 @@ impl HttpRequestHandler {
|
|||||||
response: None,
|
response: None,
|
||||||
headers: HashMap::new(),
|
headers: HashMap::new(),
|
||||||
client: None,
|
client: None,
|
||||||
|
curr_user_id: None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,8 +178,8 @@ impl HttpRequestHandler {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Check login tokens
|
/// Check API client tokens
|
||||||
pub fn check_client_token(&mut self) -> Result<(), Box<dyn Error>> {
|
pub fn check_client_token(&mut self) -> RequestResult {
|
||||||
let api_name = self.post_string("serviceName")?;
|
let api_name = self.post_string("serviceName")?;
|
||||||
let api_token = self.post_string("serviceToken")?;
|
let api_token = self.post_string("serviceToken")?;
|
||||||
|
|
||||||
@ -209,6 +212,28 @@ impl HttpRequestHandler {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Check login token
|
||||||
|
pub fn check_user_token(&mut self) -> RequestResult {
|
||||||
|
let token = self.post_string("userToken1")?;
|
||||||
|
|
||||||
|
// Find user
|
||||||
|
let user_id = self.ok_or_bad_request(
|
||||||
|
account_helper::get_user_by_login_token(&token, self.api_client()),
|
||||||
|
"Please check your login tokens!")?;
|
||||||
|
|
||||||
|
self.curr_user_id = Some(user_id);
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Get user ID. This function assess that a user ID is available to continue
|
||||||
|
pub fn user_id(&self) -> ResultBoxError<UserID> {
|
||||||
|
match self.curr_user_id {
|
||||||
|
Some(s) => Ok(s),
|
||||||
|
None => Err(ExecError::boxed_new("Could not get required user ID!"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Get an email included in the request
|
/// Get an email included in the request
|
||||||
pub fn post_email(&mut self, name: &str) -> ResultBoxError<String> {
|
pub fn post_email(&mut self, name: &str) -> ResultBoxError<String> {
|
||||||
let mail = self.post_string(name)?;
|
let mail = self.post_string(name)?;
|
||||||
|
@ -34,7 +34,7 @@ pub fn login_user(email: &str, password: &str, client: &APIClient) -> ResultBoxE
|
|||||||
let new_token = UserAccessToken {
|
let new_token = UserAccessToken {
|
||||||
user_id: user.id,
|
user_id: user.id,
|
||||||
client_id: client.id,
|
client_id: client.id,
|
||||||
token: rand_str(150)
|
token: rand_str(150),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Save it
|
// Save it
|
||||||
@ -64,3 +64,13 @@ fn get_client_tokens(user_id: UserID, client: &APIClient) -> ResultBoxError<User
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Find a user ID based on login token
|
||||||
|
pub fn get_user_by_login_token(token: &str, client: &APIClient) -> ResultBoxError<UserID> {
|
||||||
|
database::query_row(
|
||||||
|
QueryInfo::new(USER_ACCESS_TOKENS_TABLE)
|
||||||
|
.cond_u32("service_id", client.id)
|
||||||
|
.cond("token1", token),
|
||||||
|
|res| res.get_int64("user_id"),
|
||||||
|
)
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user