2014-05-04 13:39:00 +02:00
|
|
|
<?php
|
2014-05-06 19:39:41 +02:00
|
|
|
class EditUserNameJob extends AbstractUserJob
|
2014-05-04 13:39:00 +02:00
|
|
|
{
|
2014-05-06 19:39:41 +02:00
|
|
|
public function isSatisfied()
|
|
|
|
{
|
2014-05-12 00:13:18 +02:00
|
|
|
return $this->hasArgument(JobArgs::ARG_NEW_USER_NAME);
|
2014-05-06 19:39:41 +02:00
|
|
|
}
|
|
|
|
|
2014-05-04 13:39:00 +02:00
|
|
|
public function execute()
|
|
|
|
{
|
|
|
|
$user = $this->user;
|
2014-05-12 00:13:18 +02:00
|
|
|
$newName = $this->getArgument(JobArgs::ARG_NEW_USER_NAME);
|
2014-05-04 13:39:00 +02:00
|
|
|
|
2014-05-04 20:09:03 +02:00
|
|
|
$oldName = $user->getName();
|
2014-05-04 13:39:00 +02:00
|
|
|
if ($oldName == $newName)
|
|
|
|
return $user;
|
|
|
|
|
2014-05-04 20:09:03 +02:00
|
|
|
$user->setName($newName);
|
2014-05-04 13:39:00 +02:00
|
|
|
|
2014-05-06 19:39:41 +02:00
|
|
|
if ($this->getContext() == self::CONTEXT_NORMAL)
|
2014-05-04 17:53:40 +02:00
|
|
|
UserModel::save($user);
|
2014-05-04 13:39:00 +02:00
|
|
|
|
2014-05-04 19:23:09 +02:00
|
|
|
Logger::log('{user} renamed {old} to {new}', [
|
2014-05-04 13:39:00 +02:00
|
|
|
'user' => TextHelper::reprUser(Auth::getCurrentUser()),
|
|
|
|
'old' => TextHelper::reprUser($oldName),
|
|
|
|
'new' => TextHelper::reprUser($newName)]);
|
|
|
|
|
|
|
|
return $user;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function requiresPrivilege()
|
|
|
|
{
|
2014-05-04 16:27:15 +02:00
|
|
|
return new Privilege(
|
2014-05-07 00:34:02 +02:00
|
|
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
|
|
? Privilege::RegisterAccount
|
|
|
|
: Privilege::ChangeUserName,
|
2014-05-04 16:27:15 +02:00
|
|
|
Access::getIdentity($this->user));
|
2014-05-04 13:39:00 +02:00
|
|
|
}
|
|
|
|
}
|