<?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\Config\Cache\ConfigCache;
+use Friendica\Core\Config\ValueObject\Cache;
use Friendica\Core\Update;
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
{
*/
private $dba;
/**
- * @var ConfigCache
+ * @var Cache
*/
private $configCache;
$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
+
+ 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
-Options
+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, ConfigCache $configCache, $argv = null)
+ public function __construct(Database $dba, Cache $configCache, $argv = null)
{
parent::__construct($argv);
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 (!$this->dba->isConnected()) {
switch ($this->getArgument(0)) {
case "dryrun":
- $output = DBStructure::update($basePath, true, false);
+ $output = DBStructure::dryRun();
break;
case "update":
$force = $this->getOption(['f', 'force'], false);
$override = $this->getOption(['o', 'override'], 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($basePath);
$output = ob_get_clean();
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;
}