Improved search error messages
This commit is contained in:
parent
5412ac14b9
commit
24d8bf5295
5 changed files with 71 additions and 41 deletions
|
@ -149,7 +149,7 @@ class PostDao extends AbstractDao implements ICrudDao
|
|||
return;
|
||||
}
|
||||
|
||||
elseif ($requirement->getType() === PostFilter::REQUIREMENT_COMMENT)
|
||||
elseif ($requirement->getType() === PostFilter::REQUIREMENT_COMMENT_AUTHOR)
|
||||
{
|
||||
foreach ($requirement->getValue()->getValues() as $userName)
|
||||
{
|
||||
|
|
|
@ -104,7 +104,12 @@ class EnumHelper
|
|||
$key = trim(strtolower($enumString));
|
||||
$lowerEnumMap = array_change_key_case($enumMap, \CASE_LOWER);
|
||||
if (!isset($lowerEnumMap[$key]))
|
||||
throw new \DomainException('Unrecognized value: ' . $enumString);
|
||||
{
|
||||
throw new \DomainException(sprintf(
|
||||
'Unrecognized value: %s.' . PHP_EOL . 'Possible values: %s',
|
||||
$enumString,
|
||||
join(', ', array_keys($lowerEnumMap))));
|
||||
}
|
||||
|
||||
return $lowerEnumMap[$key];
|
||||
}
|
||||
|
|
|
@ -3,8 +3,8 @@ namespace Szurubooru;
|
|||
|
||||
class NotSupportedException extends \BadMethodCallException
|
||||
{
|
||||
public function __construct()
|
||||
public function __construct($message = null)
|
||||
{
|
||||
parent::__construct('Not supported');
|
||||
parent::__construct($message === null ? 'Not supported' : $message);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -25,7 +25,7 @@ class PostFilter extends BasicFilter implements IFilter
|
|||
const REQUIREMENT_UPLOADER = 'uploader.name';
|
||||
const REQUIREMENT_SAFETY = 'safety';
|
||||
const REQUIREMENT_FAVORITE = 'favoritedBy.name';
|
||||
const REQUIREMENT_COMMENT = 'commentedBy.name';
|
||||
const REQUIREMENT_COMMENT_AUTHOR = 'commentedBy.name';
|
||||
const REQUIREMENT_TYPE = 'contentType';
|
||||
const REQUIREMENT_USER_SCORE = 'userScore';
|
||||
|
||||
|
|
|
@ -43,7 +43,13 @@ class PostSearchParser extends AbstractSearchParser
|
|||
$tokenKey = $token->getKey();
|
||||
$tokenValue = $token->getValue();
|
||||
|
||||
$countAliases = ['tag_count' => 'tag', 'fav_count' => 'fav', 'score' => 'score'];
|
||||
$countAliases =
|
||||
[
|
||||
'tag_count' => 'tags',
|
||||
'fav_count' => 'favs',
|
||||
'score' => 'score',
|
||||
'comment_count' => 'comments',
|
||||
];
|
||||
foreach ($countAliases as $realKey => $baseAlias)
|
||||
{
|
||||
if ($this->matches($tokenKey, [$baseAlias . '_min', $baseAlias . '_max']))
|
||||
|
@ -60,59 +66,49 @@ class PostSearchParser extends AbstractSearchParser
|
|||
[['id'], [$this, 'addIdRequirement']],
|
||||
[['hash', 'name'], [$this, 'addHashRequirement']],
|
||||
[['date', 'time'], [$this, 'addDateRequirement']],
|
||||
[['tag_count'], [$this, 'addTagCountRequirement']],
|
||||
[['fav_count'], [$this, 'addFavCountRequirement']],
|
||||
[['comment_count'], [$this, 'addCommentCountRequirement']],
|
||||
[['tag_count', 'tags'], [$this, 'addTagCountRequirement']],
|
||||
[['fav_count', 'favs'], [$this, 'addFavCountRequirement']],
|
||||
[['comment_count', 'comments'], [$this, 'addCommentCountRequirement']],
|
||||
[['score'], [$this, 'addScoreRequirement']],
|
||||
[['uploader', 'submit', 'up'], [$this, 'addUploaderRequirement']],
|
||||
[['uploader', 'uploader', 'uploaded', 'submit', 'submitter', 'submitted'], [$this, 'addUploaderRequirement']],
|
||||
[['safety', 'rating'], [$this, 'addSafetyRequirement']],
|
||||
[['fav'], [$this, 'addFavRequirement']],
|
||||
[['type'], [$this, 'addTypeRequirement']],
|
||||
[['comment'], [$this, 'addCommentRequirement']],
|
||||
[['comment', 'comment_author', 'commented'], [$this, 'addCommentAuthorRequirement']],
|
||||
];
|
||||
|
||||
foreach ($map as $item)
|
||||
{
|
||||
list ($aliases, $callback) = $item;
|
||||
if ($this->matches($tokenKey, $aliases))
|
||||
{
|
||||
return $callback($filter, $token);
|
||||
}
|
||||
}
|
||||
|
||||
if ($this->matches($tokenKey, ['special']))
|
||||
{
|
||||
if ($this->matches($tokenValue, ['liked']))
|
||||
$specialMap =
|
||||
[
|
||||
[['liked'], [$this, 'addOwnLikedRequirement']],
|
||||
[['disliked'], [$this, 'addOwnDislikedRequirement']],
|
||||
[['fav'], [$this, 'addOwnFavRequirement']],
|
||||
];
|
||||
|
||||
foreach ($specialMap as $item)
|
||||
{
|
||||
$this->privilegeService->assertLoggedIn();
|
||||
return $this->addUserScoreRequirement(
|
||||
$filter,
|
||||
$this->authService->getLoggedInUser()->getName(),
|
||||
1,
|
||||
$token->isNegated());
|
||||
list ($aliases, $callback) = $item;
|
||||
if ($this->matches($token->getValue(), $aliases))
|
||||
return $callback($filter, $token);
|
||||
}
|
||||
|
||||
if ($this->matches($tokenValue, ['disliked']))
|
||||
{
|
||||
$this->privilegeService->assertLoggedIn();
|
||||
return $this->addUserScoreRequirement(
|
||||
$filter,
|
||||
$this->authService->getLoggedInUser()->getName(),
|
||||
-1,
|
||||
$token->isNegated());
|
||||
throw new NotSupportedException(
|
||||
'Unknown value for special search term: ' . $token->getValue()
|
||||
. '. Possible search terms: '
|
||||
. join(', ', array_map(function($term) { return join('/', $term[0]); }, $specialMap)));
|
||||
}
|
||||
|
||||
if ($this->matches($tokenValue, ['fav']))
|
||||
{
|
||||
$this->privilegeService->assertLoggedIn();
|
||||
$token = new NamedSearchToken();
|
||||
$token->setKey('fav');
|
||||
$token->setValue($this->authService->getLoggedInUser()->getName());
|
||||
return $this->decorateFilterFromNamedToken($filter, $token);
|
||||
}
|
||||
}
|
||||
|
||||
throw new NotSupportedException();
|
||||
throw new NotSupportedException('Unknown search term: ' . $token->getKey()
|
||||
. '. Possible search terms: special, '
|
||||
. join(', ', array_map(function($term) { return join('/', $term[0]); }, $map)));
|
||||
}
|
||||
|
||||
protected function getOrderColumn($tokenText)
|
||||
|
@ -153,6 +149,35 @@ class PostSearchParser extends AbstractSearchParser
|
|||
throw new NotSupportedException();
|
||||
}
|
||||
|
||||
private function addOwnLikedRequirement($filter, $token)
|
||||
{
|
||||
$this->privilegeService->assertLoggedIn();
|
||||
$this->addUserScoreRequirement(
|
||||
$filter,
|
||||
$this->authService->getLoggedInUser()->getName(),
|
||||
1,
|
||||
$token->isNegated());
|
||||
}
|
||||
|
||||
private function addOwnDislikedRequirement($filter, $token)
|
||||
{
|
||||
$this->privilegeService->assertLoggedIn();
|
||||
$this->addUserScoreRequirement(
|
||||
$filter,
|
||||
$this->authService->getLoggedInUser()->getName(),
|
||||
-1,
|
||||
$token->isNegated());
|
||||
}
|
||||
|
||||
private function addOwnFavRequirement($filter, $token)
|
||||
{
|
||||
$this->privilegeService->assertLoggedIn();
|
||||
$token = new NamedSearchToken();
|
||||
$token->setKey('fav');
|
||||
$token->setValue($this->authService->getLoggedInUser()->getName());
|
||||
$this->decorateFilterFromNamedToken($filter, $token);
|
||||
}
|
||||
|
||||
private function addIdRequirement($filter, $token)
|
||||
{
|
||||
$this->addRequirementFromToken(
|
||||
|
@ -280,12 +305,12 @@ class PostSearchParser extends AbstractSearchParser
|
|||
});
|
||||
}
|
||||
|
||||
private function addCommentRequirement($filter, $token)
|
||||
private function addCommentAuthorRequirement($filter, $token)
|
||||
{
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
PostFilter::REQUIREMENT_COMMENT,
|
||||
PostFilter::REQUIREMENT_COMMENT_AUTHOR,
|
||||
self::ALLOW_COMPOSITE);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue