class DbCommandBase in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/lib/Drupal/Core/Command/DbCommandBase.php \Drupal\Core\Command\DbCommandBase
Base command that abstracts handling of database connection arguments.
Hierarchy
- class \Symfony\Component\Console\Command\Command
- class \Drupal\Core\Command\DbCommandBase
Expanded class hierarchy of DbCommandBase
1 file declares its use of DbCommandBase
- DbCommandBaseTest.php in core/
modules/ system/ tests/ src/ Kernel/ Scripts/ DbCommandBaseTest.php - Contains \Drupal\Tests\system\Kernel\Scripts\DbCommandBaseTest.
File
- core/
lib/ Drupal/ Core/ Command/ DbCommandBase.php, line 18 - Contains \Drupal\Core\Command\DbCommandBase.
Namespace
Drupal\Core\CommandView source
class DbCommandBase extends Command {
/**
* {@inheritdoc}
*/
protected function configure() {
$this
->addOption('database', NULL, InputOption::VALUE_OPTIONAL, 'The database connection name to use.', 'default')
->addOption('database-url', 'db-url', InputOption::VALUE_OPTIONAL, 'A database url to parse and use as the database connection.')
->addOption('prefix', NULL, InputOption::VALUE_OPTIONAL, 'Override or set the table prefix used in the database connection.');
}
/**
* Parse input options decide on a database.
*
* @param \Symfony\Component\Console\Input\InputInterface $input
* Input object.
* @return \Drupal\Core\Database\Connection
*/
protected function getDatabaseConnection(InputInterface $input) {
// Load connection from a url.
if ($input
->getOption('database-url')) {
// @todo this could probably be refactored to not use a global connection.
// Ensure database connection isn't set.
if (Database::getConnectionInfo('db-tools')) {
throw new \RuntimeException('Database "db-tools" is already defined. Cannot define database provided.');
}
$info = Database::convertDbUrlToConnectionInfo($input
->getOption('database-url'), \Drupal::root());
Database::addConnectionInfo('db-tools', 'default', $info);
$key = 'db-tools';
}
else {
$key = $input
->getOption('database');
}
// If they supplied a prefix, replace it in the connection information.
$prefix = $input
->getOption('prefix');
if ($prefix) {
$info = Database::getConnectionInfo($key)['default'];
$info['prefix']['default'] = $prefix;
Database::removeConnection($key);
Database::addConnectionInfo($key, 'default', $info);
}
return Database::getConnection('default', $key);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
private | property | ||
Command:: |
public | function | Adds an argument. | |
Command:: |
public | function | Adds an option. | |
Command:: |
public | function | Add a command usage example. | |
Command:: |
public | function | Returns a text representation of the command. | |
Command:: |
public | function | Returns an XML representation of the command. | |
Command:: |
protected | function | Executes the current command. | 14 |
Command:: |
public | function | Returns the aliases for the command. | |
Command:: |
public | function | Gets the application instance for this command. | |
Command:: |
public | function | Gets the InputDefinition attached to this Command. | |
Command:: |
public | function | Returns the description for the command. | |
Command:: |
public | function | Returns the help for the command. | |
Command:: |
public | function | Gets a helper instance by name. | |
Command:: |
public | function | Gets the helper set. | |
Command:: |
public | function | Returns the command name. | |
Command:: |
public | function | Gets the InputDefinition to be used to create XML and Text representations of this Command. | 1 |
Command:: |
public | function | Returns the processed help for the command replacing the %command.name% and %command.full_name% patterns with the real values dynamically. | |
Command:: |
public | function | Returns the synopsis for the command. | |
Command:: |
public | function | Returns alternative usages of the command. | |
Command:: |
public | function | Ignores validation errors. | |
Command:: |
protected | function | Initializes the command just after the input has been validated. | |
Command:: |
protected | function | Interacts with the user. | 2 |
Command:: |
public | function | Checks whether the command is enabled or not in the current environment. | |
Command:: |
public | function | Merges the application definition with the command definition. | |
Command:: |
public | function | Runs the command. | |
Command:: |
public | function | Sets the aliases for the command. | |
Command:: |
public | function | Sets the application instance for this command. | |
Command:: |
public | function | Sets the code to execute when running this command. | |
Command:: |
public | function | Sets an array of argument and option instances. | |
Command:: |
public | function | Sets the description for the command. | |
Command:: |
public | function | Sets the help for the command. | |
Command:: |
public | function | Sets the helper set. | |
Command:: |
public | function | Sets the name of the command. | |
Command:: |
public | function | Sets the process title of the command. | |
Command:: |
private | function | Validates a command name. | |
Command:: |
public | function | Constructor. | 3 |
DbCommandBase:: |
protected | function |
Configures the current command. Overrides Command:: |
3 |
DbCommandBase:: |
protected | function | Parse input options decide on a database. | 1 |