| Server IP : 127.0.0.1 / Your IP : 216.73.216.48 Web Server : Apache/2.4.58 (Win64) OpenSSL/3.1.3 PHP/8.2.12 System : Windows NT DESKTOP-3H4FHQJ 10.0 build 19045 (Windows 10) AMD64 User : win 10 ( 0) PHP Version : 8.2.12 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : D:/xamppkk/phpMyAdmin/libraries/classes/Server/Privileges/ |
Upload File : |
<?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());
}
}