2018-08-10 23:20:25 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Friendica\Core\Console;
|
|
|
|
|
2018-08-29 13:48:40 +02:00
|
|
|
use Friendica\Core\Config;
|
2019-02-03 22:46:50 +01:00
|
|
|
use Friendica\Core\L10n;
|
2018-11-12 11:36:10 +01:00
|
|
|
use Friendica\Core\Update;
|
2018-08-10 23:20:25 +02:00
|
|
|
|
|
|
|
/**
|
2018-09-16 01:28:38 +02:00
|
|
|
* Performs database post updates
|
2018-08-10 23:20:25 +02:00
|
|
|
*
|
|
|
|
* License: AGPLv3 or later, same as Friendica
|
|
|
|
*
|
2018-09-16 01:28:38 +02:00
|
|
|
* @author Tobias Diekershoff <tobias.diekershoff@gmx.net>
|
|
|
|
* @author Hypolite Petovan <hypolite@mrpetovan.com>
|
2018-08-10 23:20:25 +02:00
|
|
|
*/
|
|
|
|
class PostUpdate extends \Asika\SimpleConsole\Console
|
|
|
|
{
|
2018-08-29 13:48:40 +02:00
|
|
|
protected $helpOptions = ['h', 'help', '?'];
|
|
|
|
|
|
|
|
protected function getHelp()
|
|
|
|
{
|
|
|
|
$help = <<<HELP
|
2018-08-29 15:06:56 +02:00
|
|
|
console postupdate - Performs database post updates
|
2018-08-29 13:48:40 +02:00
|
|
|
Usage
|
|
|
|
bin/console postupdate [-h|--help|-?] [--reset <version>]
|
|
|
|
|
|
|
|
Options
|
|
|
|
-h|--help|-? Show help information
|
|
|
|
--reset <version> Reset the post update version
|
|
|
|
HELP;
|
|
|
|
return $help;
|
|
|
|
}
|
|
|
|
|
2018-08-10 23:20:25 +02:00
|
|
|
protected function doExecute()
|
|
|
|
{
|
2018-10-06 16:27:20 +02:00
|
|
|
$a = \Friendica\BaseObject::getApp();
|
2018-08-10 23:20:25 +02:00
|
|
|
|
2018-08-29 13:48:40 +02:00
|
|
|
if ($this->getOption($this->helpOptions)) {
|
|
|
|
$this->out($this->getHelp());
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$reset_version = $this->getOption('reset');
|
|
|
|
if (is_bool($reset_version)) {
|
|
|
|
$this->out($this->getHelp());
|
|
|
|
return 0;
|
|
|
|
} elseif ($reset_version) {
|
|
|
|
Config::set('system', 'post_update_version', $reset_version);
|
|
|
|
echo L10n::t('Post update version number has been set to %s.', $reset_version) . "\n";
|
|
|
|
return 0;
|
2018-08-10 23:20:25 +02:00
|
|
|
}
|
|
|
|
|
2018-10-06 16:27:20 +02:00
|
|
|
if ($a->getMode()->isInstall()) {
|
2018-08-10 23:20:25 +02:00
|
|
|
throw new \RuntimeException('Database isn\'t ready or populated yet');
|
|
|
|
}
|
|
|
|
|
2018-11-12 11:36:10 +01:00
|
|
|
echo L10n::t('Check for pending update actions.') . "\n";
|
2019-02-24 12:51:46 +01:00
|
|
|
Update::run($a->getBasePath(), true, false, true, false);
|
2018-11-12 11:36:10 +01:00
|
|
|
echo L10n::t('Done.') . "\n";
|
|
|
|
|
2018-08-10 23:20:25 +02:00
|
|
|
echo L10n::t('Execute pending post updates.') . "\n";
|
|
|
|
|
|
|
|
while (!\Friendica\Database\PostUpdate::update()) {
|
|
|
|
echo '.';
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "\n" . L10n::t('All pending post updates are done.') . "\n";
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|