112 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Console\Commands\Environment;
 | |
| 
 | |
| use Illuminate\Console\Command;
 | |
| use Illuminate\Contracts\Console\Kernel;
 | |
| use Illuminate\Database\DatabaseManager;
 | |
| use App\Traits\Commands\EnvironmentWriterTrait;
 | |
| 
 | |
| class DatabaseSettingsCommand extends Command
 | |
| {
 | |
|     use EnvironmentWriterTrait;
 | |
| 
 | |
|     protected $description = 'Configure database settings for the Panel.';
 | |
| 
 | |
|     protected $signature = 'p:environment:database
 | |
|                             {--host= : The connection address for the MySQL server.}
 | |
|                             {--port= : The connection port for the MySQL server.}
 | |
|                             {--database= : The database to use.}
 | |
|                             {--username= : Username to use when connecting.}
 | |
|                             {--password= : Password to use for this database.}';
 | |
| 
 | |
|     protected array $variables = [];
 | |
| 
 | |
|     /**
 | |
|      * DatabaseSettingsCommand constructor.
 | |
|      */
 | |
|     public function __construct(private DatabaseManager $database, private Kernel $console)
 | |
|     {
 | |
|         parent::__construct();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Handle command execution.
 | |
|      */
 | |
|     public function handle(): int
 | |
|     {
 | |
|         $this->output->note('It is highly recommended to not use "localhost" as your database host as we have seen frequent socket connection issues. If you want to use a local connection you should be using "127.0.0.1".');
 | |
|         $this->variables['DB_HOST'] = $this->option('host') ?? $this->ask(
 | |
|             'Database Host',
 | |
|             config('database.connections.mysql.host', '127.0.0.1')
 | |
|         );
 | |
| 
 | |
|         $this->variables['DB_PORT'] = $this->option('port') ?? $this->ask(
 | |
|             'Database Port',
 | |
|             config('database.connections.mysql.port', 3306)
 | |
|         );
 | |
| 
 | |
|         $this->variables['DB_DATABASE'] = $this->option('database') ?? $this->ask(
 | |
|             'Database Name',
 | |
|             config('database.connections.mysql.database', 'panel')
 | |
|         );
 | |
| 
 | |
|         $this->output->note('Using the "root" account for MySQL connections is not only highly frowned upon, it is also not allowed by this application. You\'ll need to have created a MySQL user for this software.');
 | |
|         $this->variables['DB_USERNAME'] = $this->option('username') ?? $this->ask(
 | |
|             'Database Username',
 | |
|             config('database.connections.mysql.username', 'pelican')
 | |
|         );
 | |
| 
 | |
|         $askForMySQLPassword = true;
 | |
|         if (!empty(config('database.connections.mysql.password')) && $this->input->isInteractive()) {
 | |
|             $this->variables['DB_PASSWORD'] = config('database.connections.mysql.password');
 | |
|             $askForMySQLPassword = $this->confirm('It appears you already have a MySQL connection password defined, would you like to change it?');
 | |
|         }
 | |
| 
 | |
|         if ($askForMySQLPassword) {
 | |
|             $this->variables['DB_PASSWORD'] = $this->option('password') ?? $this->secret('Database Password');
 | |
|         }
 | |
| 
 | |
|         try {
 | |
|             $this->testMySQLConnection();
 | |
|         } catch (\PDOException $exception) {
 | |
|             $this->output->error(sprintf('Unable to connect to the MySQL server using the provided credentials. The error returned was "%s".', $exception->getMessage()));
 | |
|             $this->output->error('Your connection credentials have NOT been saved. You will need to provide valid connection information before proceeding.');
 | |
| 
 | |
|             if ($this->confirm('Go back and try again?')) {
 | |
|                 $this->database->disconnect('_panel_command_test');
 | |
| 
 | |
|                 return $this->handle();
 | |
|             }
 | |
| 
 | |
|             return 1;
 | |
|         }
 | |
| 
 | |
|         $this->writeToEnvironment($this->variables);
 | |
| 
 | |
|         $this->info($this->console->output());
 | |
| 
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test that we can connect to the provided MySQL instance and perform a selection.
 | |
|      */
 | |
|     private function testMySQLConnection()
 | |
|     {
 | |
|         config()->set('database.connections._panel_command_test', [
 | |
|             'driver' => 'mysql',
 | |
|             'host' => $this->variables['DB_HOST'],
 | |
|             'port' => $this->variables['DB_PORT'],
 | |
|             'database' => $this->variables['DB_DATABASE'],
 | |
|             'username' => $this->variables['DB_USERNAME'],
 | |
|             'password' => $this->variables['DB_PASSWORD'],
 | |
|             'charset' => 'utf8mb4',
 | |
|             'collation' => 'utf8mb4_unicode_ci',
 | |
|             'strict' => true,
 | |
|         ]);
 | |
| 
 | |
|         $this->database->connection('_panel_command_test')->getPdo();
 | |
|     }
 | |
| }
 | 
