let username_or_email = data.username_or_email.clone();
let local_user_view = LocalUserView::find_by_email_or_name(context.pool(), &username_or_email)
.await
- .map_err(|e| LemmyError::from_error_message(e, "couldnt_find_that_username_or_email"))?;
+ .map_err(|e| LemmyError::from_error_message(e, "incorrect_login"))?;
// Verify the password
let valid: bool = verify(
)
.unwrap_or(false);
if !valid {
- return Err(LemmyError::from_message("password_incorrect"));
+ return Err(LemmyError::from_message("incorrect_login"));
}
check_user_valid(
local_user_view.person.banned,
local_user_view.person.deleted,
)?;
- if site_view.local_site.require_email_verification && !local_user_view.local_user.email_verified
+ // Check if the user's email is verified if email verification is turned on
+ // However, skip checking verification if the user is an admin
+ if !local_user_view.person.admin
+ && site_view.local_site.require_email_verification
+ && !local_user_view.local_user.email_verified
{
return Err(LemmyError::from_message("email_not_verified"));
}