@ -4,7 +4,7 @@ use serde_json::Value;
use std ::{ env , time ::Duration } ;
use rocket ::{
http ::{ Cookie , Cookies , SameSite } ,
http ::{ Cookie , Cookies , SameSite , Status } ,
request ::{ self , FlashMessage , Form , FromRequest , Outcome , Request } ,
response ::{ content ::Html , Flash , Redirect } ,
Route ,
@ -279,6 +279,14 @@ struct InviteData {
email : String ,
}
fn get_user_or_404 ( uuid : & str , conn : & DbConn ) -> ApiResult < User > {
if let Some ( user ) = User ::find_by_uuid ( uuid , conn ) {
Ok ( user )
} else {
err_code ! ( "User doesn't exist" , Status ::NotFound . code ) ;
}
}
#[ post( " /invite " , data = " <data> " ) ]
fn invite_user ( data : Json < InviteData > , _token : AdminToken , conn : DbConn ) -> JsonResult {
let data : InviteData = data . into_inner ( ) ;
@ -352,20 +360,20 @@ fn users_overview(_token: AdminToken, conn: DbConn) -> ApiResult<Html<String>> {
#[ get( " /users/<uuid> " ) ]
fn get_user_json ( uuid : String , _token : AdminToken , conn : DbConn ) -> JsonResult {
let user = User ::find_by_uuid ( & uuid , & conn ) . map_res ( "User doesn't exist" ) ? ;
let user = get_user_or_404 ( & uuid , & conn ) ? ;
Ok ( Json ( user . to_json ( & conn ) ) )
}
#[ post( " /users/<uuid>/delete " ) ]
fn delete_user ( uuid : String , _token : AdminToken , conn : DbConn ) -> EmptyResult {
let user = User ::find_by_uuid ( & uuid , & conn ) . map_res ( "User doesn't exist" ) ? ;
let user = get_user_or_404 ( & uuid , & conn ) ? ;
user . delete ( & conn )
}
#[ post( " /users/<uuid>/deauth " ) ]
fn deauth_user ( uuid : String , _token : AdminToken , conn : DbConn ) -> EmptyResult {
let mut user = User ::find_by_uuid ( & uuid , & conn ) . map_res ( "User doesn't exist" ) ? ;
let mut user = get_user_or_404 ( & uuid , & conn ) ? ;
Device ::delete_all_by_user ( & user . uuid , & conn ) ? ;
user . reset_security_stamp ( ) ;
@ -374,7 +382,7 @@ fn deauth_user(uuid: String, _token: AdminToken, conn: DbConn) -> EmptyResult {
#[ post( " /users/<uuid>/disable " ) ]
fn disable_user ( uuid : String , _token : AdminToken , conn : DbConn ) -> EmptyResult {
let mut user = User ::find_by_uuid ( & uuid , & conn ) . map_res ( "User doesn't exist" ) ? ;
let mut user = get_user_or_404 ( & uuid , & conn ) ? ;
Device ::delete_all_by_user ( & user . uuid , & conn ) ? ;
user . reset_security_stamp ( ) ;
user . enabled = false ;
@ -384,7 +392,7 @@ fn disable_user(uuid: String, _token: AdminToken, conn: DbConn) -> EmptyResult {
#[ post( " /users/<uuid>/enable " ) ]
fn enable_user ( uuid : String , _token : AdminToken , conn : DbConn ) -> EmptyResult {
let mut user = User ::find_by_uuid ( & uuid , & conn ) . map_res ( "User doesn't exist" ) ? ;
let mut user = get_user_or_404 ( & uuid , & conn ) ? ;
user . enabled = true ;
user . save ( & conn )
@ -392,7 +400,7 @@ fn enable_user(uuid: String, _token: AdminToken, conn: DbConn) -> EmptyResult {
#[ post( " /users/<uuid>/remove-2fa " ) ]
fn remove_2fa ( uuid : String , _token : AdminToken , conn : DbConn ) -> EmptyResult {
let mut user = User ::find_by_uuid ( & uuid , & conn ) . map_res ( "User doesn't exist" ) ? ;
let mut user = get_user_or_404 ( & uuid , & conn ) ? ;
TwoFactor ::delete_all_by_user ( & user . uuid , & conn ) ? ;
user . totp_recover = None ;
user . save ( & conn )