You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
77 lines
2.4 KiB
77 lines
2.4 KiB
<?php |
|
|
|
declare(strict_types=1); |
|
|
|
namespace PhpMyAdmin\Controllers\Preferences; |
|
|
|
use PhpMyAdmin\ConfigStorage\Relation; |
|
use PhpMyAdmin\Controllers\AbstractController; |
|
use PhpMyAdmin\Message; |
|
use PhpMyAdmin\ResponseRenderer; |
|
use PhpMyAdmin\Template; |
|
use PhpMyAdmin\TwoFactor; |
|
|
|
use function __; |
|
use function count; |
|
|
|
class TwoFactorController extends AbstractController |
|
{ |
|
/** @var Relation */ |
|
private $relation; |
|
|
|
public function __construct(ResponseRenderer $response, Template $template, Relation $relation) |
|
{ |
|
parent::__construct($response, $template); |
|
$this->relation = $relation; |
|
} |
|
|
|
public function __invoke(): void |
|
{ |
|
global $cfg, $route; |
|
|
|
$relationParameters = $this->relation->getRelationParameters(); |
|
|
|
echo $this->template->render('preferences/header', [ |
|
'route' => $route, |
|
'is_saved' => ! empty($_GET['saved']), |
|
'has_config_storage' => $relationParameters->userPreferencesFeature !== null, |
|
]); |
|
|
|
$twoFactor = new TwoFactor($cfg['Server']['user']); |
|
|
|
if (isset($_POST['2fa_remove'])) { |
|
if (! $twoFactor->check(true)) { |
|
echo $this->template->render('preferences/two_factor/confirm', [ |
|
'form' => $twoFactor->render(), |
|
]); |
|
|
|
return; |
|
} |
|
|
|
$twoFactor->configure(''); |
|
echo Message::rawNotice(__('Two-factor authentication has been removed.'))->getDisplay(); |
|
} elseif (isset($_POST['2fa_configure'])) { |
|
if (! $twoFactor->configure($_POST['2fa_configure'])) { |
|
echo $this->template->render('preferences/two_factor/configure', [ |
|
'form' => $twoFactor->setup(), |
|
'configure' => $_POST['2fa_configure'], |
|
]); |
|
|
|
return; |
|
} |
|
|
|
echo Message::rawNotice(__('Two-factor authentication has been configured.'))->getDisplay(); |
|
} |
|
|
|
$backend = $twoFactor->getBackend(); |
|
echo $this->template->render('preferences/two_factor/main', [ |
|
'enabled' => $twoFactor->isWritable(), |
|
'num_backends' => count($twoFactor->getAvailable()), |
|
'backend_id' => $backend::$id, |
|
'backend_name' => $backend::getName(), |
|
'backend_description' => $backend::getDescription(), |
|
'backends' => $twoFactor->getAllBackends(), |
|
'missing' => $twoFactor->getMissingDeps(), |
|
]); |
|
} |
|
}
|
|
|