2012-06-08 15:31:30 +02:00
|
|
|
<?php
|
|
|
|
|
2012-06-28 22:59:50 +02:00
|
|
|
/**
|
|
|
|
* @task config Configuring the Query
|
|
|
|
* @task exec Query Execution
|
|
|
|
*/
|
2012-10-23 21:01:59 +02:00
|
|
|
final class PhabricatorNotificationQuery
|
|
|
|
extends PhabricatorCursorPagedPolicyAwareQuery {
|
2012-06-08 15:31:30 +02:00
|
|
|
|
|
|
|
private $userPHID;
|
2012-06-18 23:08:10 +02:00
|
|
|
private $keys;
|
2012-06-28 22:59:50 +02:00
|
|
|
private $unread;
|
|
|
|
|
|
|
|
|
|
|
|
/* -( Configuring the Query )---------------------------------------------- */
|
|
|
|
|
2012-06-08 15:31:30 +02:00
|
|
|
|
|
|
|
public function setUserPHID($user_phid) {
|
|
|
|
$this->userPHID = $user_phid;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2012-06-18 23:08:10 +02:00
|
|
|
public function withKeys(array $keys) {
|
|
|
|
$this->keys = $keys;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2012-06-28 22:59:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Filter results by read/unread status. Note that `true` means to return
|
|
|
|
* only unread notifications, while `false` means to return only //read//
|
|
|
|
* notifications. The default is `null`, which returns both.
|
|
|
|
*
|
|
|
|
* @param mixed True or false to filter results by read status. Null to remove
|
|
|
|
* the filter.
|
|
|
|
* @return this
|
|
|
|
* @task config
|
|
|
|
*/
|
|
|
|
public function withUnread($unread) {
|
|
|
|
$this->unread = $unread;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* -( Query Execution )---------------------------------------------------- */
|
|
|
|
|
|
|
|
|
2013-03-01 20:28:02 +01:00
|
|
|
protected function loadPage() {
|
2012-06-08 15:31:30 +02:00
|
|
|
if (!$this->userPHID) {
|
|
|
|
throw new Exception("Call setUser() before executing the query");
|
|
|
|
}
|
|
|
|
|
|
|
|
$story_table = new PhabricatorFeedStoryData();
|
|
|
|
$notification_table = new PhabricatorFeedStoryNotification();
|
|
|
|
|
|
|
|
$conn = $story_table->establishConnection('r');
|
|
|
|
|
|
|
|
$data = queryfx_all(
|
|
|
|
$conn,
|
2012-10-23 21:01:59 +02:00
|
|
|
"SELECT story.*, notif.hasViewed FROM %T notif
|
2012-06-08 15:31:30 +02:00
|
|
|
JOIN %T story ON notif.chronologicalKey = story.chronologicalKey
|
2012-06-18 23:08:10 +02:00
|
|
|
%Q
|
2012-06-18 23:07:38 +02:00
|
|
|
ORDER BY notif.chronologicalKey DESC
|
|
|
|
%Q",
|
2012-06-08 15:31:30 +02:00
|
|
|
$notification_table->getTableName(),
|
|
|
|
$story_table->getTableName(),
|
2012-06-18 23:08:10 +02:00
|
|
|
$this->buildWhereClause($conn),
|
2012-06-18 23:07:38 +02:00
|
|
|
$this->buildLimitClause($conn));
|
2012-06-08 15:31:30 +02:00
|
|
|
|
|
|
|
$viewed_map = ipull($data, 'hasViewed', 'chronologicalKey');
|
2012-06-18 23:08:10 +02:00
|
|
|
|
2012-10-23 21:01:59 +02:00
|
|
|
$stories = PhabricatorFeedStory::loadAllFromRows(
|
|
|
|
$data,
|
|
|
|
$this->getViewer());
|
|
|
|
|
2012-07-02 19:37:22 +02:00
|
|
|
foreach ($stories as $key => $story) {
|
|
|
|
$story->setHasViewed($viewed_map[$key]);
|
2012-06-08 15:31:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $stories;
|
|
|
|
}
|
2012-06-18 23:08:10 +02:00
|
|
|
|
|
|
|
private function buildWhereClause(AphrontDatabaseConnection $conn_r) {
|
|
|
|
$where = array();
|
|
|
|
|
|
|
|
if ($this->userPHID) {
|
|
|
|
$where[] = qsprintf(
|
|
|
|
$conn_r,
|
|
|
|
'notif.userPHID = %s',
|
|
|
|
$this->userPHID);
|
|
|
|
}
|
|
|
|
|
2012-06-28 22:59:50 +02:00
|
|
|
if ($this->unread !== null) {
|
|
|
|
$where[] = qsprintf(
|
|
|
|
$conn_r,
|
|
|
|
'notif.hasViewed = %d',
|
|
|
|
(int)!$this->unread);
|
|
|
|
}
|
|
|
|
|
2012-06-18 23:08:10 +02:00
|
|
|
if ($this->keys) {
|
|
|
|
$where[] = qsprintf(
|
|
|
|
$conn_r,
|
|
|
|
'notif.chronologicalKey IN (%Ls)',
|
|
|
|
$this->keys);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->formatWhereClause($where);
|
|
|
|
}
|
|
|
|
|
2012-06-08 15:31:30 +02:00
|
|
|
}
|