<?php
+/**
+ * @copyright Copyright (C) 2010-2022, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
namespace Friendica\Console;
-use Friendica\Core;
+use Friendica\Core\Config\ValueObject\Cache;
use Friendica\Core\Update;
-use Friendica\Database\DBA;
+use Friendica\Database\Database;
use Friendica\Database\DBStructure;
use RuntimeException;
/**
- * @brief Performs database updates from the command line
- *
- * @author Hypolite Petovan <hypolite@mrpetovan.com>
+ * Performs database updates from the command line
*/
class DatabaseStructure extends \Asika\SimpleConsole\Console
{
protected $helpOptions = ['h', 'help', '?'];
+ /**
+ * @var Database
+ */
+ private $dba;
+ /**
+ * @var Cache
+ */
+ private $configCache;
+
protected function getHelp()
{
$help = <<<HELP
console dbstructure - Performs database updates
Usage
- bin/console dbstructure <command> [-h|--help|-?] |-f|--force] [-v]
+ bin/console dbstructure <command> [options]
Commands
- dryrun Show database update schema queries without running them
- update Update database schema
- dumpsql Dump database schema
- toinnodb Convert all tables from MyISAM to InnoDB
+ drop Show tables that aren't in use by Friendica anymore and can be dropped
+ -e|--execute Execute the removal
+
+ update Update database schema
+ -f|--force Force the update command (Even if the database structure matches)
+ -o|--override Override running or stalling updates
-Options
+ dryrun Show database update schema queries without running them
+ dumpsql Dump database schema
+ toinnodb Convert all tables from MyISAM or InnoDB in the Antelope file format to InnoDB in the Barracuda file format
+ initial Set needed initial values in the tables
+ version Set the database to a given number
+
+General Options
-h|--help|-? Show help information
-v Show more debug information.
- -f|--force Force the update command (Even if the database structure matches)
- -o|--override Override running or stalling updates
HELP;
return $help;
}
+ public function __construct(Database $dba, Cache $configCache, $argv = null)
+ {
+ parent::__construct($argv);
+
+ $this->dba = $dba;
+ $this->configCache = $configCache;
+ }
+
protected function doExecute()
{
if ($this->getOption('v')) {
return 0;
}
- if (count($this->args) > 1) {
+ if ((count($this->args) > 1) && ($this->getArgument(0) != 'version')) {
throw new \Asika\SimpleConsole\CommandArgsException('Too many arguments');
+ } elseif ((count($this->args) != 2) && ($this->getArgument(0) == 'version')) {
+ throw new \Asika\SimpleConsole\CommandArgsException('This command needs two arguments');
}
- if (!DBA::connected()) {
+ if (!$this->dba->isConnected()) {
throw new RuntimeException('Unable to connect to database');
}
- Core\Config::load();
-
- $a = get_app();
+ $basePath = $this->configCache->get('system', 'basepath');
switch ($this->getArgument(0)) {
case "dryrun":
- $output = DBStructure::update($a->getBasePath(), true, false);
+ $output = DBStructure::dryRun();
break;
case "update":
$force = $this->getOption(['f', 'force'], false);
$override = $this->getOption(['o', 'override'], false);
- $output = Update::run($a->getBasePath(), $force, $override,true, false);
+ $output = Update::run($basePath, $force, $override,true, false);
+ break;
+ case "drop":
+ $execute = $this->getOption(['e', 'execute'], false);
+ ob_start();
+ DBStructure::dropTables($execute);
+ $output = ob_get_clean();
break;
case "dumpsql":
+ DBStructure::writeStructure();
ob_start();
- DBStructure::printStructure($a->getBasePath());
+ DBStructure::printStructure($basePath);
$output = ob_get_clean();
break;
case "toinnodb":
DBStructure::convertToInnoDB();
$output = ob_get_clean();
break;
+ case "version":
+ ob_start();
+ DBStructure::setDatabaseVersion($this->getArgument(1));
+ $output = ob_get_clean();
+ break;
+ case "initial":
+ ob_start();
+ DBStructure::checkInitialValues(true);
+ $output = ob_get_clean();
+ break;
default:
$output = 'Unknown command: ' . $this->getArgument(0);
}
- $this->out($output);
+ $this->out(trim($output));
return 0;
}