- Jobs specify main privilege and sub privileges separately Rationale: increase maintenance, restrict what can be done runtime - Renamed ChangeUser* to EditUser* (consistency with EditPost*) - Simplified enum names and configuration reading - IJob interface members must be explicitly implemented Rationale: reduce chances of forgetting something, or typos in inherited method names - Invalid privileges names in configuration yield exceptions
56 lines
1.1 KiB
PHP
56 lines
1.1 KiB
PHP
<?php
|
|
class EditUserSettingsJob extends AbstractJob
|
|
{
|
|
protected $userRetriever;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->userRetriever = new UserRetriever($this);
|
|
}
|
|
|
|
public function execute()
|
|
{
|
|
$newSettings = $this->getArgument(JobArgs::ARG_NEW_SETTINGS);
|
|
|
|
if (!is_array($newSettings))
|
|
throw new SimpleException('Expected array');
|
|
|
|
$user = $this->userRetriever->retrieve();
|
|
foreach ($newSettings as $key => $value)
|
|
{
|
|
$user->getSettings()->set($key, $value);
|
|
}
|
|
|
|
if ($user->getAccessRank()->toInteger() == AccessRank::Anonymous)
|
|
return $user;
|
|
|
|
return UserModel::save($user);
|
|
}
|
|
|
|
public function getRequiredArguments()
|
|
{
|
|
return JobArgs::Conjunction(
|
|
$this->userRetriever->getRequiredArguments(),
|
|
JobArgs::ARG_NEW_SETTINGS);
|
|
}
|
|
|
|
public function getRequiredMainPrivilege()
|
|
{
|
|
return Privilege::EditUserSettings;
|
|
}
|
|
|
|
public function getRequiredSubPrivileges()
|
|
{
|
|
return Access::getIdentity($this->userRetriever->retrieve());
|
|
}
|
|
|
|
public function isAuthenticationRequired()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
public function isConfirmedEmailRequired()
|
|
{
|
|
return false;
|
|
}
|
|
}
|