<?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!');
							 | 
						|
								        }
							 | 
						|
								    }
							 | 
						|
								}
							 |