mirror of
https://github.com/openvk/openvk
synced 2025-01-24 08:39:27 +03:00
[SECURITY] Deny login to a deleted account
This commit is contained in:
parent
870653ccb1
commit
22157c7fa3
2 changed files with 12 additions and 2 deletions
|
@ -126,6 +126,10 @@ final class AuthPresenter extends OpenVKPresenter
|
||||||
if(!$this->authenticator->verifyCredentials($user->id, $this->postParam("password")))
|
if(!$this->authenticator->verifyCredentials($user->id, $this->postParam("password")))
|
||||||
$this->flashFail("err", tr("login_failed"), tr("invalid_username_or_password"));
|
$this->flashFail("err", tr("login_failed"), tr("invalid_username_or_password"));
|
||||||
|
|
||||||
|
$ovkUser = new User($user->related("profiles.user")->fetch());
|
||||||
|
if($ovkUser->isDeleted())
|
||||||
|
$this->flashFail("err", tr("login_failed"), tr("invalid_username_or_password"));
|
||||||
|
|
||||||
$secret = $user->related("profiles.user")->fetch()["2fa_secret"];
|
$secret = $user->related("profiles.user")->fetch()["2fa_secret"];
|
||||||
$code = $this->postParam("code");
|
$code = $this->postParam("code");
|
||||||
if(!is_null($secret)) {
|
if(!is_null($secret)) {
|
||||||
|
@ -136,7 +140,6 @@ final class AuthPresenter extends OpenVKPresenter
|
||||||
if(is_null($code))
|
if(is_null($code))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
$ovkUser = new User($user->related("profiles.user")->fetch());
|
|
||||||
if(!($code === (new Totp)->GenerateToken(Base32::decode($secret)) || $ovkUser->use2faBackupCode((int) $code))) {
|
if(!($code === (new Totp)->GenerateToken(Base32::decode($secret)) || $ovkUser->use2faBackupCode((int) $code))) {
|
||||||
$this->flash("err", tr("login_failed"), tr("incorrect_2fa_code"));
|
$this->flash("err", tr("login_failed"), tr("incorrect_2fa_code"));
|
||||||
return;
|
return;
|
||||||
|
@ -229,7 +232,7 @@ final class AuthPresenter extends OpenVKPresenter
|
||||||
}
|
}
|
||||||
|
|
||||||
$user = $this->users->getByChandlerUser(new ChandlerUser($uRow));
|
$user = $this->users->getByChandlerUser(new ChandlerUser($uRow));
|
||||||
if(!$user)
|
if(!$user || $user->isDeleted())
|
||||||
$this->flashFail("err", tr("error"), tr("password_reset_error"));
|
$this->flashFail("err", tr("error"), tr("password_reset_error"));
|
||||||
|
|
||||||
$request = $this->restores->getLatestByUser($user);
|
$request = $this->restores->getLatestByUser($user);
|
||||||
|
|
|
@ -211,6 +211,13 @@ abstract class OpenVKPresenter extends SimplePresenter
|
||||||
$this->template->thisUser = $this->user->identity;
|
$this->template->thisUser = $this->user->identity;
|
||||||
$this->template->userTainted = $user->isTainted();
|
$this->template->userTainted = $user->isTainted();
|
||||||
|
|
||||||
|
if($this->user->identity->isDeleted()) {
|
||||||
|
Authenticator::i()->logout();
|
||||||
|
Session::i()->set("_su", NULL);
|
||||||
|
$this->flashFail("err", tr("error"), tr("profile_not_found"));
|
||||||
|
$this->redirect("/", static::REDIRECT_TEMPORARY);
|
||||||
|
}
|
||||||
|
|
||||||
if($this->user->identity->isBanned() && !$this->banTolerant) {
|
if($this->user->identity->isBanned() && !$this->banTolerant) {
|
||||||
header("HTTP/1.1 403 Forbidden");
|
header("HTTP/1.1 403 Forbidden");
|
||||||
$this->getTemplatingEngine()->render(__DIR__ . "/templates/@banned.xml", [
|
$this->getTemplatingEngine()->render(__DIR__ . "/templates/@banned.xml", [
|
||||||
|
|
Loading…
Reference in a new issue