Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
75.00% |
3 / 4 |
CRAP | |
97.67% |
42 / 43 |
delete | |
0.00% |
0 / 1 |
|
75.00% |
3 / 4 |
9 | |
97.67% |
42 / 43 |
__construct | |
100.00% |
1 / 1 |
1 | |
100.00% |
9 / 9 |
|||
configure | |
100.00% |
1 / 1 |
1 | |
100.00% |
12 / 12 |
|||
execute | |
0.00% |
0 / 1 |
5.01 | |
93.33% |
14 / 15 |
|||
interact | |
100.00% |
1 / 1 |
2 | |
100.00% |
7 / 7 |
<?php | |
/** | |
* | |
* This file is part of the phpBB Forum Software package. | |
* | |
* @copyright (c) phpBB Limited <https://www.phpbb.com> | |
* @license GNU General Public License, version 2 (GPL-2.0) | |
* | |
* For full copyright and license information, please see | |
* the docs/CREDITS.txt file. | |
* | |
*/ | |
namespace phpbb\console\command\user; | |
use phpbb\console\command\command; | |
use phpbb\db\driver\driver_interface; | |
use phpbb\language\language; | |
use phpbb\log\log_interface; | |
use phpbb\user; | |
use phpbb\user_loader; | |
use Symfony\Component\Console\Input\InputArgument; | |
use Symfony\Component\Console\Input\InputInterface; | |
use Symfony\Component\Console\Input\InputOption; | |
use Symfony\Component\Console\Output\OutputInterface; | |
use Symfony\Component\Console\Question\ConfirmationQuestion; | |
use Symfony\Component\Console\Style\SymfonyStyle; | |
class delete extends command | |
{ | |
/** @var driver_interface */ | |
protected $db; | |
/** @var language */ | |
protected $language; | |
/** @var log_interface */ | |
protected $log; | |
/** @var user_loader */ | |
protected $user_loader; | |
/** | |
* phpBB root path | |
* | |
* @var string | |
*/ | |
protected $phpbb_root_path; | |
/** | |
* PHP extension. | |
* | |
* @var string | |
*/ | |
protected $php_ext; | |
/** | |
* Construct method | |
* | |
* @param user $user | |
* @param driver_interface $db | |
* @param language $language | |
* @param log_interface $log | |
* @param user_loader $user_loader | |
* @param string $phpbb_root_path | |
* @param string $php_ext | |
*/ | |
public function __construct(user $user, driver_interface $db, language $language, log_interface $log, user_loader $user_loader, $phpbb_root_path, $php_ext) | |
{ | |
$this->db = $db; | |
$this->language = $language; | |
$this->log = $log; | |
$this->user_loader = $user_loader; | |
$this->phpbb_root_path = $phpbb_root_path; | |
$this->php_ext = $php_ext; | |
$this->language->add_lang('acp/users'); | |
parent::__construct($user); | |
} | |
/** | |
* Sets the command name and description | |
* | |
* @return null | |
*/ | |
protected function configure() | |
{ | |
$this | |
->setName('user:delete') | |
->setDescription($this->language->lang('CLI_DESCRIPTION_USER_DELETE')) | |
->addArgument( | |
'username', | |
InputArgument::REQUIRED, | |
$this->language->lang('CLI_DESCRIPTION_USER_DELETE_USERNAME') | |
) | |
->addOption( | |
'delete-posts', | |
null, | |
InputOption::VALUE_NONE, | |
$this->language->lang('CLI_DESCRIPTION_USER_DELETE_OPTION_POSTS') | |
) | |
; | |
} | |
/** | |
* Executes the command user:delete | |
* | |
* Deletes a user from the database. An option to delete the user's posts | |
* is available, by default posts will be retained. | |
* | |
* @param InputInterface $input The input stream used to get the options | |
* @param OutputInterface $output The output stream, used to print messages | |
* | |
* @return int 0 if all is well, 1 if any errors occurred | |
*/ | |
protected function execute(InputInterface $input, OutputInterface $output) | |
{ | |
$name = $input->getArgument('username'); | |
$mode = ($input->getOption('delete-posts')) ? 'remove' : 'retain'; | |
if ($name) | |
{ | |
$io = new SymfonyStyle($input, $output); | |
$user_id = $this->user_loader->load_user_by_username($name); | |
$user_row = $this->user_loader->get_user($user_id); | |
if ($user_row['user_id'] == ANONYMOUS) | |
{ | |
$io->error($this->language->lang('NO_USER')); | |
return 1; | |
} | |
if (!function_exists('user_delete')) | |
{ | |
require($this->phpbb_root_path . 'includes/functions_user.' . $this->php_ext); | |
} | |
user_delete($mode, $user_row['user_id'], $user_row['username']); | |
$this->log->add('admin', ANONYMOUS, '', 'LOG_USER_DELETED', false, array($user_row['username'])); | |
$io->success($this->language->lang('USER_DELETED')); | |
} | |
return 0; | |
} | |
/** | |
* Interacts with the user. | |
* Confirm they really want to delete the account...last chance! | |
* | |
* @param InputInterface $input An InputInterface instance | |
* @param OutputInterface $output An OutputInterface instance | |
*/ | |
protected function interact(InputInterface $input, OutputInterface $output) | |
{ | |
$helper = $this->getHelper('question'); | |
$question = new ConfirmationQuestion( | |
$this->language->lang('CLI_USER_DELETE_CONFIRM', $input->getArgument('username')), | |
false | |
); | |
if (!$helper->ask($input, $output, $question)) | |
{ | |
$input->setArgument('username', false); | |
} | |
} | |
} |