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 ...@@ -16,14 +16,7 @@ class UsersDelete extends Command
{ {
$this->setDescription('Delete users.'); $this->setDescription('Delete users.');
$this->setHelp('Delete multiple studip user accounts'); $this->setHelp('Delete multiple studip user accounts');
$this->addArgument('range', InputArgument::REQUIRED, 'Username or path to csv-file'); $this->addArgument('range', InputArgument::REQUIRED, 'Path to csv-file or - to read from STDIN');
$this->addOption(
'file_range',
'f',
InputOption::VALUE_OPTIONAL,
'Set to true, if you want use a txt file with username',
true
);
$this->addOption('email', 'e', InputOption::VALUE_OPTIONAL, 'Send a deletion email', true); $this->addOption('email', 'e', InputOption::VALUE_OPTIONAL, 'Send a deletion email', true);
$this->addOption( $this->addOption(
'delete_admins', 'delete_admins',
...@@ -37,53 +30,48 @@ class UsersDelete extends Command ...@@ -37,53 +30,48 @@ class UsersDelete extends Command
protected function execute(InputInterface $input, OutputInterface $output): int protected function execute(InputInterface $input, OutputInterface $output): int
{ {
$range = $input->getArgument('range'); $range = $input->getArgument('range');
$file_range = $input->getOption('file_range');
$email = $input->getOption('email'); $email = $input->getOption('email');
$delete_admins = $input->getOption('delete_admins'); $delete_admins = $input->getOption('delete_admins');
if ($email && !($MAIL_LOCALHOST && $MAIL_HOST_NAME && $ABSOLUTE_URI_STUDIP)) { if ($range === '-') {
$output->writeln( $file = STDIN;
"<error>To use this script you MUST set correct values for $MAIL_LOCALHOST, $MAIL_HOST_NAME and $ABSOLUTE_URI_STUDIP in local.inc!</error>" } elseif (is_file($range)) {
);
}
if (!(bool) $file_range) {
$usernames = [$range];
} else {
if (!is_file($range)) {
$output->writeln(sprintf('<error>File not found: %s</error>', $range));
return Command::FAILURE;
}
$file = fopen($range, 'r'); $file = fopen($range, 'r');
$list = ''; } else {
while (!feof($file)) { $output->writeln(sprintf('<error>File not found: %s</error>', $range));
$list .= fgets($file, 1024); return Command::FAILURE;
}
$usernames = preg_split('/[\s,;]+/', $list, -1, PREG_SPLIT_NO_EMPTY);
$usernames = array_unique($usernames);
} }
$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)) { \User::findEachBySQL(
foreach ($users as $user) { function (\User $user) use ($output, $delete_admins, $email) {
if (!$delete_admins && ($user->perms == 'admin' || $user->perms == 'root')) { if (!$delete_admins && ($user->perms == 'admin' || $user->perms == 'root')) {
$output->writeln(sprintf('User: %s is %s, NOT deleted', $user->username, $user->perms)); $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 { } else {
$umanager = new \UserManagement($user->id); $output->writeln(sprintf('<error>User: %s NOT deleted</error>', $user->username));
//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(parse_msg_to_clean_text($umanager->msg));
} },
'username IN (?)',
[$usernames]
);
return Command::SUCCESS; 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