mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-05 04:11:01 +01:00
Store "last comment" and "last action" diffs on reviewers
Summary: Ref T10967. We have a "commented" state to help reviewers get a better sense of who is part of a discussion, and a "last action" state to help distinguish between "accept" and "accepted an older version", for the purposes of sticky accepts and as a UI hint. Currently, these are first-class states, partly beacuse we were somewhat limited in what we could do with edges. However, a more flexible way to represent them is as flags separate from the primary state flag. In the new storage, write them as separate state information: `lastActionDiffPHID` stores the Diff PHID of the last review action (accept, reject, etc). `lastCommentDiffPHID` stores the Diff PHID of the last comment (top-level or inline). Test Plan: Applied storage changes, commented and acted on a revision. Saw appropriate state reflected in the database. Reviewers: chad Reviewed By: chad Maniphest Tasks: T10967 Differential Revision: https://secure.phabricator.com/D17514
This commit is contained in:
parent
77b3efafbd
commit
794b456530
5 changed files with 78 additions and 0 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
ALTER TABLE {$NAMESPACE}_differential.differential_reviewer
|
||||||
|
ADD lastActionDiffPHID VARBINARY(64);
|
|
@ -0,0 +1,2 @@
|
||||||
|
ALTER TABLE {$NAMESPACE}_differential.differential_reviewer
|
||||||
|
ADD lastCommentDiffPHID VARBINARY(64);
|
|
@ -718,6 +718,9 @@ final class DifferentialTransactionEditor
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$this->markReviewerComments($object, $xactions);
|
||||||
|
|
||||||
return $xactions;
|
return $xactions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1836,4 +1839,59 @@ final class DifferentialTransactionEditor
|
||||||
->setNewValue($edits);
|
->setNewValue($edits);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getActiveDiff($object) {
|
||||||
|
if ($this->getIsNewObject()) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
return $object->getActiveDiff();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* When a reviewer makes a comment, mark the last revision they commented
|
||||||
|
* on.
|
||||||
|
*
|
||||||
|
* This allows us to show a hint to help authors and other reviewers quickly
|
||||||
|
* distinguish between reviewers who have participated in the discussion and
|
||||||
|
* reviewers who haven't been part of it.
|
||||||
|
*/
|
||||||
|
private function markReviewerComments($object, array $xactions) {
|
||||||
|
$acting_phid = $this->getActingAsPHID();
|
||||||
|
if (!$acting_phid) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$diff = $this->getActiveDiff($object);
|
||||||
|
if (!$diff) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$has_comment = false;
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
if ($xaction->hasComment()) {
|
||||||
|
$has_comment = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$has_comment) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$reviewer_table = new DifferentialReviewer();
|
||||||
|
$conn = $reviewer_table->establishConnection('w');
|
||||||
|
|
||||||
|
queryfx(
|
||||||
|
$conn,
|
||||||
|
'UPDATE %T SET lastCommentDiffPHID = %s
|
||||||
|
WHERE revisionPHID = %s
|
||||||
|
AND reviewerPHID = %s',
|
||||||
|
$reviewer_table->getTableName(),
|
||||||
|
$diff->getPHID(),
|
||||||
|
$object->getPHID(),
|
||||||
|
$acting_phid);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,10 +7,15 @@ final class DifferentialReviewer
|
||||||
protected $reviewerPHID;
|
protected $reviewerPHID;
|
||||||
protected $reviewerStatus;
|
protected $reviewerStatus;
|
||||||
|
|
||||||
|
protected $lastActionDiffPHID;
|
||||||
|
protected $lastCommentDiffPHID;
|
||||||
|
|
||||||
protected function getConfiguration() {
|
protected function getConfiguration() {
|
||||||
return array(
|
return array(
|
||||||
self::CONFIG_COLUMN_SCHEMA => array(
|
self::CONFIG_COLUMN_SCHEMA => array(
|
||||||
'reviewerStatus' => 'text64',
|
'reviewerStatus' => 'text64',
|
||||||
|
'lastActionDiffPHID' => 'phid?',
|
||||||
|
'lastCommentDiffPHID' => 'phid?',
|
||||||
),
|
),
|
||||||
self::CONFIG_KEY_SCHEMA => array(
|
self::CONFIG_KEY_SCHEMA => array(
|
||||||
'key_revision' => array(
|
'key_revision' => array(
|
||||||
|
|
|
@ -138,6 +138,13 @@ abstract class DifferentialRevisionReviewTransaction
|
||||||
// Now, do the new write.
|
// Now, do the new write.
|
||||||
|
|
||||||
if ($map) {
|
if ($map) {
|
||||||
|
$diff = $this->getEditor()->getActiveDiff($revision);
|
||||||
|
if ($diff) {
|
||||||
|
$diff_phid = $diff->getPHID();
|
||||||
|
} else {
|
||||||
|
$diff_phid = null;
|
||||||
|
}
|
||||||
|
|
||||||
$table = new DifferentialReviewer();
|
$table = new DifferentialReviewer();
|
||||||
|
|
||||||
$reviewers = $table->loadAllWhere(
|
$reviewers = $table->loadAllWhere(
|
||||||
|
@ -156,6 +163,10 @@ abstract class DifferentialRevisionReviewTransaction
|
||||||
|
|
||||||
$reviewer->setReviewerStatus($status);
|
$reviewer->setReviewerStatus($status);
|
||||||
|
|
||||||
|
if ($diff_phid) {
|
||||||
|
$reviewer->setLastActionDiffPHID($diff_phid);
|
||||||
|
}
|
||||||
|
|
||||||
if ($status == DifferentialReviewerStatus::STATUS_RESIGNED) {
|
if ($status == DifferentialReviewerStatus::STATUS_RESIGNED) {
|
||||||
if ($reviewer->getID()) {
|
if ($reviewer->getID()) {
|
||||||
$reviewer->delete();
|
$reviewer->delete();
|
||||||
|
|
Loading…
Reference in a new issue