1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Server\Privileges;
use Exception;
use PhpMyAdmin\DatabaseInterface;
use PhpMyAdmin\Query\Compatibility;
use function __;
use function sprintf;
final class AccountLocking
{
/** @var DatabaseInterface */
private $dbi;
public function __construct(DatabaseInterface $dbi)
{
$this->dbi = $dbi;
}
/**
* @throws Exception
*/
public function lock(string $user, string $host): void
{
if (! Compatibility::hasAccountLocking($this->dbi->isMariaDB(), $this->dbi->getVersion())) {
throw new Exception(__('Account locking is not supported.'));
}
$statement = sprintf(
'ALTER USER \'%s\'@\'%s\' ACCOUNT LOCK;',
$this->dbi->escapeString($user),
$this->dbi->escapeString($host)
);
if ($this->dbi->tryQuery($statement) !== false) {
return;
}
throw new Exception($this->dbi->getError());
}
/**
* @throws Exception
*/
public function unlock(string $user, string $host): void
{
if (! Compatibility::hasAccountLocking($this->dbi->isMariaDB(), $this->dbi->getVersion())) {
throw new Exception(__('Account locking is not supported.'));
}
$statement = sprintf(
'ALTER USER \'%s\'@\'%s\' ACCOUNT UNLOCK;',
$this->dbi->escapeString($user),
$this->dbi->escapeString($host)
);
if ($this->dbi->tryQuery($statement) !== false) {
return;
}
throw new Exception($this->dbi->getError());
}
}
|