Add user creation and deletion
This commit is contained in:
parent
4af4717785
commit
6aae797f16
53
src/Console/CreateUserCommand.php
Normal file
53
src/Console/CreateUserCommand.php
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Console;
|
||||||
|
|
||||||
|
use App\Service\DatabaseService;
|
||||||
|
use Symfony\Component\Console\Attribute\AsCommand;
|
||||||
|
use Symfony\Component\Console\Command\Command;
|
||||||
|
use Symfony\Component\Console\Input\InputArgument;
|
||||||
|
use Symfony\Component\Console\Input\InputInterface;
|
||||||
|
use Symfony\Component\Console\Output\OutputInterface;
|
||||||
|
use Symfony\Component\Console\Question\Question;
|
||||||
|
|
||||||
|
#[AsCommand('user:create')]
|
||||||
|
class CreateUserCommand extends Command
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private readonly DatabaseService $db,
|
||||||
|
)
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function configure(): void
|
||||||
|
{
|
||||||
|
$this->addArgument('name', InputArgument::OPTIONAL, 'User name');
|
||||||
|
$this->addArgument('password', InputArgument::OPTIONAL, 'User password');
|
||||||
|
$this->addArgument('host', InputArgument::OPTIONAL, 'User host');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function execute(InputInterface $input, OutputInterface $output): int
|
||||||
|
{
|
||||||
|
$question = $this->getHelper('question');
|
||||||
|
|
||||||
|
$name = $input->getArgument('name');
|
||||||
|
$password = $input->getArgument('password');
|
||||||
|
$host = $input->getArgument('host');
|
||||||
|
|
||||||
|
if (!$name) {
|
||||||
|
$name = $question->ask($input, $output, new Question('User name: '));
|
||||||
|
}
|
||||||
|
if (!$password) {
|
||||||
|
$passwordQuestion = new Question('User password: ');
|
||||||
|
$passwordQuestion->setHidden(true);
|
||||||
|
$password = $question->ask($input, $output, $passwordQuestion);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->db->createUser($name, $password, $host);
|
||||||
|
|
||||||
|
$output->writeln(sprintf('User "%s" successfully created', $name));
|
||||||
|
|
||||||
|
return Command::SUCCESS;
|
||||||
|
}
|
||||||
|
}
|
49
src/Console/DeleteUserCommand.php
Normal file
49
src/Console/DeleteUserCommand.php
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Console;
|
||||||
|
|
||||||
|
use App\Service\DatabaseService;
|
||||||
|
use Symfony\Component\Console\Attribute\AsCommand;
|
||||||
|
use Symfony\Component\Console\Command\Command;
|
||||||
|
use Symfony\Component\Console\Input\InputArgument;
|
||||||
|
use Symfony\Component\Console\Input\InputInterface;
|
||||||
|
use Symfony\Component\Console\Output\OutputInterface;
|
||||||
|
use Symfony\Component\Console\Question\ChoiceQuestion;
|
||||||
|
use Symfony\Component\Console\Question\Question;
|
||||||
|
|
||||||
|
#[AsCommand('user:delete')]
|
||||||
|
class DeleteUserCommand extends Command
|
||||||
|
{
|
||||||
|
public function __construct(
|
||||||
|
private readonly DatabaseService $db,
|
||||||
|
)
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function configure(): void
|
||||||
|
{
|
||||||
|
$this->addArgument('name', InputArgument::OPTIONAL, 'User name');
|
||||||
|
$this->addArgument('host', InputArgument::OPTIONAL, 'User host');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function execute(InputInterface $input, OutputInterface $output): int
|
||||||
|
{
|
||||||
|
$question = $this->getHelper('question');
|
||||||
|
$host = $input->getArgument('host');
|
||||||
|
|
||||||
|
if (!$name = $input->getArgument('name')) {
|
||||||
|
$selectQuestion = new ChoiceQuestion('User name: ', array_map(
|
||||||
|
fn($user) => $user['name'],
|
||||||
|
$this->db->listUsers())
|
||||||
|
);
|
||||||
|
$name = $question->ask($input, $output, $selectQuestion);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->db->deleteUser($name, $host);
|
||||||
|
|
||||||
|
$output->writeln(sprintf('User "%s" successfully deleted', $name));
|
||||||
|
|
||||||
|
return Command::SUCCESS;
|
||||||
|
}
|
||||||
|
}
|
@ -10,9 +10,7 @@ class BackupService
|
|||||||
{
|
{
|
||||||
public function __construct(
|
public function __construct(
|
||||||
private readonly DatabaseCredentials $credentials
|
private readonly DatabaseCredentials $credentials
|
||||||
)
|
) {}
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public function backup(string $db, ?string $fileName = null): string
|
public function backup(string $db, ?string $fileName = null): string
|
||||||
{
|
{
|
||||||
|
@ -40,6 +40,20 @@ class DatabaseService
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function deleteDatabase(string $name): void
|
||||||
|
{
|
||||||
|
$result = $this->conn->query(sprintf('DROP DATABASE `%s`', $name));
|
||||||
|
if (!$result) {
|
||||||
|
throw new Exception(sprintf('Database delete error: %s', $this->conn->error));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function purgeDatabase(string $name): void
|
||||||
|
{
|
||||||
|
$this->deleteDatabase($name);
|
||||||
|
$this->createDatabase($name);
|
||||||
|
}
|
||||||
|
|
||||||
public function listUsers(): array
|
public function listUsers(): array
|
||||||
{
|
{
|
||||||
$results = $this->conn->query('select * from mysql.user');
|
$results = $this->conn->query('select * from mysql.user');
|
||||||
@ -56,17 +70,44 @@ class DatabaseService
|
|||||||
return $users;
|
return $users;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function deleteDatabase(string $name): void
|
public function createUser(
|
||||||
|
string $name,
|
||||||
|
string $password,
|
||||||
|
?string $host = null,
|
||||||
|
): void
|
||||||
{
|
{
|
||||||
$result = $this->conn->query(sprintf('DROP DATABASE `%s`', $name));
|
$host ??= 'localhost';
|
||||||
|
|
||||||
|
$users = $this->listUsers();
|
||||||
|
foreach ($users as $user) {
|
||||||
|
if ($user['name'] === $name) {
|
||||||
|
throw new Exception(sprintf('User "%s" already exists', $name));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$result = $this->conn->query(sprintf("CREATE USER '%s'@'%s' IDENTIFIED BY '%s'", $name, $host, $password));
|
||||||
if (!$result) {
|
if (!$result) {
|
||||||
throw new Exception(sprintf('Database delete error: %s', $this->conn->error));
|
throw new Exception(sprintf('User create error: %s', $this->conn->error));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function purgeDatabase(string $name): void
|
public function deleteUser(string $name, ?string $host = null): void
|
||||||
{
|
{
|
||||||
$this->deleteDatabase($name);
|
$host ??= 'localhost';
|
||||||
$this->createDatabase($name);
|
$users = $this->listUsers();
|
||||||
|
$found = false;
|
||||||
|
foreach ($users as $user) {
|
||||||
|
if ($user['name'] === $name) {
|
||||||
|
$found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$found) {
|
||||||
|
throw new Exception(sprintf('User "%s" not found', $name));
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = $this->conn->query(sprintf("DROP USER '%s'@'%s'", $name, $host));
|
||||||
|
if (!$result) {
|
||||||
|
throw new Exception(sprintf('User delete error: %s', $this->conn->error));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user