Refactor users_service
This commit is contained in:
@ -81,16 +81,7 @@ pub async fn request_reset_password(user: &mut User) -> anyhow::Result<()> {
|
||||
user.reset_password_token = Some(rand_str(149));
|
||||
user.time_gen_reset_token = time() as i64;
|
||||
|
||||
db_connection::execute(|conn| {
|
||||
Ok(
|
||||
diesel::update(users::dsl::users.filter(users::dsl::id.eq(user.id)))
|
||||
.set((
|
||||
users::dsl::time_gen_reset_token.eq(user.time_gen_reset_token),
|
||||
users::dsl::reset_password_token.eq(user.reset_password_token.clone()),
|
||||
))
|
||||
.execute(conn)?,
|
||||
)
|
||||
})?;
|
||||
update_account(user).await?;
|
||||
}
|
||||
|
||||
// Send mail
|
||||
@ -129,7 +120,7 @@ pub async fn delete_not_validated_accounts() -> anyhow::Result<()> {
|
||||
}
|
||||
|
||||
/// Mark account as validated
|
||||
pub async fn validate_account(user: &User) -> anyhow::Result<()> {
|
||||
pub async fn validate_account(user: &mut User) -> anyhow::Result<()> {
|
||||
if user.time_activate > 0 {
|
||||
log::debug!(
|
||||
"Did not activate account {} because it is already activated!",
|
||||
@ -138,13 +129,9 @@ pub async fn validate_account(user: &User) -> anyhow::Result<()> {
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
db_connection::execute(|conn| {
|
||||
Ok(
|
||||
diesel::update(users::dsl::users.filter(users::dsl::id.eq(user.id)))
|
||||
.set((users::dsl::time_activate.eq(time() as i64),))
|
||||
.execute(conn)?,
|
||||
)
|
||||
})?;
|
||||
user.time_activate = time() as i64;
|
||||
|
||||
update_account(user).await?;
|
||||
|
||||
mail_service::send_mail(
|
||||
&user.email,
|
||||
@ -160,15 +147,19 @@ pub async fn validate_account(user: &User) -> anyhow::Result<()> {
|
||||
}
|
||||
|
||||
/// Update account information
|
||||
pub async fn update_account(user: User) -> anyhow::Result<()> {
|
||||
pub async fn update_account(user: &User) -> anyhow::Result<()> {
|
||||
db_connection::execute(|conn| {
|
||||
Ok(
|
||||
diesel::update(users::dsl::users.filter(users::dsl::id.eq(user.id)))
|
||||
.set((
|
||||
users::dsl::name.eq(user.name),
|
||||
users::dsl::name.eq(user.name.clone()),
|
||||
users::dsl::admin.eq(user.admin),
|
||||
users::dsl::active.eq(user.active),
|
||||
users::dsl::email.eq(user.email),
|
||||
users::dsl::email.eq(user.email.clone()),
|
||||
users::dsl::time_gen_reset_token.eq(user.time_gen_reset_token),
|
||||
users::dsl::reset_password_token.eq(user.reset_password_token.clone()),
|
||||
users::dsl::time_activate.eq(time() as i64),
|
||||
users::dsl::password.eq(user.password.clone()),
|
||||
))
|
||||
.execute(conn)?,
|
||||
)
|
||||
@ -178,19 +169,13 @@ pub async fn update_account(user: User) -> anyhow::Result<()> {
|
||||
}
|
||||
|
||||
/// Change user paswsord
|
||||
pub async fn change_password(user: &User, new_password: &str) -> anyhow::Result<()> {
|
||||
pub async fn change_password(user: &mut User, new_password: &str) -> anyhow::Result<()> {
|
||||
let hash = bcrypt::hash(new_password, DEFAULT_COST)?;
|
||||
|
||||
db_connection::execute(|conn| {
|
||||
Ok(
|
||||
diesel::update(users::dsl::users.filter(users::dsl::id.eq(user.id)))
|
||||
.set((
|
||||
users::dsl::password.eq(hash),
|
||||
users::dsl::reset_password_token.eq(None::<String>),
|
||||
))
|
||||
.execute(conn)?,
|
||||
)
|
||||
})?;
|
||||
user.reset_password_token = None;
|
||||
user.password = Some(hash);
|
||||
|
||||
update_account(user).await?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
Reference in New Issue
Block a user