update database settings command

This commit is contained in:
Boy132 2024-04-30 00:03:00 +02:00
parent 3f3b500a14
commit 488acce564

View File

@ -11,14 +11,20 @@ class DatabaseSettingsCommand extends Command
{ {
use EnvironmentWriterTrait; use EnvironmentWriterTrait;
public const DATABASE_DRIVERS = [
'sqlite' => 'SQLite (recommended)',
'mysql' => 'MySQL',
];
protected $description = 'Configure database settings for the Panel.'; protected $description = 'Configure database settings for the Panel.';
protected $signature = 'p:environment:database 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.} {--host= : The connection address for the MySQL server.}
{--port= : The connection port for the MySQL server.} {--port= : The connection port for the MySQL server.}
{--database= : The database to use.} {--username= : Username to use when connecting to the MySQL server.}
{--username= : Username to use when connecting.} {--password= : Password to use for the MySQL database.}';
{--password= : Password to use for this database.}';
protected array $variables = []; protected array $variables = [];
@ -35,51 +41,65 @@ class DatabaseSettingsCommand extends Command
*/ */
public function handle(): int 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".'); $selected = config('database.default', 'sqlite');
$this->variables['DB_HOST'] = $this->option('host') ?? $this->ask( $this->variables['DB_CONNECTION'] = $this->option('driver') ?? $this->choice(
'Database Host', 'Database Driver',
config('database.connections.mysql.host', '127.0.0.1') self::DATABASE_DRIVERS,
array_key_exists($selected, self::DATABASE_DRIVERS) ? $selected : null
); );
$this->variables['DB_PORT'] = $this->option('port') ?? $this->ask( if ($this->variables['DB_CONNECTION'] === 'mysql') {
'Database Port', $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".');
config('database.connections.mysql.port', 3306) $this->variables['DB_HOST'] = $this->option('host') ?? $this->ask(
); 'Database Host',
config('database.connections.mysql.host', '127.0.0.1')
);
$this->variables['DB_DATABASE'] = $this->option('database') ?? $this->ask( $this->variables['DB_PORT'] = $this->option('port') ?? $this->ask(
'Database Name', 'Database Port',
config('database.connections.mysql.database', 'panel') config('database.connections.mysql.port', 3306)
); );
$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_DATABASE'] = $this->option('database') ?? $this->ask(
$this->variables['DB_USERNAME'] = $this->option('username') ?? $this->ask( 'Database Name',
'Database Username', config('database.connections.mysql.database', 'panel')
config('database.connections.mysql.username', 'pelican') );
);
$askForMySQLPassword = true; $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.');
if (!empty(config('database.connections.mysql.password')) && $this->input->isInteractive()) { $this->variables['DB_USERNAME'] = $this->option('username') ?? $this->ask(
$this->variables['DB_PASSWORD'] = config('database.connections.mysql.password'); 'Database Username',
$askForMySQLPassword = $this->confirm('It appears you already have a MySQL connection password defined, would you like to change it?'); config('database.connections.mysql.username', 'pelican')
} );
if ($askForMySQLPassword) { $askForMySQLPassword = true;
$this->variables['DB_PASSWORD'] = $this->option('password') ?? $this->secret('Database Password'); 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?');
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; 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;
}
} 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->writeToEnvironment($this->variables);