Skip to content
Snippets Groups Projects
Commit 5b2691ad authored by André Noack's avatar André Noack
Browse files

Resolve #2786 "cli Kommando user:delete wirft unverständliche Fehlermeldung"

Closes #2786

Merge request studip/studip!1883
parent 84fa046d
No related branches found
No related tags found
No related merge requests found
......@@ -16,14 +16,7 @@ class UsersDelete extends Command
{
$this->setDescription('Delete users.');
$this->setHelp('Delete multiple studip user accounts');
$this->addArgument('range', InputArgument::REQUIRED, 'Username or path to csv-file');
$this->addOption(
'file_range',
'f',
InputOption::VALUE_OPTIONAL,
'Set to true, if you want use a txt file with username',
true
);
$this->addArgument('range', InputArgument::REQUIRED, 'Path to csv-file or - to read from STDIN');
$this->addOption('email', 'e', InputOption::VALUE_OPTIONAL, 'Send a deletion email', true);
$this->addOption(
'delete_admins',
......@@ -37,53 +30,48 @@ class UsersDelete extends Command
protected function execute(InputInterface $input, OutputInterface $output): int
{
$range = $input->getArgument('range');
$file_range = $input->getOption('file_range');
$email = $input->getOption('email');
$delete_admins = $input->getOption('delete_admins');
if ($email && !($MAIL_LOCALHOST && $MAIL_HOST_NAME && $ABSOLUTE_URI_STUDIP)) {
$output->writeln(
"<error>To use this script you MUST set correct values for $MAIL_LOCALHOST, $MAIL_HOST_NAME and $ABSOLUTE_URI_STUDIP in local.inc!</error>"
);
}
if (!(bool) $file_range) {
$usernames = [$range];
} else {
if (!is_file($range)) {
$output->writeln(sprintf('<error>File not found: %s</error>', $range));
return Command::FAILURE;
}
if ($range === '-') {
$file = STDIN;
} elseif (is_file($range)) {
$file = fopen($range, 'r');
$list = '';
while (!feof($file)) {
$list .= fgets($file, 1024);
}
$usernames = preg_split('/[\s,;]+/', $list, -1, PREG_SPLIT_NO_EMPTY);
$usernames = array_unique($usernames);
} else {
$output->writeln(sprintf('<error>File not found: %s</error>', $range));
return Command::FAILURE;
}
$users = \User::findBySQL('username IN (?)', [$usernames]);
$list = '';
while (!feof($file)) {
$list .= fgets($file, 1024);
}
$usernames = preg_split('/[\s,;]+/', $list, -1, PREG_SPLIT_NO_EMPTY);
$usernames = array_unique($usernames);
if (!empty($users)) {
foreach ($users as $user) {
\User::findEachBySQL(
function (\User $user) use ($output, $delete_admins, $email) {
if (!$delete_admins && ($user->perms == 'admin' || $user->perms == 'root')) {
$output->writeln(sprintf('User: %s is %s, NOT deleted', $user->username, $user->perms));
return;
}
$umanager = new \UserManagement($user->id);
//wenn keine Email gewünscht, Adresse aus den Daten löschen
if (!$email) {
$umanager->user_data['auth_user_md5.Email'] = '';
}
if ($umanager->deleteUser()) {
$output->writeln(sprintf('<info>User: %s successfully deleted:</info>', $user->username));
} else {
$umanager = new \UserManagement($user->id);
//wenn keine Email gewünscht, Adresse aus den Daten löschen
if (!$email) {
$umanager->user_data['auth_user_md5.Email'] = '';
}
if ($umanager->deleteUser()) {
$output->writeln(sprintf('<info>User: %s successfully deleted:</info>', $user->username));
} else {
$output->writeln(sprintf('<error>User: %s NOT deleted</error>', $user->username));
}
$output->writeln(parse_msg_to_clean_text($umanager->msg));
$output->writeln(sprintf('<error>User: %s NOT deleted</error>', $user->username));
}
}
}
$output->writeln(parse_msg_to_clean_text($umanager->msg));
},
'username IN (?)',
[$usernames]
);
return Command::SUCCESS;
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment