Add "User::block()" to console command

This commit is contained in:
nupplaPhil 2020-02-21 23:12:07 +01:00
parent b4f6e8fda1
commit 0c3f8b124b
No known key found for this signature in database
GPG key ID: D8365C3D36B77D90
3 changed files with 40 additions and 8 deletions

View file

@ -60,6 +60,8 @@ Usage
bin/console user add [<name> [<nickname> [<email> [<language>]]]] [-h|--help|-?] [-v] bin/console user add [<name> [<nickname> [<email> [<language>]]]] [-h|--help|-?] [-v]
bin/console user allow [<nickname>] [-h|--help|-?] [-v] bin/console user allow [<nickname>] [-h|--help|-?] [-v]
bin/console user deny [<nickname>] [-h|--help|-?] [-v] bin/console user deny [<nickname>] [-h|--help|-?] [-v]
bin/console user block [<nickname>] [-h|--help|-?] [-v]
bin/console user unblock [<nickname>] [-h|--help|-?] [-v]
Description Description
Modify user settings per console commands. Modify user settings per console commands.
@ -108,6 +110,10 @@ HELP;
return $this->pendingUser(true); return $this->pendingUser(true);
case 'deny': case 'deny':
return $this->pendingUser(false); return $this->pendingUser(false);
case 'block':
return $this->blockUser(true);
case 'unblock':
return $this->blockUser(false);
default: default:
throw new \Asika\SimpleConsole\CommandArgsException('Wrong command.'); throw new \Asika\SimpleConsole\CommandArgsException('Wrong command.');
} }
@ -210,7 +216,7 @@ HELP;
* @return bool True, if allow was successful * @return bool True, if allow was successful
* @throws \Friendica\Network\HTTPException\InternalServerErrorException * @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/ */
public function pendingUser(bool $allow = true) private function pendingUser(bool $allow = true)
{ {
$nick = $this->getArgument(1); $nick = $this->getArgument(1);
@ -234,4 +240,32 @@ HELP;
return ($allow) ? UserModel::allow($pending['hash']) : UserModel::deny($pending['hash']); return ($allow) ? UserModel::allow($pending['hash']) : UserModel::deny($pending['hash']);
} }
/**
* Blocks/unblocks a user
*
* @param bool $block True, if the given user should get blocked
*
* @return bool True, if the command was successful
* @throws \Exception
*/
private function blockUser(bool $block = true)
{
$nick = $this->getArgument(1);
if (!$nick) {
$this->out($this->l10n->t('Enter user nickname: '));
$nick = CliPrompt::prompt();
if (empty($nick)) {
throw new RuntimeException('A nick name must be set.');
}
}
$user = $this->dba->selectFirst('user', ['uid'], ['nickname' => $nick]);
if (empty($user)) {
throw new RuntimeException($this->l10n->t('User not found'));
}
return $block ? UserModel::block($user['uid'] ?? 0) : UserModel::block($user['uid'] ?? 0, false);
}
} }

View file

@ -894,7 +894,7 @@ class User
*/ */
public static function block(int $uid, bool $block = true) public static function block(int $uid, bool $block = true)
{ {
return DBA::update('user', ['blocked' => 0], ['uid' => $uid]); return DBA::update('user', ['blocked' => $block], ['uid' => $uid]);
} }
/** /**
@ -1150,11 +1150,11 @@ class User
} }
/** /**
* @param object $uid user to remove * @param int $uid user to remove
* @return bool * @return bool
* @throws InternalServerErrorException * @throws InternalServerErrorException
*/ */
public static function remove($uid) public static function remove(int $uid)
{ {
if (!$uid) { if (!$uid) {
return false; return false;

View file

@ -130,14 +130,12 @@ class Users extends BaseAdmin
break; break;
case 'block': case 'block':
parent::checkFormSecurityTokenRedirectOnError('/admin/users', 'admin_users', 't'); parent::checkFormSecurityTokenRedirectOnError('/admin/users', 'admin_users', 't');
// @TODO Move this to Model\User:block([$uid]); User::block($uid);
DBA::update('user', ['blocked' => 1], ['uid' => $uid]);
notice(DI::l10n()->t('User "%s" blocked', $user['username'])); notice(DI::l10n()->t('User "%s" blocked', $user['username']));
break; break;
case 'unblock': case 'unblock':
parent::checkFormSecurityTokenRedirectOnError('/admin/users', 'admin_users', 't'); parent::checkFormSecurityTokenRedirectOnError('/admin/users', 'admin_users', 't');
// @TODO Move this to Model\User:unblock([$uid]); User::block($uid, false);
DBA::update('user', ['blocked' => 0], ['uid' => $uid]);
notice(DI::l10n()->t('User "%s" unblocked', $user['username'])); notice(DI::l10n()->t('User "%s" unblocked', $user['username']));
break; break;
} }