Add restore command
This commit is contained in:
parent
11089d82bc
commit
7daddaab88
2
.gitignore
vendored
2
.gitignore
vendored
@ -8,3 +8,5 @@
|
|||||||
/var/
|
/var/
|
||||||
/vendor/
|
/vendor/
|
||||||
###< symfony/framework-bundle ###
|
###< symfony/framework-bundle ###
|
||||||
|
|
||||||
|
*_backup.sql
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
"symfony/console": "5.3.*",
|
"symfony/console": "5.3.*",
|
||||||
"symfony/dotenv": "5.3.*",
|
"symfony/dotenv": "5.3.*",
|
||||||
"symfony/filesystem": "5.3.*",
|
"symfony/filesystem": "5.3.*",
|
||||||
|
"symfony/finder": "5.3.*",
|
||||||
"symfony/flex": "^1.3.1",
|
"symfony/flex": "^1.3.1",
|
||||||
"symfony/framework-bundle": "5.3.*",
|
"symfony/framework-bundle": "5.3.*",
|
||||||
"symfony/process": "5.3.*",
|
"symfony/process": "5.3.*",
|
||||||
|
2
composer.lock
generated
2
composer.lock
generated
@ -4,7 +4,7 @@
|
|||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "8c7050f7bee5a93ee3509d8014488736",
|
"content-hash": "9ee32d11a76246681509a53554f766a3",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "psr/cache",
|
"name": "psr/cache",
|
||||||
|
@ -33,8 +33,8 @@ class BackupDatabase extends Command
|
|||||||
{
|
{
|
||||||
$db = $this->getDatabaseName($input, $output);
|
$db = $this->getDatabaseName($input, $output);
|
||||||
|
|
||||||
$output = $this->bs->backup($db);
|
$backupName = $this->bs->backup($db);
|
||||||
dump($output);
|
$output->writeln(sprintf('Backup written to: %s', $backupName));
|
||||||
|
|
||||||
return Command::SUCCESS;
|
return Command::SUCCESS;
|
||||||
}
|
}
|
||||||
|
52
src/Console/RestoreDatabase.php
Normal file
52
src/Console/RestoreDatabase.php
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Console;
|
||||||
|
|
||||||
|
use App\Service\BackupService;
|
||||||
|
use App\Service\DatabaseService;
|
||||||
|
use App\Service\Traits\SelectDatabaseQuestion;
|
||||||
|
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\Finder\Finder;
|
||||||
|
|
||||||
|
class RestoreDatabase extends Command
|
||||||
|
{
|
||||||
|
use SelectDatabaseQuestion;
|
||||||
|
|
||||||
|
protected static $defaultName = 'app:db:restore';
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
private DatabaseService $db,
|
||||||
|
private BackupService $bs,
|
||||||
|
)
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function configure(): void
|
||||||
|
{
|
||||||
|
$this->addArgument('name', InputArgument::OPTIONAL, 'Database name');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function execute(InputInterface $input, OutputInterface $output): int
|
||||||
|
{
|
||||||
|
$question = $this->getHelper('question');
|
||||||
|
$db = $this->getDatabaseName($input, $output);
|
||||||
|
|
||||||
|
$finder = new Finder();
|
||||||
|
$finder->in(__DIR__ . '/../..');
|
||||||
|
$files = [sprintf('%s_backup.sql', $db)];
|
||||||
|
foreach ($finder->files()->name('*_backup.sql') as $file) {
|
||||||
|
$files[] = $file->getFilename();
|
||||||
|
}
|
||||||
|
$selectQuestion = new ChoiceQuestion('Backup name (*_backup.sql): ', $files);
|
||||||
|
$fileName = $question->ask($input, $output, $selectQuestion);
|
||||||
|
|
||||||
|
$this->bs->restore($db, $fileName);
|
||||||
|
|
||||||
|
return Command::SUCCESS;
|
||||||
|
}
|
||||||
|
}
|
@ -3,6 +3,7 @@
|
|||||||
namespace App\Service;
|
namespace App\Service;
|
||||||
|
|
||||||
use Symfony\Component\Filesystem\Filesystem;
|
use Symfony\Component\Filesystem\Filesystem;
|
||||||
|
use Symfony\Component\Process\InputStream;
|
||||||
use Symfony\Component\Process\Process;
|
use Symfony\Component\Process\Process;
|
||||||
|
|
||||||
class BackupService
|
class BackupService
|
||||||
@ -11,8 +12,12 @@ class BackupService
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public function backup(string $db): string
|
public function backup(string $db, ?string $fileName = null): string
|
||||||
{
|
{
|
||||||
|
if (!$fileName) {
|
||||||
|
$fileName = sprintf('%s_backup.sql', $db);
|
||||||
|
}
|
||||||
|
|
||||||
$filesystem = new Filesystem();
|
$filesystem = new Filesystem();
|
||||||
$process = new Process([
|
$process = new Process([
|
||||||
'mysqldump',
|
'mysqldump',
|
||||||
@ -21,10 +26,21 @@ class BackupService
|
|||||||
]);
|
]);
|
||||||
$process->setEnv(['MYSQL_PWD' => $this->credentials->getPassword()]);
|
$process->setEnv(['MYSQL_PWD' => $this->credentials->getPassword()]);
|
||||||
$process->run();
|
$process->run();
|
||||||
|
|
||||||
$fileName = sprintf('%s_backup.sql', $db);
|
|
||||||
$filesystem->dumpFile($fileName, $process->getOutput());
|
$filesystem->dumpFile($fileName, $process->getOutput());
|
||||||
|
|
||||||
return $fileName;
|
return $fileName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function restore(string $db, string $fileName): void
|
||||||
|
{
|
||||||
|
$process = new Process([
|
||||||
|
'mysql',
|
||||||
|
'-u', $this->credentials->getUser(),
|
||||||
|
$db,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$process->setEnv(['MYSQL_PWD' => $this->credentials->getPassword()]);
|
||||||
|
$process->setInput(file_get_contents($fileName));
|
||||||
|
$process->run();
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user