Added score: support to post searching
This commit is contained in:
parent
47081293ef
commit
11931075f5
4 changed files with 48 additions and 23 deletions
1
TODO
1
TODO
|
@ -15,7 +15,6 @@ everything related to posts:
|
|||
- comment:rr-
|
||||
- comment_count: 3..5
|
||||
- fav:rr-
|
||||
- score:3..5
|
||||
- file_size:3K..5M
|
||||
- image_size:huge/large/medium/small
|
||||
- type:img/flash/yt/video
|
||||
|
|
|
@ -16,6 +16,7 @@ class PostFilter extends BasicFilter implements IFilter
|
|||
const REQUIREMENT_HASH = 'name';
|
||||
const REQUIREMENT_TAG_COUNT = 'tagCount';
|
||||
const REQUIREMENT_FAV_COUNT = 'favCount';
|
||||
const REQUIREMENT_SCORE = 'score';
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
|
|
|
@ -61,6 +61,15 @@ abstract class AbstractSearchParser
|
|||
return new \Szurubooru\SearchServices\Requirements\RequirementSingleValue($text);
|
||||
}
|
||||
|
||||
protected function addRequirementFromToken($filter, $token, $type, $flags)
|
||||
{
|
||||
$requirement = new \Szurubooru\SearchServices\Requirements\Requirement();
|
||||
$requirement->setType($type, $flags);
|
||||
$requirement->setValue($this->createRequirementValue($token->getValue(), $flags));
|
||||
$requirement->setNegated($token->isNegated());
|
||||
$filter->addRequirement($requirement);
|
||||
}
|
||||
|
||||
private function getOrder($query)
|
||||
{
|
||||
$order = [];
|
||||
|
|
|
@ -34,6 +34,9 @@ class PostSearchParser extends AbstractSearchParser
|
|||
elseif ($token->getKey() === 'fav_count')
|
||||
$this->addFavCountRequirement($filter, $token);
|
||||
|
||||
elseif ($token->getKey() === 'score')
|
||||
$this->addScoreRequirement($filter, $token);
|
||||
|
||||
else
|
||||
throw new \BadMethodCallException('Not supported');
|
||||
}
|
||||
|
@ -63,19 +66,20 @@ class PostSearchParser extends AbstractSearchParser
|
|||
|
||||
private function addIdRequirement($filter, $token)
|
||||
{
|
||||
$requirement = new \Szurubooru\SearchServices\Requirements\Requirement();
|
||||
$requirement->setType(\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_ID);
|
||||
$requirement->setValue($this->createRequirementValue($token->getValue(), self::ALLOW_COMPOSITE | self::ALLOW_RANGES));
|
||||
$requirement->setNegated($token->isNegated());
|
||||
$filter->addRequirement($requirement);
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_ID,
|
||||
self::ALLOW_COMPOSITE | self::ALLOW_RANGES);
|
||||
}
|
||||
|
||||
private function addHashRequirement($filter, $token)
|
||||
{
|
||||
$requirement = new \Szurubooru\SearchServices\Requirements\Requirement();
|
||||
$requirement->setType(\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_HASH);
|
||||
$requirement->setValue($this->createRequirementValue($token->getValue(), self::ALLOW_COMPOSITE));
|
||||
$filter->addRequirement($requirement);
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_HASH,
|
||||
self::ALLOW_COMPOSITE);
|
||||
}
|
||||
|
||||
private function addDateRequirement($filter, $token)
|
||||
|
@ -99,27 +103,39 @@ class PostSearchParser extends AbstractSearchParser
|
|||
if ($timeMax)
|
||||
$finalString .= date('c', $timeMax);
|
||||
|
||||
$requirement = new \Szurubooru\SearchServices\Requirements\Requirement();
|
||||
$requirement->setType(\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_DATE);
|
||||
$requirement->setValue($this->createRequirementValue($finalString, self::ALLOW_RANGES));
|
||||
$requirement->setNegated($token->isNegated());
|
||||
$filter->addRequirement($requirement);
|
||||
$token->setValue($finalString);
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_DATE,
|
||||
self::ALLOW_RANGES);
|
||||
}
|
||||
|
||||
private function addTagCountRequirement($filter, $token)
|
||||
{
|
||||
$requirement = new \Szurubooru\SearchServices\Requirements\Requirement();
|
||||
$requirement->setType(\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_TAG_COUNT);
|
||||
$requirement->setValue($this->createRequirementValue($token->getValue(), self::ALLOW_COMPOSITE | self::ALLOW_RANGES));
|
||||
$filter->addRequirement($requirement);
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_TAG_COUNT,
|
||||
self::ALLOW_COMPOSITE | self::ALLOW_RANGES);
|
||||
}
|
||||
|
||||
private function addFavCountRequirement($filter, $token)
|
||||
{
|
||||
$requirement = new \Szurubooru\SearchServices\Requirements\Requirement();
|
||||
$requirement->setType(\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_FAV_COUNT);
|
||||
$requirement->setValue($this->createRequirementValue($token->getValue(), self::ALLOW_COMPOSITE | self::ALLOW_RANGES));
|
||||
$filter->addRequirement($requirement);
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_FAV_COUNT,
|
||||
self::ALLOW_COMPOSITE | self::ALLOW_RANGES);
|
||||
}
|
||||
|
||||
private function addScoreRequirement($filter, $token)
|
||||
{
|
||||
$this->addRequirementFromToken(
|
||||
$filter,
|
||||
$token,
|
||||
\Szurubooru\SearchServices\Filters\PostFilter::REQUIREMENT_SCORE,
|
||||
self::ALLOW_COMPOSITE | self::ALLOW_RANGES);
|
||||
}
|
||||
|
||||
private function dateToTime($value)
|
||||
|
|
Loading…
Reference in a new issue