mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-10 23:01:04 +01:00
Reduce surface area of DifferentialComment API
Summary: Ref T2222. Shrink the API to make it easier to move this object's storage to ApplicationTransactions. Fixes T3415. This moves the "Summary" and "Test Plan" into the property list, and thereby fixes all the attribution problems associated with commandeering, creating a revision from another user's diff, etc. Test Plan: Browsed several revisions. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T3415, T2222 Differential Revision: https://secure.phabricator.com/D7375
This commit is contained in:
parent
cf1c06e157
commit
32dd8af9e5
5 changed files with 56 additions and 75 deletions
|
@ -91,9 +91,6 @@ final class DifferentialRevisionViewController extends DifferentialController {
|
||||||
$aux_fields = $this->loadAuxiliaryFields($revision);
|
$aux_fields = $this->loadAuxiliaryFields($revision);
|
||||||
|
|
||||||
$comments = $revision->loadComments();
|
$comments = $revision->loadComments();
|
||||||
$comments = array_merge(
|
|
||||||
$this->getImplicitComments($revision, reset($diffs)),
|
|
||||||
$comments);
|
|
||||||
|
|
||||||
$all_changesets = $changesets;
|
$all_changesets = $changesets;
|
||||||
$inlines = $this->loadInlineComments(
|
$inlines = $this->loadInlineComments(
|
||||||
|
@ -111,22 +108,8 @@ final class DifferentialRevisionViewController extends DifferentialController {
|
||||||
mpull($comments, 'getAuthorPHID'));
|
mpull($comments, 'getAuthorPHID'));
|
||||||
|
|
||||||
foreach ($comments as $comment) {
|
foreach ($comments as $comment) {
|
||||||
$metadata = $comment->getMetadata();
|
foreach ($comment->getRequiredHandlePHIDs() as $phid) {
|
||||||
$added_reviewers = idx(
|
$object_phids[] = $phid;
|
||||||
$metadata,
|
|
||||||
DifferentialComment::METADATA_ADDED_REVIEWERS);
|
|
||||||
if ($added_reviewers) {
|
|
||||||
foreach ($added_reviewers as $phid) {
|
|
||||||
$object_phids[] = $phid;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$added_ccs = idx(
|
|
||||||
$metadata,
|
|
||||||
DifferentialComment::METADATA_ADDED_CCS);
|
|
||||||
if ($added_ccs) {
|
|
||||||
foreach ($added_ccs as $phid) {
|
|
||||||
$object_phids[] = $phid;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -479,38 +462,6 @@ final class DifferentialRevisionViewController extends DifferentialController {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getImplicitComments(
|
|
||||||
DifferentialRevision $revision,
|
|
||||||
DifferentialDiff $diff) {
|
|
||||||
|
|
||||||
$author_phid = nonempty(
|
|
||||||
$diff->getAuthorPHID(),
|
|
||||||
$revision->getAuthorPHID());
|
|
||||||
|
|
||||||
$template = new DifferentialComment();
|
|
||||||
$template->setAuthorPHID($author_phid);
|
|
||||||
$template->setRevisionID($revision->getID());
|
|
||||||
$template->setDateCreated($revision->getDateCreated());
|
|
||||||
|
|
||||||
$comments = array();
|
|
||||||
|
|
||||||
if (strlen($revision->getSummary())) {
|
|
||||||
$summary_comment = clone $template;
|
|
||||||
$summary_comment->setContent($revision->getSummary());
|
|
||||||
$summary_comment->setAction(DifferentialAction::ACTION_SUMMARIZE);
|
|
||||||
$comments[] = $summary_comment;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strlen($revision->getTestPlan())) {
|
|
||||||
$testplan_comment = clone $template;
|
|
||||||
$testplan_comment->setContent($revision->getTestPlan());
|
|
||||||
$testplan_comment->setAction(DifferentialAction::ACTION_TESTPLAN);
|
|
||||||
$comments[] = $testplan_comment;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $comments;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function getRevisionActions(DifferentialRevision $revision) {
|
private function getRevisionActions(DifferentialRevision $revision) {
|
||||||
$user = $this->getRequest()->getUser();
|
$user = $this->getRequest()->getUser();
|
||||||
$viewer_phid = $user->getPHID();
|
$viewer_phid = $user->getPHID();
|
||||||
|
|
|
@ -566,7 +566,7 @@ final class DifferentialCommentEditor extends PhabricatorEditor {
|
||||||
|
|
||||||
$comment = id(new DifferentialComment())
|
$comment = id(new DifferentialComment())
|
||||||
->setAuthorPHID($actor_phid)
|
->setAuthorPHID($actor_phid)
|
||||||
->setRevisionID($revision->getID())
|
->setRevision($revision)
|
||||||
->setAction($action)
|
->setAction($action)
|
||||||
->setContent((string)$this->message)
|
->setContent((string)$this->message)
|
||||||
->setMetadata($metadata);
|
->setMetadata($metadata);
|
||||||
|
|
|
@ -783,10 +783,9 @@ final class DifferentialRevisionEditor extends PhabricatorEditor {
|
||||||
|
|
||||||
|
|
||||||
private function createComment() {
|
private function createComment() {
|
||||||
$revision_id = $this->revision->getID();
|
|
||||||
$comment = id(new DifferentialComment())
|
$comment = id(new DifferentialComment())
|
||||||
->setAuthorPHID($this->getActorPHID())
|
->setAuthorPHID($this->getActorPHID())
|
||||||
->setRevisionID($revision_id)
|
->setRevision($this->revision)
|
||||||
->setContent($this->getComments())
|
->setContent($this->getComments())
|
||||||
->setAction(DifferentialAction::ACTION_UPDATE)
|
->setAction(DifferentialAction::ACTION_UPDATE)
|
||||||
->setMetadata(
|
->setMetadata(
|
||||||
|
|
|
@ -20,11 +20,39 @@ final class DifferentialComment extends DifferentialDAO
|
||||||
|
|
||||||
private $arbitraryDiffForFacebook;
|
private $arbitraryDiffForFacebook;
|
||||||
|
|
||||||
|
public function setRevision(DifferentialRevision $revision) {
|
||||||
|
return $this->setRevisionID($revision->getID());
|
||||||
|
}
|
||||||
|
|
||||||
public function giveFacebookSomeArbitraryDiff(DifferentialDiff $diff) {
|
public function giveFacebookSomeArbitraryDiff(DifferentialDiff $diff) {
|
||||||
$this->arbitraryDiffForFacebook = $diff;
|
$this->arbitraryDiffForFacebook = $diff;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRequiredHandlePHIDs() {
|
||||||
|
$phids = array();
|
||||||
|
|
||||||
|
$metadata = $this->getMetadata();
|
||||||
|
$added_reviewers = idx(
|
||||||
|
$metadata,
|
||||||
|
self::METADATA_ADDED_REVIEWERS);
|
||||||
|
if ($added_reviewers) {
|
||||||
|
foreach ($added_reviewers as $phid) {
|
||||||
|
$phids[] = $phid;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$added_ccs = idx(
|
||||||
|
$metadata,
|
||||||
|
self::METADATA_ADDED_CCS);
|
||||||
|
if ($added_ccs) {
|
||||||
|
foreach ($added_ccs as $phid) {
|
||||||
|
$phids[] = $phid;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $phids;
|
||||||
|
}
|
||||||
|
|
||||||
public function getConfiguration() {
|
public function getConfiguration() {
|
||||||
return array(
|
return array(
|
||||||
self::CONFIG_SERIALIZATION => array(
|
self::CONFIG_SERIALIZATION => array(
|
||||||
|
@ -42,16 +70,8 @@ final class DifferentialComment extends DifferentialDAO
|
||||||
return PhabricatorContentSource::newFromSerialized($this->contentSource);
|
return PhabricatorContentSource::newFromSerialized($this->contentSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getMarkupFieldKey($field) {
|
public function getMarkupFieldKey($field) {
|
||||||
if ($this->getID()) {
|
return 'DC:'.$this->getID();
|
||||||
return 'DC:'.$this->getID();
|
|
||||||
}
|
|
||||||
|
|
||||||
// The summary and test plan render as comments, but do not have IDs.
|
|
||||||
// They are also mutable. Build keys using content hashes.
|
|
||||||
$hash = PhabricatorHash::digest($this->getMarkupText($field));
|
|
||||||
return 'DC:'.$hash;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function newMarkupEngine($field) {
|
public function newMarkupEngine($field) {
|
||||||
|
@ -70,18 +90,7 @@ final class DifferentialComment extends DifferentialDAO
|
||||||
}
|
}
|
||||||
|
|
||||||
public function shouldUseMarkupCache($field) {
|
public function shouldUseMarkupCache($field) {
|
||||||
if ($this->getID()) {
|
return (bool)$this->getID();
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$action = $this->getAction();
|
|
||||||
switch ($action) {
|
|
||||||
case DifferentialAction::ACTION_SUMMARIZE:
|
|
||||||
case DifferentialAction::ACTION_TESTPLAN:
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -112,6 +112,28 @@ final class DifferentialRevisionDetailView extends AphrontView {
|
||||||
$properties->setHasKeyboardShortcuts(true);
|
$properties->setHasKeyboardShortcuts(true);
|
||||||
$properties->setActionList($actions);
|
$properties->setActionList($actions);
|
||||||
|
|
||||||
|
$properties->invokeWillRenderEvent();
|
||||||
|
|
||||||
|
if (strlen($revision->getSummary())) {
|
||||||
|
$properties->addSectionHeader(pht('Summary'));
|
||||||
|
$properties->addTextContent(
|
||||||
|
PhabricatorMarkupEngine::renderOneObject(
|
||||||
|
id(new PhabricatorMarkupOneOff())->setContent(
|
||||||
|
$revision->getSummary()),
|
||||||
|
'default',
|
||||||
|
$user));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strlen($revision->getTestPlan())) {
|
||||||
|
$properties->addSectionHeader(pht('Test Plan'));
|
||||||
|
$properties->addTextContent(
|
||||||
|
PhabricatorMarkupEngine::renderOneObject(
|
||||||
|
id(new PhabricatorMarkupOneOff())->setContent(
|
||||||
|
$revision->getTestPlan()),
|
||||||
|
'default',
|
||||||
|
$user));
|
||||||
|
}
|
||||||
|
|
||||||
$object_box = id(new PHUIObjectBoxView())
|
$object_box = id(new PHUIObjectBoxView())
|
||||||
->setHeader($header)
|
->setHeader($header)
|
||||||
->addPropertyList($properties);
|
->addPropertyList($properties);
|
||||||
|
|
Loading…
Reference in a new issue