szurubooru/src/Api/Jobs/UserJobs/EditUserEmailJob.php

83 lines
1.9 KiB
PHP
Raw Normal View History

2014-05-04 13:39:00 +02:00
<?php
class EditUserEmailJob extends AbstractJob
2014-05-04 13:39:00 +02:00
{
protected $userRetriever;
public function __construct()
{
$this->userRetriever = new UserRetriever($this);
}
2014-05-04 13:39:00 +02:00
public function execute()
{
2014-05-15 10:32:53 +02:00
if (Core::getConfig()->registration->needEmailForRegistering)
if (!$this->hasArgument(JobArgs::ARG_NEW_EMAIL) or empty($this->getArgument(JobArgs::ARG_NEW_EMAIL)))
2014-05-04 14:57:44 +02:00
throw new SimpleException('E-mail address is required - you will be sent confirmation e-mail.');
$user = $this->userRetriever->retrieve();
$newEmail = $this->getArgument(JobArgs::ARG_NEW_EMAIL);
2014-05-04 13:39:00 +02:00
2014-05-07 09:26:04 +02:00
$oldEmail = $user->getConfirmedEmail();
2014-05-04 13:39:00 +02:00
if ($oldEmail == $newEmail)
return $user;
2014-05-07 09:26:04 +02:00
$user->setUnconfirmedEmail($newEmail);
$user->setConfirmedEmail(null);
2014-05-04 13:39:00 +02:00
if ($this->getContext() == self::CONTEXT_NORMAL)
2014-05-07 09:26:04 +02:00
{
UserModel::save($user);
2014-05-07 09:26:04 +02:00
self::observeSave($user);
}
2014-05-04 13:39:00 +02:00
2014-05-04 19:23:09 +02:00
Logger::log('{user} changed {subject}\'s e-mail to {mail}', [
2014-05-04 13:39:00 +02:00
'user' => TextHelper::reprUser(Auth::getCurrentUser()),
'subject' => TextHelper::reprUser($user),
'mail' => $newEmail]);
return $user;
}
2014-05-07 09:26:04 +02:00
public static function observeSave($user)
{
if (Access::check(new Privilege(Privilege::EditUserEmailNoConfirm), $user))
2014-05-07 09:26:04 +02:00
{
$user->confirmEmail();
}
else
{
if (!empty($user->getUnconfirmedEmail()))
ActivateUserEmailJob::sendEmail($user);
}
}
public function getRequiredArguments()
2014-05-12 10:31:34 +02:00
{
return JobArgs::Conjunction(
$this->userRetriever->getRequiredArguments(),
JobArgs::ARG_NEW_EMAIL);
2014-05-12 10:31:34 +02:00
}
public function getRequiredMainPrivilege()
2014-05-04 13:39:00 +02:00
{
return $this->getContext() == self::CONTEXT_BATCH_ADD
? Privilege::RegisterAccount
: Privilege::EditUserEmail;
}
public function getRequiredSubPrivileges()
{
return Access::getIdentity($this->userRetriever->retrieve());
}
public function isAuthenticationRequired()
{
return false;
}
public function isConfirmedEmailRequired()
{
return false;
2014-05-04 13:39:00 +02:00
}
}