Added argument checking system
This commit is contained in:
parent
0e6ed74682
commit
484adbbf49
73 changed files with 1072 additions and 261 deletions
|
@ -14,22 +14,22 @@ abstract class AbstractJob
|
||||||
|
|
||||||
public abstract function execute();
|
public abstract function execute();
|
||||||
|
|
||||||
public function isSatisfied()
|
public function getRequiredArguments()
|
||||||
{
|
{
|
||||||
return true;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
<?php
|
|
||||||
abstract class AbstractPostJob extends AbstractJob
|
|
||||||
{
|
|
||||||
protected $post;
|
|
||||||
|
|
||||||
public function prepare()
|
|
||||||
{
|
|
||||||
if ($this->hasArgument(JobArgs::ARG_POST_ENTITY))
|
|
||||||
{
|
|
||||||
$this->post = $this->getArgument(JobArgs::ARG_POST_ENTITY);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$postId = $this->getArgument(JobArgs::ARG_POST_ID);
|
|
||||||
$this->post = PostModel::getByIdOrName($postId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -9,8 +9,7 @@ final class Api
|
||||||
{
|
{
|
||||||
$job->setArguments($jobArgs);
|
$job->setArguments($jobArgs);
|
||||||
|
|
||||||
if (!$job->isSatisfied())
|
self::checkArguments($job);
|
||||||
throw new ApiJobUnsatisfiedException($job);
|
|
||||||
|
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
|
|
||||||
|
@ -20,25 +19,6 @@ final class Api
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function checkPrivileges(AbstractJob $job)
|
|
||||||
{
|
|
||||||
if ($job->requiresAuthentication())
|
|
||||||
Access::assertAuthentication();
|
|
||||||
|
|
||||||
if ($job->requiresConfirmedEmail())
|
|
||||||
Access::assertEmailConfirmation();
|
|
||||||
|
|
||||||
$privileges = $job->requiresPrivilege();
|
|
||||||
if ($privileges !== false)
|
|
||||||
{
|
|
||||||
if (!is_array($privileges))
|
|
||||||
$privileges = [$privileges];
|
|
||||||
|
|
||||||
foreach ($privileges as $privilege)
|
|
||||||
Access::assert($privilege);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function runMultiple($jobs)
|
public static function runMultiple($jobs)
|
||||||
{
|
{
|
||||||
$statuses = [];
|
$statuses = [];
|
||||||
|
@ -52,4 +32,63 @@ final class Api
|
||||||
});
|
});
|
||||||
return $statuses;
|
return $statuses;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function checkArguments(AbstractJob $job)
|
||||||
|
{
|
||||||
|
self::runArgumentCheck($job, $job->getRequiredArguments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function checkPrivileges(AbstractJob $job)
|
||||||
|
{
|
||||||
|
if ($job->isAuthenticationRequired())
|
||||||
|
Access::assertAuthentication();
|
||||||
|
|
||||||
|
if ($job->isConfirmedEmailRequired())
|
||||||
|
Access::assertEmailConfirmation();
|
||||||
|
|
||||||
|
$privileges = $job->getRequiredPrivileges();
|
||||||
|
if ($privileges !== false)
|
||||||
|
{
|
||||||
|
if (!is_array($privileges))
|
||||||
|
$privileges = [$privileges];
|
||||||
|
|
||||||
|
foreach ($privileges as $privilege)
|
||||||
|
Access::assert($privilege);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static function runArgumentCheck($job, $item)
|
||||||
|
{
|
||||||
|
if (is_array($item))
|
||||||
|
throw new Exception('Argument definition cannot be an array.');
|
||||||
|
elseif ($item instanceof JobArgsNestedStruct)
|
||||||
|
{
|
||||||
|
if ($item instanceof JobArgsAlternative)
|
||||||
|
{
|
||||||
|
$success = false;
|
||||||
|
foreach ($item->args as $subItem)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
self::runArgumentCheck($job, $subItem);
|
||||||
|
$success = true;
|
||||||
|
}
|
||||||
|
catch (ApiJobUnsatisfiedException $e)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!$success)
|
||||||
|
throw new ApiJobUnsatisfiedException($job);
|
||||||
|
}
|
||||||
|
elseif ($item instanceof JobArgsConjunction)
|
||||||
|
{
|
||||||
|
foreach ($item->args as $subItem)
|
||||||
|
!self::runArgumentCheck($job, $subItem);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elseif ($item === null)
|
||||||
|
return;
|
||||||
|
elseif (!$job->hasArgument($item))
|
||||||
|
throw new ApiJobUnsatisfiedException($job, $item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
<?php
|
<?php
|
||||||
class ApiJobUnsatisfiedException extends SimpleException
|
class ApiJobUnsatisfiedException extends SimpleException
|
||||||
{
|
{
|
||||||
public function __construct(AbstractJob $job)
|
public function __construct(AbstractJob $job, $arg = null)
|
||||||
{
|
{
|
||||||
parent::__construct(get_class($job) . ' cannot be run due to unsatisfied execution conditions.');
|
parent::__construct('%s cannot be run due to unsatisfied execution conditions (%s).',
|
||||||
|
get_class($job),
|
||||||
|
$arg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,8 +8,9 @@ class JobArgs
|
||||||
const ARG_TOKEN = 'token';
|
const ARG_TOKEN = 'token';
|
||||||
|
|
||||||
const ARG_USER_ENTITY = 'user';
|
const ARG_USER_ENTITY = 'user';
|
||||||
const ARG_USER_ID = 'user-id';
|
#const ARG_USER_ID = 'user-id';
|
||||||
const ARG_USER_NAME = 'user-name';
|
const ARG_USER_NAME = 'user-name';
|
||||||
|
const ARG_USER_EMAIL = 'user-email';
|
||||||
|
|
||||||
const ARG_POST_ENTITY = 'post';
|
const ARG_POST_ENTITY = 'post';
|
||||||
const ARG_POST_ID = 'post-id';
|
const ARG_POST_ID = 'post-id';
|
||||||
|
@ -18,6 +19,7 @@ class JobArgs
|
||||||
const ARG_TAG_NAME = 'tag-name';
|
const ARG_TAG_NAME = 'tag-name';
|
||||||
const ARG_TAG_NAMES = 'tag-names';
|
const ARG_TAG_NAMES = 'tag-names';
|
||||||
|
|
||||||
|
const ARG_COMMENT_ENTITY = 'comment';
|
||||||
const ARG_COMMENT_ID = 'comment-id';
|
const ARG_COMMENT_ID = 'comment-id';
|
||||||
|
|
||||||
const ARG_LOG_ID = 'log-id';
|
const ARG_LOG_ID = 'log-id';
|
||||||
|
@ -44,4 +46,19 @@ class JobArgs
|
||||||
const ARG_NEW_EMAIL = 'new-email';
|
const ARG_NEW_EMAIL = 'new-email';
|
||||||
const ARG_NEW_USER_NAME = 'new-user-name';
|
const ARG_NEW_USER_NAME = 'new-user-name';
|
||||||
const ARG_NEW_PASSWORD = 'new-password';
|
const ARG_NEW_PASSWORD = 'new-password';
|
||||||
|
|
||||||
|
public static function Alternative()
|
||||||
|
{
|
||||||
|
return JobArgsAlternative::factory(func_get_args());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function Conjunction()
|
||||||
|
{
|
||||||
|
return JobArgsConjunction::factory(func_get_args());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function Optional()
|
||||||
|
{
|
||||||
|
return JobArgsOptional::factory(func_get_args());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
25
src/Api/JobArgsAlternative.php
Normal file
25
src/Api/JobArgsAlternative.php
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
<?php
|
||||||
|
class JobArgsAlternative extends JobArgsNestedStruct
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* simplifies the structure as much as possible
|
||||||
|
* and returns new class or existing args.
|
||||||
|
*/
|
||||||
|
public static function factory(array $args)
|
||||||
|
{
|
||||||
|
$finalArgs = [];
|
||||||
|
|
||||||
|
foreach ($args as $arg)
|
||||||
|
{
|
||||||
|
if ($arg instanceof self)
|
||||||
|
$finalArgs = array_merge($finalArgs, $arg->args);
|
||||||
|
elseif ($arg !== null)
|
||||||
|
$finalArgs []= $arg;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($finalArgs) == 1)
|
||||||
|
return $finalArgs[0];
|
||||||
|
else
|
||||||
|
return new self($finalArgs);
|
||||||
|
}
|
||||||
|
}
|
25
src/Api/JobArgsConjunction.php
Normal file
25
src/Api/JobArgsConjunction.php
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
<?php
|
||||||
|
class JobArgsConjunction extends JobArgsNestedStruct
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Simplifies the structure as much as possible
|
||||||
|
* and returns new class or existing args.
|
||||||
|
*/
|
||||||
|
public static function factory(array $args)
|
||||||
|
{
|
||||||
|
$finalArgs = [];
|
||||||
|
|
||||||
|
foreach ($args as $arg)
|
||||||
|
{
|
||||||
|
if ($arg instanceof self)
|
||||||
|
$finalArgs = array_merge($finalArgs, $arg->args);
|
||||||
|
elseif ($arg !== null)
|
||||||
|
$finalArgs []= $arg;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($finalArgs) == 1)
|
||||||
|
return $finalArgs[0];
|
||||||
|
else
|
||||||
|
return new self($finalArgs);
|
||||||
|
}
|
||||||
|
}
|
19
src/Api/JobArgsNestedStruct.php
Normal file
19
src/Api/JobArgsNestedStruct.php
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
<?php
|
||||||
|
class JobArgsNestedStruct
|
||||||
|
{
|
||||||
|
public $args;
|
||||||
|
|
||||||
|
protected function __construct(array $args)
|
||||||
|
{
|
||||||
|
usort($args, function($arg1, $arg2)
|
||||||
|
{
|
||||||
|
return strnatcasecmp(serialize($arg1), serialize($arg2));
|
||||||
|
});
|
||||||
|
$this->args = $args;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function factory(array $args)
|
||||||
|
{
|
||||||
|
throw new BadMethodCallException('Not implemented');
|
||||||
|
}
|
||||||
|
}
|
20
src/Api/JobArgsOptional.php
Normal file
20
src/Api/JobArgsOptional.php
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
class JobArgsOptional extends JobArgsNestedStruct
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Simplifies the structure as much as possible
|
||||||
|
* and returns new class or existing args.
|
||||||
|
*/
|
||||||
|
public static function factory(array $args)
|
||||||
|
{
|
||||||
|
$args = array_filter($args, function($arg)
|
||||||
|
{
|
||||||
|
return $arg !== null;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (count($args) == 0)
|
||||||
|
return null;
|
||||||
|
else
|
||||||
|
return new self($args);
|
||||||
|
}
|
||||||
|
}
|
|
@ -5,7 +5,12 @@ class ActivateUserEmailJob extends AbstractJob
|
||||||
{
|
{
|
||||||
if (!$this->hasArgument(JobArgs::ARG_TOKEN))
|
if (!$this->hasArgument(JobArgs::ARG_TOKEN))
|
||||||
{
|
{
|
||||||
$user = UserModel::getByNameOrEmail($this->getArgument(JobArgs::ARG_USER_NAME));
|
if ($this->hasArgument(JobArgs::ARG_USER_ENTITY))
|
||||||
|
$user = $this->getArgument(JobArgs::ARG_USER_ENTITY);
|
||||||
|
elseif ($this->hasArgument(JobArgs::ARG_USER_NAME))
|
||||||
|
$user = UserModel::getByName($this->getArgument(JobArgs::ARG_USER_NAME));
|
||||||
|
else
|
||||||
|
$user = UserModel::getByEmail($this->getArgument(JobArgs::ARG_USER_EMAIL));
|
||||||
|
|
||||||
if (empty($user->getUnconfirmedEmail()))
|
if (empty($user->getUnconfirmedEmail()))
|
||||||
{
|
{
|
||||||
|
@ -38,6 +43,16 @@ class ActivateUserEmailJob extends AbstractJob
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_TOKEN,
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_USER_ENTITY,
|
||||||
|
JobArgs::ARG_USER_EMAIL,
|
||||||
|
JobArgs::ARG_USER_NAME));
|
||||||
|
}
|
||||||
|
|
||||||
public static function sendEmail($user)
|
public static function sendEmail($user)
|
||||||
{
|
{
|
||||||
$regConfig = getConfig()->registration;
|
$regConfig = getConfig()->registration;
|
||||||
|
|
|
@ -44,12 +44,17 @@ class AddPostJob extends AbstractJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Optional(JobArgs::ARG_ANONYMOUS);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::AddPost);
|
return new Privilege(Privilege::AddPost);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return getConfig()->registration->needEmailForUploading;
|
return getConfig()->registration->needEmailForUploading;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,7 +46,12 @@ class AddUserJob extends AbstractJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::RegisterAccount);
|
return new Privilege(Privilege::RegisterAccount);
|
||||||
}
|
}
|
||||||
|
|
29
src/Api/Jobs/CommentJobs/AbstractCommentJob.php
Normal file
29
src/Api/Jobs/CommentJobs/AbstractCommentJob.php
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
<?php
|
||||||
|
abstract class AbstractCommentJob extends AbstractJob
|
||||||
|
{
|
||||||
|
protected $comment;
|
||||||
|
|
||||||
|
public function prepare()
|
||||||
|
{
|
||||||
|
if ($this->hasArgument(JobArgs::ARG_COMMENT_ENTITY))
|
||||||
|
{
|
||||||
|
$this->comment = $this->getArgument(JobArgs::ARG_COMMENT_ENTITY);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$commentId = $this->getArgument(JobArgs::ARG_COMMENT_ID);
|
||||||
|
$this->comment = CommentModel::getById($commentId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_COMMENT_ID,
|
||||||
|
JobArgs::ARG_COMMENT_ENTITY),
|
||||||
|
$this->getRequiredSubArguments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract function getRequiredSubArguments();
|
||||||
|
}
|
|
@ -1,13 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class DeleteCommentJob extends AbstractJob
|
class DeleteCommentJob extends AbstractCommentJob
|
||||||
{
|
{
|
||||||
protected $comment;
|
|
||||||
|
|
||||||
public function prepare()
|
|
||||||
{
|
|
||||||
$this->comment = CommentModel::getById($this->getArgument(JobArgs::ARG_COMMENT_ID));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->comment->getPost();
|
$post = $this->comment->getPost();
|
||||||
|
@ -19,19 +12,24 @@ class DeleteCommentJob extends AbstractJob
|
||||||
'post' => TextHelper::reprPost($post)]);
|
'post' => TextHelper::reprPost($post)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::DeleteComment,
|
Privilege::DeleteComment,
|
||||||
Access::getIdentity($this->comment->getCommenter()));
|
Access::getIdentity($this->comment->getCommenter()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
|
@ -1,13 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditCommentJob extends AbstractJob
|
class EditCommentJob extends AbstractCommentJob
|
||||||
{
|
{
|
||||||
protected $comment;
|
|
||||||
|
|
||||||
public function prepare()
|
|
||||||
{
|
|
||||||
$this->comment = CommentModel::getById($this->getArgument(JobArgs::ARG_COMMENT_ID));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$comment = $this->comment;
|
$comment = $this->comment;
|
||||||
|
@ -23,19 +16,24 @@ class EditCommentJob extends AbstractJob
|
||||||
return $comment;
|
return $comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_TEXT;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::EditComment,
|
Privilege::EditComment,
|
||||||
Access::getIdentity($this->comment->getCommenter()));
|
Access::getIdentity($this->comment->getCommenter()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
|
@ -5,6 +5,9 @@ class GetPostContentJob extends AbstractJob
|
||||||
|
|
||||||
public function prepare()
|
public function prepare()
|
||||||
{
|
{
|
||||||
|
if ($this->hasArgument(JobArgs::ARG_POST_ENTITY))
|
||||||
|
$this->post = $this->getArgument(JobArgs::ARG_POST_ENTITY);
|
||||||
|
else
|
||||||
$this->post = PostModel::getByName($this->getArgument(JobArgs::ARG_POST_NAME));
|
$this->post = PostModel::getByName($this->getArgument(JobArgs::ARG_POST_NAME));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,7 +33,14 @@ class GetPostContentJob extends AbstractJob
|
||||||
return new ApiFileOutput($path, $fileName);
|
return new ApiFileOutput($path, $fileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_POST_NAME,
|
||||||
|
JobArgs::ARG_POST_ENTITY);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
$privileges = [];
|
$privileges = [];
|
||||||
|
|
|
@ -3,7 +3,14 @@ class GetPostThumbJob extends AbstractJob
|
||||||
{
|
{
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
|
if ($this->getArgument(JobArgs::ARG_POST_NAME))
|
||||||
$name = $this->getArgument(JobArgs::ARG_POST_NAME);
|
$name = $this->getArgument(JobArgs::ARG_POST_NAME);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$post = PostModel::getByName($this->getArgument(JobArgs::ARG_POST_ENTITY));
|
||||||
|
$name = $post->getName();
|
||||||
|
}
|
||||||
|
|
||||||
$width = $this->hasArgument(JobArgs::ARG_THUMB_WIDTH) ? $this->getArgument(JobArgs::ARG_THUMB_WIDTH) : null;
|
$width = $this->hasArgument(JobArgs::ARG_THUMB_WIDTH) ? $this->getArgument(JobArgs::ARG_THUMB_WIDTH) : null;
|
||||||
$height = $this->hasArgument(JobArgs::ARG_THUMB_HEIGHT) ? $this->getArgument(JobArgs::ARG_THUMB_HEIGHT) : null;
|
$height = $this->hasArgument(JobArgs::ARG_THUMB_HEIGHT) ? $this->getArgument(JobArgs::ARG_THUMB_HEIGHT) : null;
|
||||||
|
|
||||||
|
@ -13,7 +20,7 @@ class GetPostThumbJob extends AbstractJob
|
||||||
$path = PostModel::getThumbDefaultPath($name, $width, $height);
|
$path = PostModel::getThumbDefaultPath($name, $width, $height);
|
||||||
if (!file_exists($path))
|
if (!file_exists($path))
|
||||||
{
|
{
|
||||||
$post = PostModel::getByIdOrName($name);
|
$post = PostModel::getByName($name);
|
||||||
|
|
||||||
if ($post->isHidden())
|
if ($post->isHidden())
|
||||||
Access::assert(new Privilege(Privilege::ListPosts, 'hidden'));
|
Access::assert(new Privilege(Privilege::ListPosts, 'hidden'));
|
||||||
|
@ -35,7 +42,17 @@ class GetPostThumbJob extends AbstractJob
|
||||||
return new ApiFileOutput($path, 'thumbnail.jpg');
|
return new ApiFileOutput($path, 'thumbnail.jpg');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_POST_ENTITY,
|
||||||
|
JobArgs::ARG_POST_NAME),
|
||||||
|
JobArgs::Optional(JobArgs::ARG_THUMB_WIDTH),
|
||||||
|
JobArgs::Optional(JobArgs::ARG_THUMB_HEIGHT));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
//manually enforced in execute when post is retrieved
|
//manually enforced in execute when post is retrieved
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -17,7 +17,12 @@ class ListLogsJob extends AbstractJob
|
||||||
return $logs;
|
return $logs;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::ListLogs);
|
return new Privilege(Privilege::ListLogs);
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,14 @@ class MergeTagsJob extends AbstractJob
|
||||||
'target' => TextHelper::reprTag($targetTag)]);
|
'target' => TextHelper::reprTag($targetTag)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_SOURCE_TAG_NAME,
|
||||||
|
JobArgs::ARG_TARGET_TAG_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::MergeTags);
|
return new Privilege(Privilege::MergeTags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,4 +30,13 @@ abstract class AbstractPageJob extends AbstractJob
|
||||||
$ret->pageCount = $pageCount;
|
$ret->pageCount = $pageCount;
|
||||||
return $ret;
|
return $ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_PAGE_NUMBER,
|
||||||
|
$this->getRequiredSubArguments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract function getRequiredSubArguments();
|
||||||
}
|
}
|
|
@ -39,7 +39,14 @@ class GetLogJob extends AbstractPageJob
|
||||||
return intval(getConfig()->browsing->logsPerPage);
|
return intval(getConfig()->browsing->logsPerPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_LOG_ID,
|
||||||
|
JobArgs::ARG_QUERY);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::ViewLog);
|
return new Privilege(Privilege::ViewLog);
|
||||||
}
|
}
|
|
@ -25,7 +25,12 @@ class ListCommentsJob extends AbstractPageJob
|
||||||
return intval(getConfig()->comments->commentsPerPage);
|
return intval(getConfig()->comments->commentsPerPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::ListComments);
|
return new Privilege(Privilege::ListComments);
|
||||||
}
|
}
|
|
@ -20,7 +20,12 @@ class ListPostsJob extends AbstractPageJob
|
||||||
return intval(getConfig()->browsing->postsPerPage);
|
return intval(getConfig()->browsing->postsPerPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_QUERY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::ListPosts);
|
return new Privilege(Privilege::ListPosts);
|
||||||
}
|
}
|
|
@ -20,4 +20,12 @@ class ListRelatedTagsJob extends ListTagsJob
|
||||||
{
|
{
|
||||||
return intval(getConfig()->browsing->tagsRelated);
|
return intval(getConfig()->browsing->tagsRelated);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
parent::getRequiredArguments(),
|
||||||
|
Jobargs::ARG_TAG_NAME,
|
||||||
|
JobArgs::Optional(JobArgs::ARG_TAG_NAMES));
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -18,7 +18,12 @@ class ListTagsJob extends AbstractPageJob
|
||||||
return intval(getConfig()->browsing->tagsPerPage);
|
return intval(getConfig()->browsing->tagsPerPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_QUERY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::ListTags);
|
return new Privilege(Privilege::ListTags);
|
||||||
}
|
}
|
|
@ -18,7 +18,12 @@ class ListUsersJob extends AbstractPageJob
|
||||||
return intval(getConfig()->browsing->usersPerPage);
|
return intval(getConfig()->browsing->usersPerPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_QUERY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::ListUsers);
|
return new Privilege(Privilege::ListUsers);
|
||||||
}
|
}
|
|
@ -5,7 +5,12 @@ class PasswordResetJob extends AbstractJob
|
||||||
{
|
{
|
||||||
if (!$this->hasArgument(JobArgs::ARG_TOKEN))
|
if (!$this->hasArgument(JobArgs::ARG_TOKEN))
|
||||||
{
|
{
|
||||||
|
if ($this->hasArgument(JobArgs::ARG_USER_NAME))
|
||||||
$user = UserModel::getByNameOrEmail($this->getArgument(JobArgs::ARG_USER_NAME));
|
$user = UserModel::getByNameOrEmail($this->getArgument(JobArgs::ARG_USER_NAME));
|
||||||
|
elseif ($this->hasArgument(JobArgs::ARG_USER_EMAIL))
|
||||||
|
$user = UserModel::getByNameOrEmail($this->getArgument(JobArgs::ARG_USER_EMAIL));
|
||||||
|
else
|
||||||
|
$user = $this->getArgument(JobArgs::ARG_USER_ENTITTY);
|
||||||
|
|
||||||
if (empty($user->getConfirmedEmail()))
|
if (empty($user->getConfirmedEmail()))
|
||||||
throw new SimpleException('This user has no e-mail confirmed; password reset cannot proceed');
|
throw new SimpleException('This user has no e-mail confirmed; password reset cannot proceed');
|
||||||
|
@ -42,6 +47,15 @@ class PasswordResetJob extends AbstractJob
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_USER_NAME,
|
||||||
|
JobArgs::ARG_USER_EMAIL,
|
||||||
|
JobArgs::ARG_USER_ENTITY,
|
||||||
|
JobArgs::ARG_TOKEN);
|
||||||
|
}
|
||||||
|
|
||||||
public static function sendEmail($user)
|
public static function sendEmail($user)
|
||||||
{
|
{
|
||||||
$regConfig = getConfig()->registration;
|
$regConfig = getConfig()->registration;
|
||||||
|
|
35
src/Api/Jobs/PostJobs/AbstractPostJob.php
Normal file
35
src/Api/Jobs/PostJobs/AbstractPostJob.php
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
<?php
|
||||||
|
abstract class AbstractPostJob extends AbstractJob
|
||||||
|
{
|
||||||
|
protected $post;
|
||||||
|
|
||||||
|
public function prepare()
|
||||||
|
{
|
||||||
|
if ($this->hasArgument(JobArgs::ARG_POST_ENTITY))
|
||||||
|
{
|
||||||
|
$this->post = $this->getArgument(JobArgs::ARG_POST_ENTITY);
|
||||||
|
}
|
||||||
|
elseif ($this->hasArgument(JobArgs::ARG_POST_ID))
|
||||||
|
{
|
||||||
|
$postId = $this->getArgument(JobArgs::ARG_POST_ID);
|
||||||
|
$this->post = PostModel::getById($postId);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$postName = $this->getArgument(JobArgs::ARG_POST_NAME);
|
||||||
|
$this->post = PostModel::getByName($postName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_POST_ID,
|
||||||
|
JobArgs::ARG_POST_NAME,
|
||||||
|
JobArgs::ARG_POST_ENTITY),
|
||||||
|
$this->getRequiredSubArguments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract function getRequiredSubArguments();
|
||||||
|
}
|
|
@ -1,10 +1,10 @@
|
||||||
<?php
|
<?php
|
||||||
class AddCommentJob extends AbstractJob
|
class AddCommentJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
|
$post = $this->post;
|
||||||
$user = Auth::getCurrentUser();
|
$user = Auth::getCurrentUser();
|
||||||
$post = PostModel::getById($this->getArgument(JobArgs::ARG_POST_ID));
|
|
||||||
$text = $this->getArgument(JobArgs::ARG_NEW_TEXT);
|
$text = $this->getArgument(JobArgs::ARG_NEW_TEXT);
|
||||||
|
|
||||||
$comment = CommentModel::spawn();
|
$comment = CommentModel::spawn();
|
||||||
|
@ -21,17 +21,22 @@ class AddCommentJob extends AbstractJob
|
||||||
return $comment;
|
return $comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_TEXT;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::AddComment);
|
return new Privilege(Privilege::AddComment);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return getConfig()->registration->needEmailForCommenting;
|
return getConfig()->registration->needEmailForCommenting;
|
||||||
}
|
}
|
|
@ -12,19 +12,24 @@ class DeletePostJob extends AbstractPostJob
|
||||||
'post' => TextHelper::reprPost($post)]);
|
'post' => TextHelper::reprPost($post)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::DeletePost,
|
Privilege::DeletePost,
|
||||||
Access::getIdentity($this->post->getUploader()));
|
Access::getIdentity($this->post->getUploader()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
|
@ -1,12 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditPostContentJob extends AbstractPostJob
|
class EditPostContentJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_POST_CONTENT)
|
|
||||||
or $this->hasArgument(JobArgs::ARG_NEW_POST_CONTENT_URL);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
|
@ -32,7 +26,14 @@ class EditPostContentJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_NEW_POST_CONTENT,
|
||||||
|
JobArgs::ARG_NEW_POST_CONTENT_URL);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -43,7 +43,12 @@ class EditPostJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditPostRelationsJob extends AbstractPostJob
|
class EditPostRelationsJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_RELATED_POST_IDS);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
|
@ -37,7 +32,12 @@ class EditPostRelationsJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_RELATED_POST_IDS;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditPostSafetyJob extends AbstractPostJob
|
class EditPostSafetyJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_SAFETY);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
|
@ -28,7 +23,12 @@ class EditPostSafetyJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_SAFETY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditPostSourceJob extends AbstractPostJob
|
class EditPostSourceJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_SOURCE);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
|
@ -28,7 +23,12 @@ class EditPostSourceJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_SOURCE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditPostTagsJob extends AbstractPostJob
|
class EditPostTagsJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_TAG_NAMES);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
|
@ -45,7 +40,12 @@ class EditPostTagsJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_TAG_NAMES;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditPostThumbJob extends AbstractPostJob
|
class EditPostThumbJob extends AbstractPostJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_THUMB_CONTENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
|
@ -23,7 +18,12 @@ class EditPostThumbJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_THUMB_CONTENT;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -20,14 +20,19 @@ class FeaturePostJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Optional(JobArgs::ARG_ANONYMOUS);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::FeaturePost,
|
Privilege::FeaturePost,
|
||||||
Access::getIdentity($this->post->getUploader()));
|
Access::getIdentity($this->post->getUploader()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
|
@ -19,7 +19,12 @@ class FlagPostJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::FlagPost,
|
Privilege::FlagPost,
|
|
@ -10,7 +10,12 @@ class GetPostJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
$post = $this->post;
|
$post = $this->post;
|
||||||
$privileges = [];
|
$privileges = [];
|
|
@ -11,14 +11,19 @@ class ScorePostJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_POST_SCORE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::ScorePost,
|
Privilege::ScorePost,
|
||||||
Access::getIdentity($this->post->getUploader()));
|
Access::getIdentity($this->post->getUploader()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
|
@ -19,14 +19,19 @@ class TogglePostFavoriteJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_STATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::FavoritePost,
|
Privilege::FavoritePost,
|
||||||
Access::getIdentity($this->post->getUploader()));
|
Access::getIdentity($this->post->getUploader()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
|
@ -50,7 +50,14 @@ class TogglePostTagJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_TAG_NAME,
|
||||||
|
Jobargs::ARG_NEW_STATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::EditPostTags,
|
Privilege::EditPostTags,
|
|
@ -19,7 +19,12 @@ class TogglePostVisibilityJob extends AbstractPostJob
|
||||||
return $post;
|
return $post;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_STATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::HidePost,
|
Privilege::HidePost,
|
|
@ -26,17 +26,26 @@ class PreviewCommentJob extends AbstractJob
|
||||||
return $comment;
|
return $comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_NEW_TEXT,
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_COMMENT_ID,
|
||||||
|
JobArgs::ARG_POST_ID));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::AddComment);
|
return new Privilege(Privilege::AddComment);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresAuthentication()
|
public function isAuthenticationRequired()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresConfirmedEmail()
|
public function isConfirmedEmailRequired()
|
||||||
{
|
{
|
||||||
return getConfig()->registration->needEmailForCommenting;
|
return getConfig()->registration->needEmailForCommenting;
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,14 @@ class RenameTagsJob extends AbstractJob
|
||||||
'target' => TextHelper::reprTag($targetTag)]);
|
'target' => TextHelper::reprTag($targetTag)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_SOURCE_TAG_NAME,
|
||||||
|
JobArgs::ARG_TARGET_TAG_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::RenameTags);
|
return new Privilege(Privilege::RenameTags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,4 +15,16 @@ abstract class AbstractUserJob extends AbstractJob
|
||||||
$this->user = UserModel::getByNameOrEmail($userName);
|
$this->user = UserModel::getByNameOrEmail($userName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRequiredArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::Conjunction(
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_USER_NAME,
|
||||||
|
JobArgs::ARG_USER_EMAIL,
|
||||||
|
JobArgs::ARG_USER_ENTITY),
|
||||||
|
$this->getRequiredSubArguments());
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract function getRequiredSubArguments();
|
||||||
}
|
}
|
|
@ -13,7 +13,12 @@ class AcceptUserRegistrationJob extends AbstractUserJob
|
||||||
'subject' => TextHelper::reprUser($user)]);
|
'subject' => TextHelper::reprUser($user)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(Privilege::AcceptUserRegistration);
|
return new Privilege(Privilege::AcceptUserRegistration);
|
||||||
}
|
}
|
|
@ -13,7 +13,12 @@ class DeleteUserJob extends AbstractUserJob
|
||||||
'subject' => TextHelper::reprUser($name)]);
|
'subject' => TextHelper::reprUser($name)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::DeleteUser,
|
Privilege::DeleteUser,
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditUserAccessRankJob extends AbstractUserJob
|
class EditUserAccessRankJob extends AbstractUserJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_ACCESS_RANK);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$user = $this->user;
|
$user = $this->user;
|
||||||
|
@ -28,7 +23,12 @@ class EditUserAccessRankJob extends AbstractUserJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_ACCESS_RANK;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::ChangeUserAccessRank,
|
Privilege::ChangeUserAccessRank,
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditUserEmailJob extends AbstractUserJob
|
class EditUserEmailJob extends AbstractUserJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_EMAIL);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
if (getConfig()->registration->needEmailForRegistering)
|
if (getConfig()->registration->needEmailForRegistering)
|
||||||
|
@ -49,7 +44,12 @@ class EditUserEmailJob extends AbstractUserJob
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_EMAIL;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -65,7 +65,12 @@ class EditUserJob extends AbstractUserJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditUserNameJob extends AbstractUserJob
|
class EditUserNameJob extends AbstractUserJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_USER_NAME);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$user = $this->user;
|
$user = $this->user;
|
||||||
|
@ -28,7 +23,12 @@ class EditUserNameJob extends AbstractUserJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_USER_NAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -1,11 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
class EditUserPasswordJob extends AbstractUserJob
|
class EditUserPasswordJob extends AbstractUserJob
|
||||||
{
|
{
|
||||||
public function isSatisfied()
|
|
||||||
{
|
|
||||||
return $this->hasArgument(JobArgs::ARG_NEW_PASSWORD);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function execute()
|
public function execute()
|
||||||
{
|
{
|
||||||
$user = $this->user;
|
$user = $this->user;
|
||||||
|
@ -27,7 +22,12 @@ class EditUserPasswordJob extends AbstractUserJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_PASSWORD;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
$this->getContext() == self::CONTEXT_BATCH_ADD
|
$this->getContext() == self::CONTEXT_BATCH_ADD
|
|
@ -19,7 +19,12 @@ class FlagUserJob extends AbstractUserJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::FlagUser,
|
Privilege::FlagUser,
|
|
@ -6,7 +6,12 @@ class GetUserJob extends AbstractUserJob
|
||||||
return $this->user;
|
return $this->user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::ViewUser,
|
Privilege::ViewUser,
|
|
@ -22,7 +22,12 @@ class ToggleUserBanJob extends AbstractUserJob
|
||||||
return $user;
|
return $user;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function requiresPrivilege()
|
public function getRequiredSubArguments()
|
||||||
|
{
|
||||||
|
return JobArgs::ARG_NEW_STATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getRequiredPrivileges()
|
||||||
{
|
{
|
||||||
return new Privilege(
|
return new Privilege(
|
||||||
Privilege::BanUser,
|
Privilege::BanUser,
|
|
@ -17,13 +17,11 @@ class UserController
|
||||||
$context->transport->paginator = $ret;
|
$context->transport->paginator = $ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function genericView($name, $tab = 'favs', $page = 1)
|
public function genericView($identifier, $tab = 'favs', $page = 1)
|
||||||
{
|
{
|
||||||
$user = Api::run(
|
$user = Api::run(
|
||||||
new GetUserJob(),
|
new GetUserJob(),
|
||||||
[
|
$this->appendUserIdentifierArgument([], $identifier));
|
||||||
JobArgs::ARG_USER_NAME => $name,
|
|
||||||
]);
|
|
||||||
|
|
||||||
$flagged = in_array(TextHelper::reprUser($user), SessionHelper::get('flagged', []));
|
$flagged = in_array(TextHelper::reprUser($user), SessionHelper::get('flagged', []));
|
||||||
|
|
||||||
|
@ -69,9 +67,9 @@ class UserController
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function settingsAction($name)
|
public function settingsAction($identifier)
|
||||||
{
|
{
|
||||||
$this->genericView($name, 'settings');
|
$this->genericView($identifier, 'settings');
|
||||||
|
|
||||||
$user = getContext()->transport->user;
|
$user = getContext()->transport->user;
|
||||||
|
|
||||||
|
@ -97,9 +95,9 @@ class UserController
|
||||||
Messenger::message('Browsing settings updated!');
|
Messenger::message('Browsing settings updated!');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function editAction($name)
|
public function editAction($identifier)
|
||||||
{
|
{
|
||||||
$this->genericView($name, 'edit');
|
$this->genericView($identifier, 'edit');
|
||||||
$this->requirePasswordConfirmation();
|
$this->requirePasswordConfirmation();
|
||||||
|
|
||||||
if (InputHelper::get('password1') != InputHelper::get('password2'))
|
if (InputHelper::get('password1') != InputHelper::get('password2'))
|
||||||
|
@ -107,12 +105,12 @@ class UserController
|
||||||
|
|
||||||
$args =
|
$args =
|
||||||
[
|
[
|
||||||
JobArgs::ARG_USER_NAME => $name,
|
|
||||||
JobArgs::ARG_NEW_USER_NAME => InputHelper::get('name'),
|
JobArgs::ARG_NEW_USER_NAME => InputHelper::get('name'),
|
||||||
JobArgs::ARG_NEW_PASSWORD => InputHelper::get('password1'),
|
JobArgs::ARG_NEW_PASSWORD => InputHelper::get('password1'),
|
||||||
JobArgs::ARG_NEW_EMAIL => InputHelper::get('email'),
|
JobArgs::ARG_NEW_EMAIL => InputHelper::get('email'),
|
||||||
JobArgs::ARG_NEW_ACCESS_RANK => InputHelper::get('access-rank'),
|
JobArgs::ARG_NEW_ACCESS_RANK => InputHelper::get('access-rank'),
|
||||||
];
|
];
|
||||||
|
$args = $this->appendUserIdentifierArgument($args, $identifier);
|
||||||
|
|
||||||
$args = array_filter($args);
|
$args = array_filter($args);
|
||||||
$user = Api::run(new EditUserJob(), $args);
|
$user = Api::run(new EditUserJob(), $args);
|
||||||
|
@ -127,13 +125,14 @@ class UserController
|
||||||
Messenger::message($message);
|
Messenger::message($message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function deleteAction($name)
|
public function deleteAction($identifier)
|
||||||
{
|
{
|
||||||
$this->genericView($name, 'delete');
|
$this->genericView($identifier, 'delete');
|
||||||
$this->requirePasswordConfirmation();
|
$this->requirePasswordConfirmation();
|
||||||
|
|
||||||
Api::run(new DeleteUserJob(), [
|
Api::run(
|
||||||
JobArgs::ARG_USER_NAME => $name]);
|
new DeleteUserJob(),
|
||||||
|
$this->appendUserIdentifierArgument([], $identifier));
|
||||||
|
|
||||||
$user = UserModel::tryGetById(Auth::getCurrentUser()->getId());
|
$user = UserModel::tryGetById(Auth::getCurrentUser()->getId());
|
||||||
if (!$user)
|
if (!$user)
|
||||||
|
@ -143,29 +142,36 @@ class UserController
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function flagAction($name)
|
public function flagAction($identifier)
|
||||||
{
|
{
|
||||||
Api::run(new FlagUserJob(), [JobArgs::ARG_USER_NAME => $name]);
|
Api::run(
|
||||||
|
new FlagUserJob(),
|
||||||
|
$this->appendUserIdentifierArgument([], $identifier));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function banAction($name)
|
public function banAction($identifier)
|
||||||
{
|
{
|
||||||
Api::run(new ToggleUserBanJob(), [
|
Api::run(
|
||||||
JobArgs::ARG_USER_NAME => $name,
|
new ToggleUserBanJob(),
|
||||||
JobArgs::ARG_NEW_STATE => true]);
|
$this->appendUserIdentifierArgument([
|
||||||
|
JobArgs::ARG_NEW_STATE => true
|
||||||
|
], $identifier));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function unbanAction($name)
|
public function unbanAction($identifier)
|
||||||
{
|
{
|
||||||
Api::run(new ToggleUserBanJob(), [
|
Api::run(
|
||||||
JobArgs::ARG_USER_NAME => $name,
|
new ToggleUserBanJob(),
|
||||||
JobArgs::ARG_NEW_STATE => false]);
|
$this->appendUserIdentifierArgument([
|
||||||
|
JobArgs::ARG_NEW_STATE => true
|
||||||
|
], $identifier));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function acceptRegistrationAction($name)
|
public function acceptRegistrationAction($identifier)
|
||||||
{
|
{
|
||||||
Api::run(new AcceptUserRegistrationJob(), [
|
Api::run(
|
||||||
JobArgs::ARG_USER_NAME => $name]);
|
new AcceptUserRegistrationJob(),
|
||||||
|
$this->appendUserIdentifierArgument([], $identifier));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function toggleSafetyAction($safety)
|
public function toggleSafetyAction($safety)
|
||||||
|
@ -243,17 +249,20 @@ class UserController
|
||||||
$context = getContext();
|
$context = getContext();
|
||||||
$context->viewName = 'message';
|
$context->viewName = 'message';
|
||||||
Assets::setSubTitle('account activation');
|
Assets::setSubTitle('account activation');
|
||||||
$name = InputHelper::get('name');
|
$identifier = InputHelper::get('identifier');
|
||||||
|
|
||||||
if (empty($tokenText))
|
if (empty($tokenText))
|
||||||
{
|
{
|
||||||
Api::run(new ActivateUserEmailJob(), [ JobArgs::ARG_USER_NAME => $name ]);
|
Api::run(
|
||||||
|
new ActivateUserEmailJob(),
|
||||||
|
$this->appendUserIdentifierArgument([], $identifier));
|
||||||
|
|
||||||
Messenger::message('Activation e-mail resent.');
|
Messenger::message('Activation e-mail resent.');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$user = Api::run(new ActivateUserEmailJob(), [ JobArgs::ARG_TOKEN => $tokenText ]);
|
$user = Api::run(new ActivateUserEmailJob(), [
|
||||||
|
JobArgs::ARG_TOKEN => $tokenText ]);
|
||||||
|
|
||||||
$message = 'Activation completed successfully.';
|
$message = 'Activation completed successfully.';
|
||||||
if (getConfig()->registration->staffActivation)
|
if (getConfig()->registration->staffActivation)
|
||||||
|
@ -277,11 +286,13 @@ class UserController
|
||||||
$context = getContext();
|
$context = getContext();
|
||||||
$context->viewName = 'message';
|
$context->viewName = 'message';
|
||||||
Assets::setSubTitle('password reset');
|
Assets::setSubTitle('password reset');
|
||||||
$name = InputHelper::get('name');
|
$identifier = InputHelper::get('identifier');
|
||||||
|
|
||||||
if (empty($tokenText))
|
if (empty($tokenText))
|
||||||
{
|
{
|
||||||
Api::run(new PasswordResetJob(), [ JobArgs::ARG_USER_NAME => $name ]);
|
Api::run(
|
||||||
|
new PasswordResetJob(),
|
||||||
|
$this->appendUserIdentifierArgument([], $identifier));
|
||||||
|
|
||||||
Messenger::message('E-mail sent. Follow instructions to reset password.');
|
Messenger::message('E-mail sent. Follow instructions to reset password.');
|
||||||
}
|
}
|
||||||
|
@ -308,4 +319,13 @@ class UserController
|
||||||
throw new SimpleException('Must supply valid password');
|
throw new SimpleException('Must supply valid password');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function appendUserIdentifierArgument(array $arguments, $userIdentifier)
|
||||||
|
{
|
||||||
|
if (strpos($userIdentifier, '@') !== false)
|
||||||
|
$arguments[JobArgs::ARG_USER_EMAIL] = $userIdentifier;
|
||||||
|
else
|
||||||
|
$arguments[JobArgs::ARG_USER_NAME] = $userIdentifier;
|
||||||
|
return $arguments;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,9 @@ Assets::addScript('comment-edit.js');
|
||||||
<div class="avatar">
|
<div class="avatar">
|
||||||
<?php $commenter = $this->context->comment->getCommenter() ?>
|
<?php $commenter = $this->context->comment->getCommenter() ?>
|
||||||
<?php if ($commenter): ?>
|
<?php if ($commenter): ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(['UserController', 'genericView'], ['name' => $commenter->getName()]) ?>">
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
|
['UserController', 'genericView'],
|
||||||
|
['identifier' => $commenter->getName()]) ?>">
|
||||||
<img src="<?= htmlspecialchars($commenter->getAvatarUrl(40)) ?>" alt="<?= $commenter->getName() ?>"/>
|
<img src="<?= htmlspecialchars($commenter->getAvatarUrl(40)) ?>" alt="<?= $commenter->getName() ?>"/>
|
||||||
</a>
|
</a>
|
||||||
<?php else: ?>
|
<?php else: ?>
|
||||||
|
@ -24,7 +26,7 @@ Assets::addScript('comment-edit.js');
|
||||||
<?php if ($commenter): ?>
|
<?php if ($commenter): ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $commenter->getName()]) ?>">
|
['identifier' => $commenter->getName()]) ?>">
|
||||||
<?= $commenter->getName() ?>
|
<?= $commenter->getName() ?>
|
||||||
</a>
|
</a>
|
||||||
<?php else: ?>
|
<?php else: ?>
|
||||||
|
|
|
@ -95,7 +95,7 @@ $canEditAnything = count(array_filter($editPostPrivileges)) > 0;
|
||||||
<span class="value" title="<?= $val = $uploader->getName() ?>">
|
<span class="value" title="<?= $val = $uploader->getName() ?>">
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $uploader->getName()]) ?>">
|
['identifier' => $uploader->getName()]) ?>">
|
||||||
<img src="<?= htmlentities($uploader->getAvatarUrl(24)) ?>" alt="<?= $uploader->getName() ?>"/>
|
<img src="<?= htmlentities($uploader->getAvatarUrl(24)) ?>" alt="<?= $uploader->getName() ?>"/>
|
||||||
<?= $val ?>
|
<?= $val ?>
|
||||||
</a>
|
</a>
|
||||||
|
@ -245,7 +245,7 @@ $canEditAnything = count(array_filter($editPostPrivileges)) > 0;
|
||||||
<li>
|
<li>
|
||||||
<a title="<?= $user->getName() ?>" href="<?= \Chibi\Router::linkTo(
|
<a title="<?= $user->getName() ?>" href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $user->getName()]) ?>">
|
['identifier' => $user->getName()]) ?>">
|
||||||
<img src="<?= htmlspecialchars($user->getAvatarUrl()) ?>" alt="<?= $user->getName() ?>">
|
<img src="<?= htmlspecialchars($user->getAvatarUrl()) ?>" alt="<?= $user->getName() ?>">
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
|
@ -43,7 +43,7 @@ Assets::addStylesheet('static-main.css');
|
||||||
by
|
by
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->featuredPostUser->getName()]) ?>">
|
['identifier' => $this->context->featuredPostUser->getName()]) ?>">
|
||||||
<?= $this->context->featuredPostUser->getName() ?>
|
<?= $this->context->featuredPostUser->getName() ?>
|
||||||
</a>,
|
</a>,
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
|
|
|
@ -56,8 +56,8 @@
|
||||||
'Users',
|
'Users',
|
||||||
\Chibi\Router::linkTo(['UserController', 'listView']),
|
\Chibi\Router::linkTo(['UserController', 'listView']),
|
||||||
$activeController == 'user' and $activeAction != 'registration' and
|
$activeController == 'user' and $activeAction != 'registration' and
|
||||||
(!isset($this->context->route->arguments['name']) or
|
(!isset($this->context->route->arguments['identifier']) or
|
||||||
$this->context->route->arguments['name'] != Auth::getCurrentUser()->getName()));
|
$this->context->route->arguments['identifier'] != Auth::getCurrentUser()->getName()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Auth::isLoggedIn())
|
if (!Auth::isLoggedIn())
|
||||||
|
@ -76,9 +76,9 @@
|
||||||
{
|
{
|
||||||
$registerNavItem(
|
$registerNavItem(
|
||||||
'My account',
|
'My account',
|
||||||
\Chibi\Router::linkTo(['UserController', 'genericView'], ['name' => Auth::getCurrentUser()->getName()]),
|
\Chibi\Router::linkTo(['UserController', 'genericView'], ['identifier' => Auth::getCurrentUser()->getName()]),
|
||||||
$activeController == 'user' and isset($this->context->route->arguments['name']) and
|
$activeController == 'user' and isset($this->context->route->arguments['identifier']) and
|
||||||
$this->context->route->arguments['name'] == Auth::getCurrentUser()->getName());
|
$this->context->route->arguments['identifier'] == Auth::getCurrentUser()->getName());
|
||||||
|
|
||||||
$registerNavItem(
|
$registerNavItem(
|
||||||
'Log out',
|
'Log out',
|
||||||
|
@ -119,7 +119,7 @@
|
||||||
TextCaseConverter::CAMEL_CASE,
|
TextCaseConverter::CAMEL_CASE,
|
||||||
TextCaseConverter::SPINAL_CASE) ?>">
|
TextCaseConverter::SPINAL_CASE) ?>">
|
||||||
|
|
||||||
<a class="<?= Auth::getCurrentUser()->hasEnabledSafety($safety) ? 'enabled' : 'disabled' ?>"
|
<a class="simple-action <?= Auth::getCurrentUser()->hasEnabledSafety($safety) ? 'enabled' : 'disabled' ?>"
|
||||||
href="<?= \Chibi\Router::linkTo(
|
href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'toggleSafetyAction'],
|
['UserController', 'toggleSafetyAction'],
|
||||||
['safety' => $safety->toInteger()]) ?>"
|
['safety' => $safety->toInteger()]) ?>"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<form
|
<form
|
||||||
action="<?= \Chibi\Router::linkTo(
|
action="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'deleteAction'],
|
['UserController', 'deleteAction'],
|
||||||
['name' => $this->context->transport->user->getName()]) ?>"
|
['identifier' => $this->context->transport->user->getName()]) ?>"
|
||||||
method="post"
|
method="post"
|
||||||
class="delete confirmable"
|
class="delete confirmable"
|
||||||
autocomplete="off"
|
autocomplete="off"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<form
|
<form
|
||||||
action="<?= \Chibi\Router::linkTo(
|
action="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'editAction'],
|
['UserController', 'editAction'],
|
||||||
['name' => $this->context->transport->user->getName()]) ?>"
|
['identifier' => $this->context->transport->user->getName()]) ?>"
|
||||||
method="post"
|
method="post"
|
||||||
class="edit"
|
class="edit"
|
||||||
autocomplete="off">
|
autocomplete="off">
|
||||||
|
|
|
@ -44,14 +44,14 @@ if (Auth::getCurrentUser()->hasEnabledEndlessScrolling())
|
||||||
<div class="user">
|
<div class="user">
|
||||||
<a class="avatar" href="<?= \Chibi\Router::linkTo(
|
<a class="avatar" href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $user->getName()]) ?>">
|
['identifier' => $user->getName()]) ?>">
|
||||||
<img src="<?= htmlspecialchars($user->getAvatarUrl(100)) ?>" alt="<?= $user->getName() ?>"/>
|
<img src="<?= htmlspecialchars($user->getAvatarUrl(100)) ?>" alt="<?= $user->getName() ?>"/>
|
||||||
</a>
|
</a>
|
||||||
<div class="details">
|
<div class="details">
|
||||||
<h1>
|
<h1>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $user->getName()]) ?>">
|
['identifier' => $user->getName()]) ?>">
|
||||||
<?= $user->getName() ?>
|
<?= $user->getName() ?>
|
||||||
</a>
|
</a>
|
||||||
</h1>
|
</h1>
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
<div class="form-row">
|
<div class="form-row">
|
||||||
<label>User:</label>
|
<label>User:</label>
|
||||||
<div class="input-wrapper">
|
<div class="input-wrapper">
|
||||||
<input name="name" placeholder="Name or e-mail address" type="text"/>
|
<input name="identifier" placeholder="Name or e-mail address" type="text"/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<form
|
<form
|
||||||
action="<?= \Chibi\Router::linkTo(
|
action="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'settingsAction'],
|
['UserController', 'settingsAction'],
|
||||||
['name' => $this->context->transport->user->getName()]) ?>"
|
['identifier' => $this->context->transport->user->getName()]) ?>"
|
||||||
method="post"
|
method="post"
|
||||||
class="settings">
|
class="settings">
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
<div class="avatar-wrapper">
|
<div class="avatar-wrapper">
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->transport->user->getName()]) ?>">
|
['identifier' => $this->context->transport->user->getName()]) ?>">
|
||||||
|
|
||||||
<img
|
<img
|
||||||
src="<?= htmlspecialchars($this->context->transport->user->getAvatarUrl(140)) ?>"
|
src="<?= htmlspecialchars($this->context->transport->user->getAvatarUrl(140)) ?>"
|
||||||
|
@ -98,7 +98,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
'text' => 'Edit account settings',
|
'text' => 'Edit account settings',
|
||||||
'link' => \Chibi\Router::linkTo(
|
'link' => \Chibi\Router::linkTo(
|
||||||
['UserController', 'editAction'],
|
['UserController', 'editAction'],
|
||||||
['name' => $this->context->transport->user->getName(), 'tab' => 'edit']),
|
['identifier' => $this->context->transport->user->getName(), 'tab' => 'edit']),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +112,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
'text' => 'Accept registration',
|
'text' => 'Accept registration',
|
||||||
'simple-action' => \Chibi\Router::linkTo(
|
'simple-action' => \Chibi\Router::linkTo(
|
||||||
['UserController', 'acceptRegistrationAction'],
|
['UserController', 'acceptRegistrationAction'],
|
||||||
['name' => $this->context->transport->user->getName()]),
|
['identifier' => $this->context->transport->user->getName()]),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,7 +137,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
'text' => 'Flag for moderator attention',
|
'text' => 'Flag for moderator attention',
|
||||||
'simple-action' => \Chibi\Router::linkTo(
|
'simple-action' => \Chibi\Router::linkTo(
|
||||||
['UserController', 'flagAction'],
|
['UserController', 'flagAction'],
|
||||||
['name' => $this->context->transport->user->getName()]),
|
['identifier' => $this->context->transport->user->getName()]),
|
||||||
'data-confirm-text' => 'Are you sure you want to flag this user?',
|
'data-confirm-text' => 'Are you sure you want to flag this user?',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
'text' => 'Ban user',
|
'text' => 'Ban user',
|
||||||
'simple-action' => \Chibi\Router::linkTo(
|
'simple-action' => \Chibi\Router::linkTo(
|
||||||
['UserController', 'banAction'],
|
['UserController', 'banAction'],
|
||||||
['name' => $this->context->transport->user->getName()]),
|
['identifier' => $this->context->transport->user->getName()]),
|
||||||
'data-confirm-text' => 'Are you sure you want to ban this user?',
|
'data-confirm-text' => 'Are you sure you want to ban this user?',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
@ -167,7 +167,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
'text' => 'Unban user',
|
'text' => 'Unban user',
|
||||||
'simple-action' => \Chibi\Router::linkTo(
|
'simple-action' => \Chibi\Router::linkTo(
|
||||||
['UserController', 'unbanAction'],
|
['UserController', 'unbanAction'],
|
||||||
['name' => $this->context->transport->user->getName()]),
|
['identifier' => $this->context->transport->user->getName()]),
|
||||||
'data-confirm-text' => 'Are you sure you want to unban this user?',
|
'data-confirm-text' => 'Are you sure you want to unban this user?',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
@ -183,7 +183,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
'text' => 'Delete account',
|
'text' => 'Delete account',
|
||||||
'link' => \Chibi\Router::linkTo(
|
'link' => \Chibi\Router::linkTo(
|
||||||
['UserController', 'deleteAction'],
|
['UserController', 'deleteAction'],
|
||||||
['name' => $this->context->transport->user->getName(), 'tab' => 'delete']),
|
['identifier' => $this->context->transport->user->getName(), 'tab' => 'delete']),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,7 +202,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->transport->user->getName(),
|
['identifier' => $this->context->transport->user->getName(),
|
||||||
'tab' => 'favs',
|
'tab' => 'favs',
|
||||||
'page' => 1]) ?>">
|
'page' => 1]) ?>">
|
||||||
Favs
|
Favs
|
||||||
|
@ -216,7 +216,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->transport->user->getName(),
|
['identifier' => $this->context->transport->user->getName(),
|
||||||
'tab' => 'uploads',
|
'tab' => 'uploads',
|
||||||
'page' => 1]) ?>">
|
'page' => 1]) ?>">
|
||||||
Uploads
|
Uploads
|
||||||
|
@ -234,7 +234,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->transport->user->getName(),
|
['identifier' => $this->context->transport->user->getName(),
|
||||||
'tab' => 'settings']) ?>">
|
'tab' => 'settings']) ?>">
|
||||||
Browsing settings
|
Browsing settings
|
||||||
</a>
|
</a>
|
||||||
|
@ -249,7 +249,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->transport->user->getName(),
|
['identifier' => $this->context->transport->user->getName(),
|
||||||
'tab' => 'edit']) ?>">
|
'tab' => 'edit']) ?>">
|
||||||
Account settings
|
Account settings
|
||||||
</a>
|
</a>
|
||||||
|
@ -266,7 +266,7 @@ Assets::addStylesheet('user-view.css');
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<a href="<?= \Chibi\Router::linkTo(
|
<a href="<?= \Chibi\Router::linkTo(
|
||||||
['UserController', 'genericView'],
|
['UserController', 'genericView'],
|
||||||
['name' => $this->context->transport->user->getName(),
|
['identifier' => $this->context->transport->user->getName(),
|
||||||
'tab' => 'delete']) ?>">
|
'tab' => 'delete']) ?>">
|
||||||
Delete account
|
Delete account
|
||||||
</a>
|
</a>
|
||||||
|
|
|
@ -88,7 +88,7 @@ $tagValidation =
|
||||||
|
|
||||||
$userValidation =
|
$userValidation =
|
||||||
[
|
[
|
||||||
'name' => '[^\/]+',
|
'identifier' => '[^\/]+',
|
||||||
'page' => '\d*',
|
'page' => '\d*',
|
||||||
'tab' => 'favs|uploads|settings|edit|delete',
|
'tab' => 'favs|uploads|settings|edit|delete',
|
||||||
'filter' => '[^\/]+',
|
'filter' => '[^\/]+',
|
||||||
|
@ -97,8 +97,8 @@ $userValidation =
|
||||||
\Chibi\Router::register(['UserController', 'listView'], 'GET', '/users', $userValidation);
|
\Chibi\Router::register(['UserController', 'listView'], 'GET', '/users', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'listView'], 'GET', '/users/{page}', $userValidation);
|
\Chibi\Router::register(['UserController', 'listView'], 'GET', '/users/{page}', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'listView'], 'GET', '/users/{filter}/{page}', $userValidation);
|
\Chibi\Router::register(['UserController', 'listView'], 'GET', '/users/{filter}/{page}', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'genericView'], 'GET', '/user/{name}/{tab}', $userValidation);
|
\Chibi\Router::register(['UserController', 'genericView'], 'GET', '/user/{identifier}/{tab}', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'genericView'], 'GET', '/user/{name}/{tab}/{page}', $userValidation);
|
\Chibi\Router::register(['UserController', 'genericView'], 'GET', '/user/{identifier}/{tab}/{page}', $userValidation);
|
||||||
|
|
||||||
\Chibi\Router::register(['UserController', 'registrationView'], 'GET', '/register', $userValidation);
|
\Chibi\Router::register(['UserController', 'registrationView'], 'GET', '/register', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'registrationAction'], 'POST', '/register', $userValidation);
|
\Chibi\Router::register(['UserController', 'registrationAction'], 'POST', '/register', $userValidation);
|
||||||
|
@ -110,11 +110,11 @@ $userValidation =
|
||||||
\Chibi\Router::register(['UserController', 'passwordResetAction'], 'POST', '/password-reset', $userValidation);
|
\Chibi\Router::register(['UserController', 'passwordResetAction'], 'POST', '/password-reset', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'passwordResetAction'], 'GET', '/password-reset/{tokenText}', $userValidation);
|
\Chibi\Router::register(['UserController', 'passwordResetAction'], 'GET', '/password-reset/{tokenText}', $userValidation);
|
||||||
|
|
||||||
\Chibi\Router::register(['UserController', 'flagAction'], 'POST', '/user/{name}/flag', $userValidation);
|
\Chibi\Router::register(['UserController', 'flagAction'], 'POST', '/user/{identifier}/flag', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'banAction'], 'POST', '/user/{name}/ban', $userValidation);
|
\Chibi\Router::register(['UserController', 'banAction'], 'POST', '/user/{identifier}/ban', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'unbanAction'], 'POST', '/user/{name}/unban', $userValidation);
|
\Chibi\Router::register(['UserController', 'unbanAction'], 'POST', '/user/{identifier}/unban', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'acceptRegistrationAction'], 'POST', '/user/{name}/accept-registration', $userValidation);
|
\Chibi\Router::register(['UserController', 'acceptRegistrationAction'], 'POST', '/user/{identifier}/accept-registration', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'deleteAction'], 'POST', '/user/{name}/delete', $userValidation);
|
\Chibi\Router::register(['UserController', 'deleteAction'], 'POST', '/user/{identifier}/delete', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'settingsAction'], 'POST', '/user/{name}/settings', $userValidation);
|
\Chibi\Router::register(['UserController', 'settingsAction'], 'POST', '/user/{identifier}/settings', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'editAction'], 'POST', '/user/{name}/edit', $userValidation);
|
\Chibi\Router::register(['UserController', 'editAction'], 'POST', '/user/{identifier}/edit', $userValidation);
|
||||||
\Chibi\Router::register(['UserController', 'toggleSafetyAction'], 'POST', '/user/toggle-safety/{safety}', $userValidation);
|
\Chibi\Router::register(['UserController', 'toggleSafetyAction'], 'POST', '/user/toggle-safety/{safety}', $userValidation);
|
||||||
|
|
367
tests/Api/ApiArgumentTest.php
Normal file
367
tests/Api/ApiArgumentTest.php
Normal file
|
@ -0,0 +1,367 @@
|
||||||
|
<?php
|
||||||
|
class ApiArgumentTest extends AbstractFullApiTest
|
||||||
|
{
|
||||||
|
public function testAcceptUserRegistrationJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new AcceptUserRegistrationJob(),
|
||||||
|
$this->getUserSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testActivateUserEmailJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ActivateUserEmailJob(),
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_TOKEN,
|
||||||
|
$this->getUserSelector()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddPostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new AddPostJob(),
|
||||||
|
JobArgs::Optional(
|
||||||
|
JobArgs::ARG_ANONYMOUS));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddCommentJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new AddCommentJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_TEXT));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAddUserJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new AddUserJob(), null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDeletePostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new DeletePostJob(),
|
||||||
|
$this->getPostSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDeleteCommentJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new DeleteCommentJob(),
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_COMMENT_ENTITY,
|
||||||
|
JobArgs::ARG_COMMENT_ID));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testDeleteUserJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new DeleteUserJob(),
|
||||||
|
$this->getUserSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditCommentJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditCommentJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_NEW_TEXT,
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_COMMENT_ENTITY,
|
||||||
|
JobArgs::ARG_COMMENT_ID)));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostContentJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostContentJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_NEW_POST_CONTENT,
|
||||||
|
JobArgs::ARG_NEW_POST_CONTENT_URL)));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostJob(),
|
||||||
|
$this->getPostSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostRelationsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostRelationsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_RELATED_POST_IDS));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostSafetyJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostSafetyJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_SAFETY));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostSourceJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostSourceJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_SOURCE));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostTagsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostTagsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_TAG_NAMES));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditPostThumbJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditPostThumbJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_THUMB_CONTENT));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditUserAccessRankJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditUserAccessRankJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getUserSelector(),
|
||||||
|
JobArgs::ARG_NEW_ACCESS_RANK));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditUserEmailJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditUserEmailJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getUserSelector(),
|
||||||
|
JobArgs::ARG_NEW_EMAIL));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditUserJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditUserJob(),
|
||||||
|
$this->getUserSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditUserNameJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditUserNameJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getUserSelector(),
|
||||||
|
JobArgs::ARG_NEW_USER_NAME));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testEditUserPasswordJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new EditUserPasswordJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getUserSelector(),
|
||||||
|
JobArgs::ARG_NEW_PASSWORD));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFeaturePostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new FeaturePostJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::Optional(JobArgs::ARG_ANONYMOUS),
|
||||||
|
$this->getPostSelector()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFlagPostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new FlagPostJob(),
|
||||||
|
$this->getPostSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFlagUserJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new FlagUserJob(),
|
||||||
|
$this->getUserSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetLogJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new GetLogJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_QUERY,
|
||||||
|
JobArgs::ARG_LOG_ID,
|
||||||
|
JobArgs::ARG_PAGE_NUMBER));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetPostContentJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new GetPostContentJob(),
|
||||||
|
$this->getPostSafeSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetPostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new GetPostJob(),
|
||||||
|
$this->getPostSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetPostThumbJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new GetPostThumbJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::Optional(JobArgs::ARG_THUMB_WIDTH),
|
||||||
|
JobArgs::Optional(JobArgs::ARG_THUMB_HEIGHT),
|
||||||
|
$this->getPostSafeSelector()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetUserJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new GetUserJob(),
|
||||||
|
$this->getUserSelector());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListCommentsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ListCommentsJob(),
|
||||||
|
JobArgs::ARG_PAGE_NUMBER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListLogsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ListLogsJob(),
|
||||||
|
null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListPostsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ListPostsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_QUERY,
|
||||||
|
JobArgs::ARG_PAGE_NUMBER));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListRelatedTagsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ListRelatedTagsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::Optional(JobArgs::ARG_TAG_NAMES),
|
||||||
|
JobArgs::ARG_TAG_NAME,
|
||||||
|
JobArgs::ARG_QUERY,
|
||||||
|
JobArgs::ARG_PAGE_NUMBER));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListTagsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ListTagsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_QUERY,
|
||||||
|
JobArgs::ARG_PAGE_NUMBER));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListUsersJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ListUsersJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_QUERY,
|
||||||
|
JobArgs::ARG_PAGE_NUMBER));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testMergeTagsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new MergeTagsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_SOURCE_TAG_NAME,
|
||||||
|
JobArgs::ARG_TARGET_TAG_NAME));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRenameTagsJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new RenameTagsJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::ARG_SOURCE_TAG_NAME,
|
||||||
|
JobArgs::ARG_TARGET_TAG_NAME));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testPasswordResetJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new PasswordResetJob(),
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_TOKEN,
|
||||||
|
$this->getUserSelector()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testPreviewCommentJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new PreviewCommentJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_POST_ID,
|
||||||
|
JobArgs::ARG_COMMENT_ID),
|
||||||
|
JobArgs::ARG_NEW_TEXT));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testScorePostJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ScorePostJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_POST_SCORE));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testTogglePostFavoriteJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new TogglePostFavoriteJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_STATE));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testTogglePostTagJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new TogglePostTagJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_TAG_NAME,
|
||||||
|
JobArgs::ARG_NEW_STATE));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testTogglePostVisibilityJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new TogglePostVisibilityJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getPostSelector(),
|
||||||
|
JobArgs::ARG_NEW_STATE));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testToggleUserBanJob()
|
||||||
|
{
|
||||||
|
$this->testArguments(new ToggleUserBanJob(),
|
||||||
|
JobArgs::Conjunction(
|
||||||
|
$this->getUserSelector(),
|
||||||
|
JobArgs::ARG_NEW_STATE));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function testArguments($job, $arguments)
|
||||||
|
{
|
||||||
|
$this->testedJobs []= $job;
|
||||||
|
$this->assert->areEquivalent($arguments, $job->getRequiredArguments());
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getPostSelector()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_POST_ENTITY,
|
||||||
|
JobArgs::ARG_POST_ID,
|
||||||
|
JobArgs::ARG_POST_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getPostSafeSelector()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_POST_NAME,
|
||||||
|
JobArgs::ARG_POST_ENTITY);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getUserSelector()
|
||||||
|
{
|
||||||
|
return JobArgs::Alternative(
|
||||||
|
JobArgs::ARG_USER_EMAIL,
|
||||||
|
JobArgs::ARG_USER_ENTITY,
|
||||||
|
JobArgs::ARG_USER_NAME);
|
||||||
|
}
|
||||||
|
}
|
|
@ -52,7 +52,7 @@ class ApiAuthTest extends AbstractFullApiTest
|
||||||
protected function testAuth($job, $expectedAuth)
|
protected function testAuth($job, $expectedAuth)
|
||||||
{
|
{
|
||||||
$this->testedJobs []= $job;
|
$this->testedJobs []= $job;
|
||||||
$this->assert->areEqual($expectedAuth, $job->requiresAuthentication());
|
$this->assert->areEqual($expectedAuth, $job->isAuthenticationRequired());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testAuthEnforcing()
|
public function testAuthEnforcing()
|
||||||
|
|
|
@ -52,7 +52,7 @@ class ApiEmailRequirementsTest extends AbstractFullApiTest
|
||||||
protected function testRegularEmailRequirement($job)
|
protected function testRegularEmailRequirement($job)
|
||||||
{
|
{
|
||||||
$this->testedJobs []= $job;
|
$this->testedJobs []= $job;
|
||||||
$this->assert->areEqual(false, $job->requiresConfirmedEmail());
|
$this->assert->areEqual(false, $job->isConfirmedEmailRequired());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCommentsEmailRequirements()
|
public function testCommentsEmailRequirements()
|
||||||
|
@ -66,10 +66,10 @@ class ApiEmailRequirementsTest extends AbstractFullApiTest
|
||||||
$this->testedJobs []= $job;
|
$this->testedJobs []= $job;
|
||||||
|
|
||||||
getConfig()->registration->needEmailForCommenting = false;
|
getConfig()->registration->needEmailForCommenting = false;
|
||||||
$this->assert->areEqual(false, $job->requiresConfirmedEmail());
|
$this->assert->areEqual(false, $job->isConfirmedEmailRequired());
|
||||||
|
|
||||||
getConfig()->registration->needEmailForCommenting = true;
|
getConfig()->registration->needEmailForCommenting = true;
|
||||||
$this->assert->areEqual(true, $job->requiresConfirmedEmail());
|
$this->assert->areEqual(true, $job->isConfirmedEmailRequired());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testPostingEmailRequirement()
|
public function testPostingEmailRequirement()
|
||||||
|
@ -79,10 +79,10 @@ class ApiEmailRequirementsTest extends AbstractFullApiTest
|
||||||
$this->testedJobs []= $job;
|
$this->testedJobs []= $job;
|
||||||
|
|
||||||
getConfig()->registration->needEmailForUploading = false;
|
getConfig()->registration->needEmailForUploading = false;
|
||||||
$this->assert->areEqual(false, $job->requiresConfirmedEmail());
|
$this->assert->areEqual(false, $job->isConfirmedEmailRequired());
|
||||||
|
|
||||||
getConfig()->registration->needEmailForUploading = true;
|
getConfig()->registration->needEmailForUploading = true;
|
||||||
$this->assert->areEqual(true, $job->requiresConfirmedEmail());
|
$this->assert->areEqual(true, $job->isConfirmedEmailRequired());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testEnforcing()
|
public function testEnforcing()
|
||||||
|
|
|
@ -33,7 +33,7 @@ class ApiPrivilegeTest extends AbstractFullApiTest
|
||||||
protected function testRegularPrivilege($job, $expectedPrivilege)
|
protected function testRegularPrivilege($job, $expectedPrivilege)
|
||||||
{
|
{
|
||||||
$this->testedJobs []= $job;
|
$this->testedJobs []= $job;
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDynamicPostPrivileges()
|
public function testDynamicPostPrivileges()
|
||||||
|
@ -80,12 +80,12 @@ class ApiPrivilegeTest extends AbstractFullApiTest
|
||||||
$expectedPrivilege->secondary = 'all';
|
$expectedPrivilege->secondary = 'all';
|
||||||
$job->setArgument(JobArgs::ARG_POST_ID, $otherPost->getId());
|
$job->setArgument(JobArgs::ARG_POST_ID, $otherPost->getId());
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
|
|
||||||
$expectedPrivilege->secondary = 'own';
|
$expectedPrivilege->secondary = 'own';
|
||||||
$job->setArgument(JobArgs::ARG_POST_ID, $ownPost->getId());
|
$job->setArgument(JobArgs::ARG_POST_ID, $ownPost->getId());
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDynamicPostRetrievalPrivileges()
|
public function testDynamicPostRetrievalPrivileges()
|
||||||
|
@ -110,7 +110,7 @@ class ApiPrivilegeTest extends AbstractFullApiTest
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent([
|
$this->assert->areEquivalent([
|
||||||
new Privilege(Privilege::ViewPost, 'hidden'),
|
new Privilege(Privilege::ViewPost, 'hidden'),
|
||||||
new Privilege(Privilege::ViewPost, 'safe')], $job->requiresPrivilege());
|
new Privilege(Privilege::ViewPost, 'safe')], $job->getRequiredPrivileges());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ class ApiPrivilegeTest extends AbstractFullApiTest
|
||||||
{
|
{
|
||||||
$job = new GetPostThumbJob();
|
$job = new GetPostThumbJob();
|
||||||
$this->testedJobs []= $job;
|
$this->testedJobs []= $job;
|
||||||
$this->assert->areEquivalent(false, $job->requiresPrivilege());
|
$this->assert->areEquivalent(false, $job->getRequiredPrivileges());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDynamicUserPrivileges()
|
public function testDynamicUserPrivileges()
|
||||||
|
@ -149,12 +149,12 @@ class ApiPrivilegeTest extends AbstractFullApiTest
|
||||||
$expectedPrivilege->secondary = 'own';
|
$expectedPrivilege->secondary = 'own';
|
||||||
$job->setArgument(JobArgs::ARG_USER_NAME, $ownUser->getName());
|
$job->setArgument(JobArgs::ARG_USER_NAME, $ownUser->getName());
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
|
|
||||||
$expectedPrivilege->secondary = 'all';
|
$expectedPrivilege->secondary = 'all';
|
||||||
$job->setArgument(JobArgs::ARG_USER_NAME, $otherUser->getName());
|
$job->setArgument(JobArgs::ARG_USER_NAME, $otherUser->getName());
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDynamicCommentPrivileges()
|
public function testDynamicCommentPrivileges()
|
||||||
|
@ -175,12 +175,12 @@ class ApiPrivilegeTest extends AbstractFullApiTest
|
||||||
$expectedPrivilege->secondary = 'own';
|
$expectedPrivilege->secondary = 'own';
|
||||||
$job->setArgument(JobArgs::ARG_COMMENT_ID, $ownComment->getId());
|
$job->setArgument(JobArgs::ARG_COMMENT_ID, $ownComment->getId());
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
|
|
||||||
$expectedPrivilege->secondary = 'all';
|
$expectedPrivilege->secondary = 'all';
|
||||||
$job->setArgument(JobArgs::ARG_COMMENT_ID, $otherComment->getId());
|
$job->setArgument(JobArgs::ARG_COMMENT_ID, $otherComment->getId());
|
||||||
$job->prepare();
|
$job->prepare();
|
||||||
$this->assert->areEquivalent($expectedPrivilege, $job->requiresPrivilege());
|
$this->assert->areEquivalent($expectedPrivilege, $job->getRequiredPrivileges());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testPrivilegeEnforcing()
|
public function testPrivilegeEnforcing()
|
||||||
|
|
Loading…
Reference in a new issue