Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
0.00% covered (danger)
0.00%
0 / 1
75.00% covered (warning)
75.00%
3 / 4
CRAP
96.15% covered (success)
96.15%
50 / 52
delete
0.00% covered (danger)
0.00%
0 / 1
75.00% covered (warning)
75.00%
3 / 4
9
96.15% covered (success)
96.15%
50 / 52
 __construct
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
9 / 9
 configure
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
15 / 15
 execute
0.00% covered (danger)
0.00%
0 / 1
5.03
89.47% covered (warning)
89.47%
17 / 19
 interact
100.00% covered (success)
100.00%
1 / 1
2
100.00% covered (success)
100.00%
9 / 9
<?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);
        }
    }
}