196 lines
6.8 KiB
PHP
196 lines
6.8 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (C) 2010-2023, 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\Core;
|
|
|
|
use Dice\Dice;
|
|
use Friendica;
|
|
use Friendica\App;
|
|
|
|
/**
|
|
* Description of Console
|
|
*/
|
|
class Console extends \Asika\SimpleConsole\Console
|
|
{
|
|
// Disables the default help handling
|
|
protected $helpOptions = [];
|
|
protected $customHelpOptions = ['h', 'help', '?'];
|
|
|
|
/**
|
|
* @var Dice The DI library
|
|
*/
|
|
protected $dice;
|
|
|
|
protected function getHelp()
|
|
{
|
|
$help = <<<HELP
|
|
Usage: bin/console [--version] [-h|--help|-?] <command> [<args>] [-v]
|
|
|
|
Commands:
|
|
addon Addon management
|
|
cache Manage node cache
|
|
config Edit site config
|
|
contact Contact management
|
|
createdoxygen Generate Doxygen headers
|
|
dbstructure Do database updates
|
|
docbloxerrorchecker Check the file tree for DocBlox errors
|
|
extract Generate translation string file for the Friendica project (deprecated)
|
|
globalcommunityblock Block remote profile from interacting with this node
|
|
globalcommunitysilence Silence a profile from the global community page
|
|
archivecontact Archive a contact when you know that it isn't existing anymore
|
|
help Show help about a command, e.g (bin/console help config)
|
|
autoinstall Starts automatic installation of friendica based on values from htconfig.php
|
|
lock Edit site locks
|
|
maintenance Set maintenance mode for this node
|
|
movetoavatarcache Move cached avatars to the file based avatar cache
|
|
mergecontacts Merge duplicated contact entries
|
|
user User management
|
|
php2po Generate a messages.po file from a strings.php file
|
|
po2php Generate a strings.php file from a messages.po file
|
|
typo Checks for parse errors in Friendica files
|
|
postupdate Execute pending post update scripts (can last days)
|
|
relocate Update node base URL
|
|
serverblock Manage blocked servers
|
|
storage Manage storage backend
|
|
relay Manage ActivityPub relay servers
|
|
|
|
Options:
|
|
-h|--help|-? Show help information
|
|
-v Show more debug information.
|
|
HELP;
|
|
return $help;
|
|
}
|
|
|
|
protected $subConsoles = [
|
|
'addon' => Friendica\Console\Addon::class,
|
|
'archivecontact' => Friendica\Console\ArchiveContact::class,
|
|
'autoinstall' => Friendica\Console\AutomaticInstallation::class,
|
|
'cache' => Friendica\Console\Cache::class,
|
|
'config' => Friendica\Console\Config::class,
|
|
'contact' => Friendica\Console\Contact::class,
|
|
'createdoxygen' => Friendica\Console\CreateDoxygen::class,
|
|
'docbloxerrorchecker' => Friendica\Console\DocBloxErrorChecker::class,
|
|
'dbstructure' => Friendica\Console\DatabaseStructure::class,
|
|
'extract' => Friendica\Console\Extract::class,
|
|
'fixapdeliveryworkertaskparameters' => Friendica\Console\FixAPDeliveryWorkerTaskParameters::class,
|
|
'globalcommunityblock' => Friendica\Console\GlobalCommunityBlock::class,
|
|
'globalcommunitysilence' => Friendica\Console\GlobalCommunitySilence::class,
|
|
'lock' => Friendica\Console\Lock::class,
|
|
'maintenance' => Friendica\Console\Maintenance::class,
|
|
'mergecontacts' => Friendica\Console\MergeContacts::class,
|
|
'movetoavatarcache' => Friendica\Console\MoveToAvatarCache::class,
|
|
'php2po' => Friendica\Console\PhpToPo::class,
|
|
'postupdate' => Friendica\Console\PostUpdate::class,
|
|
'po2php' => Friendica\Console\PoToPhp::class,
|
|
'relay' => Friendica\Console\Relay::class,
|
|
'relocate' => Friendica\Console\Relocate::class,
|
|
'serverblock' => Friendica\Console\ServerBlock::class,
|
|
'storage' => Friendica\Console\Storage::class,
|
|
'test' => Friendica\Console\Test::class,
|
|
'typo' => Friendica\Console\Typo::class,
|
|
'user' => Friendica\Console\User::class,
|
|
];
|
|
|
|
/**
|
|
* CliInput Friendica constructor.
|
|
*
|
|
* @param Dice $dice The DI library
|
|
* @param array $argv
|
|
*/
|
|
public function __construct(Dice $dice, array $argv = null)
|
|
{
|
|
parent::__construct($argv);
|
|
|
|
$this->dice = $dice;
|
|
}
|
|
|
|
protected function doExecute(): int
|
|
{
|
|
if ($this->getOption('v')) {
|
|
$this->out('Executable: ' . $this->executable);
|
|
$this->out('Arguments: ' . var_export($this->args, true));
|
|
$this->out('Options: ' . var_export($this->options, true));
|
|
}
|
|
|
|
$subHelp = false;
|
|
$command = null;
|
|
|
|
if ($this->getOption('version')) {
|
|
$this->out('Friendica Console version ' . App::VERSION);
|
|
|
|
return 0;
|
|
} elseif ((count($this->options) === 0 || $this->getOption($this->customHelpOptions) === true || $this->getOption($this->customHelpOptions) === 1) && count($this->args) === 0
|
|
) {
|
|
} elseif (count($this->args) >= 2 && $this->getArgument(0) == 'help') {
|
|
$command = $this->getArgument(1);
|
|
$subHelp = true;
|
|
array_shift($this->args);
|
|
array_shift($this->args);
|
|
} elseif (count($this->args) >= 1) {
|
|
$command = $this->getArgument(0);
|
|
array_shift($this->args);
|
|
}
|
|
|
|
if (is_null($command)) {
|
|
$this->out($this->getHelp());
|
|
return 0;
|
|
}
|
|
|
|
$console = $this->getSubConsole($command);
|
|
|
|
if ($subHelp) {
|
|
$console->setOption($this->customHelpOptions, true);
|
|
}
|
|
|
|
return $console->execute();
|
|
}
|
|
|
|
private function getSubConsole($command)
|
|
{
|
|
if ($this->getOption('v')) {
|
|
$this->out('Command: ' . $command);
|
|
}
|
|
|
|
if (!isset($this->subConsoles[$command])) {
|
|
throw new \Asika\SimpleConsole\CommandArgsException('Command ' . $command . ' doesn\'t exist');
|
|
}
|
|
|
|
$subargs = $this->args;
|
|
array_unshift($subargs, $this->executable);
|
|
|
|
$className = $this->subConsoles[$command];
|
|
|
|
Friendica\DI::init($this->dice);
|
|
|
|
Renderer::registerTemplateEngine('Friendica\Render\FriendicaSmartyEngine');
|
|
|
|
/** @var Console $subconsole */
|
|
$subconsole = $this->dice->create($className, [$subargs]);
|
|
|
|
foreach ($this->options as $name => $value) {
|
|
$subconsole->setOption($name, $value);
|
|
}
|
|
|
|
return $subconsole;
|
|
}
|
|
|
|
}
|