mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-29 14:24:46 +02:00
update database settings command
This commit is contained in:
parent
3f3b500a14
commit
488acce564
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user