132 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			4.9 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;
 | |
| 
 | |
|     public const DATABASE_DRIVERS = [
 | |
|         'sqlite' => 'SQLite (recommended)',
 | |
|         'mysql' => 'MySQL',
 | |
|     ];
 | |
| 
 | |
|     protected $description = 'Configure database settings for the Panel.';
 | |
| 
 | |
|     protected $signature = 'p:environment:database
 | |
|                             {--driver= : The database driver backend to use.}
 | |
|                             {--database= : The database to use.}
 | |
|                             {--host= : The connection address for the MySQL server.}
 | |
|                             {--port= : The connection port for the MySQL server.}
 | |
|                             {--username= : Username to use when connecting to the MySQL server.}
 | |
|                             {--password= : Password to use for the MySQL database.}';
 | |
| 
 | |
|     protected array $variables = [];
 | |
| 
 | |
|     /**
 | |
|      * DatabaseSettingsCommand constructor.
 | |
|      */
 | |
|     public function __construct(private DatabaseManager $database, private Kernel $console)
 | |
|     {
 | |
|         parent::__construct();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Handle command execution.
 | |
|      */
 | |
|     public function handle(): int
 | |
|     {
 | |
|         $selected = config('database.default', 'sqlite');
 | |
|         $this->variables['DB_CONNECTION'] = $this->option('driver') ?? $this->choice(
 | |
|             'Database Driver',
 | |
|             self::DATABASE_DRIVERS,
 | |
|             array_key_exists($selected, self::DATABASE_DRIVERS) ? $selected : null
 | |
|         );
 | |
| 
 | |
|         if ($this->variables['DB_CONNECTION'] === 'mysql') {
 | |
|             $this->output->note(__('commands.database_settings.DB_HOST_note'));
 | |
|             $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(__('commands.database_settings.DB_USERNAME_note'));
 | |
|             $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(__('commands.database_settings.DB_PASSWORD_note'));
 | |
|             }
 | |
| 
 | |
|             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(__('commands.database_settings.DB_error_2'));
 | |
| 
 | |
|                 if ($this->confirm(__('commands.database_settings.go_back'))) {
 | |
|                     $this->database->disconnect('_panel_command_test');
 | |
| 
 | |
|                     return $this->handle();
 | |
|                 }
 | |
| 
 | |
|                 return 1;
 | |
|             }
 | |
|         } elseif ($this->variables['DB_CONNECTION'] === 'sqlite') {
 | |
|             $this->variables['DB_DATABASE'] = $this->option('database') ?? $this->ask(
 | |
|                 'Database Path',
 | |
|                 config('database.connections.sqlite.database', database_path('database.sqlite'))
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         $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();
 | |
|     }
 | |
| }
 | 
