<?php
|
|
|
|
namespace App\Commands;
|
|
|
|
use Illuminate\Console\Scheduling\Schedule;
|
|
use LaravelZero\Framework\Commands\Command;
|
|
use Illuminate\Support\Facades\File;
|
|
|
|
use App\Facades\Install;
|
|
|
|
use Hackzilla\PasswordGenerator\Generator\ComputerPasswordGenerator;
|
|
use Hackzilla\PasswordGenerator\RandomGenerator\Php7RandomGenerator;
|
|
|
|
/**
|
|
*
|
|
*
|
|
*
|
|
*/
|
|
class MariadbInstallCommand extends Command
|
|
{
|
|
// destination for username and password
|
|
const MCP_LOG_FILE = '/root/mcp.log';
|
|
|
|
// length for password
|
|
const PASSWORD_LENGTH = 40;
|
|
|
|
/**
|
|
* The signature of the command.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $signature = 'mariadb:install';
|
|
|
|
/**
|
|
* The description of the command.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $description = 'Install Mariadb and set configuration';
|
|
|
|
/**
|
|
* Execute the console command.
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function handle()
|
|
{
|
|
$this->info('Mariadb install...');
|
|
|
|
exec('apt update 2>&1', $output);
|
|
exec('apt install -y mariadb-server mariadb-client 2>&1', $output);
|
|
|
|
// @TODO apt add a Warning for no good, in a later version output will be scanned for helpfull infos
|
|
$this->line(implode("\n", Install::filterAptMessages($output)));
|
|
|
|
if (Install::isReady('mariadb-server mariadb-client')) {
|
|
|
|
$this->info('Mariadb setup...');
|
|
|
|
// generate password
|
|
$generator = new ComputerPasswordGenerator();
|
|
$generator->setRandomGenerator(new Php7RandomGenerator())
|
|
->setUppercase()
|
|
->setLowercase()
|
|
->setUppercase()
|
|
->setNumbers()
|
|
->setSymbols(false)
|
|
->setLength(self::PASSWORD_LENGTH);
|
|
|
|
// getting password for root
|
|
$password = $generator->generatePasswords()[0];
|
|
|
|
// remove plugin for root and set password
|
|
$this->info('Mariadb add password for root...');
|
|
exec('sudo mysql -u root -e "UPDATE mysql.user SET Password=PASSWORD(\''.$password.'\') WHERE User=\'root\';"');
|
|
exec('sudo mysql -u root -e "UPDATE mysql.user SET plugin=\'\' where User=\'root\';"');
|
|
|
|
// make sure root can only access from local
|
|
$this->info('Mariadb make sure root can ony access from local...');
|
|
exec('sudo mysql -u root -e "DELETE FROM mysql.user WHERE User=\'root\' AND Host NOT IN (\'localhost\', \'127.0.0.1\', \'::1\');"');
|
|
|
|
// delete anonymous user
|
|
$this->info('Mariadb delete anonymous user...');
|
|
exec('sudo mysql -u root -e "DELETE FROM mysql.user WHERE User=\'\';"');
|
|
|
|
// drop test database and anthing familiar
|
|
$this->info('Mariadb drop test and anthing familiar...');
|
|
exec('sudo mysql -u root -e "DROP DATABASE IF EXISTS test;"');
|
|
exec('sudo mysql -u root -e "DELETE FROM mysql.db WHERE Db=\'test\' OR Db=\'test_%\';"');
|
|
|
|
// update privileges
|
|
exec('sudo mysql -u root -e "FLUSH PRIVILEGES;"');
|
|
|
|
$this->info('Mariadb installing...Success! \o/ Check '.self::MCP_LOG_FILE);
|
|
file_put_contents(self::MCP_LOG_FILE, "Mariadb installed\nuser: root\npassword: $password\n--\n", FILE_APPEND);
|
|
|
|
} else {
|
|
$this->error('Failed! Please check log-file!');
|
|
}
|
|
}
|
|
}
|