Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F15390398
D17730.id42655.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
12 KB
Referenced Files
None
Subscribers
None
D17730.id42655.diff
View Options
diff --git a/resources/sql/autopatches/20170419.thread.02.status.sql b/resources/sql/autopatches/20170419.thread.02.status.sql
new file mode 100644
--- /dev/null
+++ b/resources/sql/autopatches/20170419.thread.02.status.sql
@@ -0,0 +1,2 @@
+ALTER TABLE {$NAMESPACE}_conpherence.conpherence_participant
+ DROP participationStatus;
diff --git a/src/__phutil_library_map__.php b/src/__phutil_library_map__.php
--- a/src/__phutil_library_map__.php
+++ b/src/__phutil_library_map__.php
@@ -305,7 +305,6 @@
'ConpherenceParticipantCountQuery' => 'applications/conpherence/query/ConpherenceParticipantCountQuery.php',
'ConpherenceParticipantQuery' => 'applications/conpherence/query/ConpherenceParticipantQuery.php',
'ConpherenceParticipantView' => 'applications/conpherence/view/ConpherenceParticipantView.php',
- 'ConpherenceParticipationStatus' => 'applications/conpherence/constants/ConpherenceParticipationStatus.php',
'ConpherenceQueryThreadConduitAPIMethod' => 'applications/conpherence/conduit/ConpherenceQueryThreadConduitAPIMethod.php',
'ConpherenceQueryTransactionConduitAPIMethod' => 'applications/conpherence/conduit/ConpherenceQueryTransactionConduitAPIMethod.php',
'ConpherenceReplyHandler' => 'applications/conpherence/mail/ConpherenceReplyHandler.php',
@@ -5099,7 +5098,6 @@
'ConpherenceParticipantCountQuery' => 'PhabricatorOffsetPagedQuery',
'ConpherenceParticipantQuery' => 'PhabricatorOffsetPagedQuery',
'ConpherenceParticipantView' => 'AphrontView',
- 'ConpherenceParticipationStatus' => 'ConpherenceConstants',
'ConpherenceQueryThreadConduitAPIMethod' => 'ConpherenceConduitAPIMethod',
'ConpherenceQueryTransactionConduitAPIMethod' => 'ConpherenceConduitAPIMethod',
'ConpherenceReplyHandler' => 'PhabricatorMailReplyHandler',
diff --git a/src/applications/conpherence/constants/ConpherenceParticipationStatus.php b/src/applications/conpherence/constants/ConpherenceParticipationStatus.php
deleted file mode 100644
--- a/src/applications/conpherence/constants/ConpherenceParticipationStatus.php
+++ /dev/null
@@ -1,8 +0,0 @@
-<?php
-
-final class ConpherenceParticipationStatus extends ConpherenceConstants {
-
- const UP_TO_DATE = 0;
- const BEHIND = 1;
-
-}
diff --git a/src/applications/conpherence/controller/ConpherenceNotificationPanelController.php b/src/applications/conpherence/controller/ConpherenceNotificationPanelController.php
--- a/src/applications/conpherence/controller/ConpherenceNotificationPanelController.php
+++ b/src/applications/conpherence/controller/ConpherenceNotificationPanelController.php
@@ -7,7 +7,6 @@
$user = $request->getUser();
$conpherences = array();
require_celerity_resource('conpherence-notification-css');
- $unread_status = ConpherenceParticipationStatus::BEHIND;
$participant_data = id(new ConpherenceParticipantQuery())
->withParticipantPHIDs(array($user->getPHID()))
@@ -37,7 +36,7 @@
'conpherence-notification',
);
- if ($p_data->getParticipationStatus() == $unread_status) {
+ if (!$p_data->isUpToDate($conpherence)) {
$classes[] = 'phabricator-notification-unread';
}
$uri = $this->getApplicationURI($conpherence->getID().'/');
@@ -95,7 +94,7 @@
$unread = id(new ConpherenceParticipantCountQuery())
->withParticipantPHIDs(array($user->getPHID()))
- ->withParticipationStatus($unread_status)
+ ->withUnread(true)
->execute();
$unread_count = idx($unread, $user->getPHID(), 0);
diff --git a/src/applications/conpherence/editor/ConpherenceEditor.php b/src/applications/conpherence/editor/ConpherenceEditor.php
--- a/src/applications/conpherence/editor/ConpherenceEditor.php
+++ b/src/applications/conpherence/editor/ConpherenceEditor.php
@@ -173,17 +173,14 @@
$phids = $this->getPHIDTransactionNewValue($xaction, array());
foreach ($phids as $phid) {
if ($phid == $this->getActor()->getPHID()) {
- $status = ConpherenceParticipationStatus::UP_TO_DATE;
$message_count = 1;
} else {
- $status = ConpherenceParticipationStatus::BEHIND;
$message_count = 0;
}
$participants[$phid] =
id(new ConpherenceParticipant())
->setConpherencePHID($object->getPHID())
->setParticipantPHID($phid)
- ->setParticipationStatus($status)
->setDateTouched(time())
->setSeenMessageCount($message_count)
->save();
@@ -243,17 +240,14 @@
$add = array_keys(array_diff_key($new_map, $old_map));
foreach ($add as $phid) {
if ($phid == $this->getActor()->getPHID()) {
- $status = ConpherenceParticipationStatus::UP_TO_DATE;
$message_count = $object->getMessageCount();
} else {
- $status = ConpherenceParticipationStatus::BEHIND;
$message_count = 0;
}
$participants[$phid] =
id(new ConpherenceParticipant())
->setConpherencePHID($object->getPHID())
->setParticipantPHID($phid)
- ->setParticipationStatus($status)
->setDateTouched(time())
->setSeenMessageCount($message_count)
->save();
@@ -279,22 +273,18 @@
// update everyone's participation status on a message -only-
$xaction_phid = $xaction->getPHID();
- $behind = ConpherenceParticipationStatus::BEHIND;
- $up_to_date = ConpherenceParticipationStatus::UP_TO_DATE;
$participants = $object->getParticipants();
$user = $this->getActor();
$time = time();
foreach ($participants as $phid => $participant) {
if ($phid != $user->getPHID()) {
- if ($participant->getParticipationStatus() != $behind) {
+ if ($participant->isUpToDate($object)) {
$participant->setSeenMessageCount(
$object->getMessageCount() - $message_count);
}
- $participant->setParticipationStatus($behind);
$participant->setDateTouched($time);
} else {
$participant->setSeenMessageCount($object->getMessageCount());
- $participant->setParticipationStatus($up_to_date);
$participant->setDateTouched($time);
}
$participant->save();
diff --git a/src/applications/conpherence/query/ConpherenceParticipantCountQuery.php b/src/applications/conpherence/query/ConpherenceParticipantCountQuery.php
--- a/src/applications/conpherence/query/ConpherenceParticipantCountQuery.php
+++ b/src/applications/conpherence/query/ConpherenceParticipantCountQuery.php
@@ -1,73 +1,69 @@
<?php
-/**
- * Query class that answers the question:
- *
- * - Q: How many unread conpherences am I participating in?
- * - A:
- * id(new ConpherenceParticipantCountQuery())
- * ->withParticipantPHIDs(array($my_phid))
- * ->withParticipationStatus(ConpherenceParticipationStatus::BEHIND)
- * ->execute();
- */
final class ConpherenceParticipantCountQuery
extends PhabricatorOffsetPagedQuery {
private $participantPHIDs;
- private $participationStatus;
+ private $unread;
public function withParticipantPHIDs(array $phids) {
$this->participantPHIDs = $phids;
return $this;
}
- public function withParticipationStatus($participation_status) {
- $this->participationStatus = $participation_status;
+ public function withUnread($unread) {
+ $this->unread = $unread;
return $this;
}
public function execute() {
+ $thread = new ConpherenceThread();
$table = new ConpherenceParticipant();
- $conn_r = $table->establishConnection('r');
+ $conn = $table->establishConnection('r');
$rows = queryfx_all(
- $conn_r,
- 'SELECT COUNT(*) as count, participantPHID '.
- 'FROM %T participant %Q %Q %Q',
+ $conn,
+ 'SELECT COUNT(*) as count, participantPHID
+ FROM %T participant JOIN %T thread
+ ON participant.conpherencePHID = thread.phid %Q %Q %Q',
$table->getTableName(),
- $this->buildWhereClause($conn_r),
- $this->buildGroupByClause($conn_r),
- $this->buildLimitClause($conn_r));
+ $thread->getTableName(),
+ $this->buildWhereClause($conn),
+ $this->buildGroupByClause($conn),
+ $this->buildLimitClause($conn));
return ipull($rows, 'count', 'participantPHID');
}
- protected function buildWhereClause(AphrontDatabaseConnection $conn_r) {
+ protected function buildWhereClause(AphrontDatabaseConnection $conn) {
$where = array();
- if ($this->participantPHIDs) {
+ if ($this->participantPHIDs !== null) {
$where[] = qsprintf(
- $conn_r,
- 'participantPHID IN (%Ls)',
+ $conn,
+ 'participant.participantPHID IN (%Ls)',
$this->participantPHIDs);
}
- if ($this->participationStatus !== null) {
- $where[] = qsprintf(
- $conn_r,
- 'participationStatus = %d',
- $this->participationStatus);
+ if ($this->unread !== null) {
+ if ($this->unread) {
+ $where[] = qsprintf(
+ $conn,
+ 'participant.seenMessageCount < thread.messageCount');
+ } else {
+ $where[] = qsprintf(
+ $conn,
+ 'participant.seenMessageCount >= thread.messageCount');
+ }
}
return $this->formatWhereClause($where);
}
- private function buildGroupByClause(AphrontDatabaseConnection $conn_r) {
- $group_by = qsprintf(
- $conn_r,
+ private function buildGroupByClause(AphrontDatabaseConnection $conn) {
+ return qsprintf(
+ $conn,
'GROUP BY participantPHID');
-
- return $group_by;
}
}
diff --git a/src/applications/conpherence/storage/ConpherenceParticipant.php b/src/applications/conpherence/storage/ConpherenceParticipant.php
--- a/src/applications/conpherence/storage/ConpherenceParticipant.php
+++ b/src/applications/conpherence/storage/ConpherenceParticipant.php
@@ -4,7 +4,6 @@
protected $participantPHID;
protected $conpherencePHID;
- protected $participationStatus;
protected $seenMessageCount;
protected $dateTouched;
protected $settings = array();
@@ -15,7 +14,6 @@
'settings' => self::SERIALIZATION_JSON,
),
self::CONFIG_COLUMN_SCHEMA => array(
- 'participationStatus' => 'uint32',
'dateTouched' => 'epoch',
'seenMessageCount' => 'uint64',
),
@@ -24,12 +22,12 @@
'columns' => array('conpherencePHID', 'participantPHID'),
'unique' => true,
),
- 'unreadCount' => array(
- 'columns' => array('participantPHID', 'participationStatus'),
- ),
'participationIndex' => array(
'columns' => array('participantPHID', 'dateTouched', 'id'),
),
+ 'key_thread' => array(
+ 'columns' => array('participantPHID', 'conpherencePHID'),
+ ),
),
) + parent::getConfiguration();
}
@@ -41,8 +39,8 @@
public function markUpToDate(
ConpherenceThread $conpherence,
ConpherenceTransaction $xaction) {
+
if (!$this->isUpToDate($conpherence)) {
- $this->setParticipationStatus(ConpherenceParticipationStatus::UP_TO_DATE);
$this->setSeenMessageCount($conpherence->getMessageCount());
$this->save();
@@ -55,11 +53,7 @@
}
public function isUpToDate(ConpherenceThread $conpherence) {
- return
- ($this->getSeenMessageCount() == $conpherence->getMessageCount())
- &&
- ($this->getParticipationStatus() ==
- ConpherenceParticipationStatus::UP_TO_DATE);
+ return ($this->getSeenMessageCount() == $conpherence->getMessageCount());
}
}
diff --git a/src/applications/people/cache/PhabricatorUserMessageCountCacheType.php b/src/applications/people/cache/PhabricatorUserMessageCountCacheType.php
--- a/src/applications/people/cache/PhabricatorUserMessageCountCacheType.php
+++ b/src/applications/people/cache/PhabricatorUserMessageCountCacheType.php
@@ -28,10 +28,9 @@
$user_phids = mpull($users, 'getPHID');
- $unread_status = ConpherenceParticipationStatus::BEHIND;
$unread = id(new ConpherenceParticipantCountQuery())
->withParticipantPHIDs($user_phids)
- ->withParticipationStatus($unread_status)
+ ->withUnread(true)
->execute();
$empty = array_fill_keys($user_phids, 0);
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Sun, Mar 16, 6:10 AM (2 w, 6 d ago)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
7706017
Default Alt Text
D17730.id42655.diff (12 KB)
Attached To
Mode
D17730: Remove "participationStatus" from ConpherenceParticipant
Attached
Detach File
Event Timeline
Log In to Comment