1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-05 20:31:03 +01:00

Allow users to query feed by a date range

Summary: Ref T12762.

Test Plan:
  - Ran queries with start date, end date, both, neither.
  - Used EXPLAIN to try to make sure doing the bitshift isn't going to be a performance issue.

{F4978842}

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T12762

Differential Revision: https://secure.phabricator.com/D18029
This commit is contained in:
epriestley 2017-05-26 10:22:29 -07:00
parent 6fed08a98e
commit 46a33c07dc
2 changed files with 56 additions and 0 deletions

View file

@ -5,6 +5,8 @@ final class PhabricatorFeedQuery
private $filterPHIDs; private $filterPHIDs;
private $chronologicalKeys; private $chronologicalKeys;
private $rangeMin;
private $rangeMax;
public function withFilterPHIDs(array $phids) { public function withFilterPHIDs(array $phids) {
$this->filterPHIDs = $phids; $this->filterPHIDs = $phids;
@ -16,6 +18,12 @@ final class PhabricatorFeedQuery
return $this; return $this;
} }
public function withEpochInRange($range_min, $range_max) {
$this->rangeMin = $range_min;
$this->rangeMax = $range_max;
return $this;
}
public function newResultObject() { public function newResultObject() {
return new PhabricatorFeedStoryData(); return new PhabricatorFeedStoryData();
} }
@ -74,6 +82,24 @@ final class PhabricatorFeedQuery
implode(', ', $keys)); implode(', ', $keys));
} }
// NOTE: We may not have 64-bit PHP, so do the shifts in MySQL instead.
// From EXPLAIN, it appears like MySQL is smart enough to compute the
// result and make use of keys to execute the query.
if ($this->rangeMin !== null) {
$where[] = qsprintf(
$conn,
'ref.chronologicalKey >= (%d << 32)',
$this->rangeMin);
}
if ($this->rangeMax !== null) {
$where[] = qsprintf(
$conn,
'ref.chronologicalKey < (%d << 32)',
$this->rangeMax);
}
return $where; return $where;
} }

View file

@ -30,6 +30,12 @@ final class PhabricatorFeedSearchEngine
->setDatasource(new PhabricatorProjectDatasource()) ->setDatasource(new PhabricatorProjectDatasource())
->setLabel(pht('Include Projects')) ->setLabel(pht('Include Projects'))
->setKey('projectPHIDs'), ->setKey('projectPHIDs'),
id(new PhabricatorSearchDateControlField())
->setLabel(pht('Occurs After'))
->setKey('rangeStart'),
id(new PhabricatorSearchDateControlField())
->setLabel(pht('Occurs Before'))
->setKey('rangeEnd'),
// NOTE: This is a legacy field retained only for backward // NOTE: This is a legacy field retained only for backward
// compatibility. If the projects field used EdgeLogic, we could use // compatibility. If the projects field used EdgeLogic, we could use
@ -71,6 +77,30 @@ final class PhabricatorFeedSearchEngine
$query->withFilterPHIDs($phids); $query->withFilterPHIDs($phids);
} }
$range_min = $map['rangeStart'];
if ($range_min) {
$range_min = $range_min->getEpoch();
}
$range_max = $map['rangeEnd'];
if ($range_max) {
$range_max = $range_max->getEpoch();
}
if ($range_min && $range_max) {
if ($range_min > $range_max) {
throw new PhabricatorSearchConstraintException(
pht(
'The specified "Occurs Before" date is earlier in time than the '.
'specified "Occurs After" date, so this query can never match '.
'any results.'));
}
}
if ($range_min || $range_max) {
$query->withEpochInRange($range_min, $range_max);
}
return $query; return $query;
} }