1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 23:01:04 +01:00

Lift most "InlineController" querying to the base class

Summary: Ref T13513. Move querying to "DiffInlineCommentQuery" classes and lift them into the base Controller.

Test Plan: In Differential and Diffusion, created, edited, and submitted inline comments.

Maniphest Tasks: T13513

Differential Revision: https://secure.phabricator.com/D21231
This commit is contained in:
epriestley 2020-05-07 12:42:14 -07:00
parent 949b9163d0
commit af5b94b234
3 changed files with 70 additions and 83 deletions

View file

@ -3,6 +3,10 @@
final class DifferentialInlineCommentEditController final class DifferentialInlineCommentEditController
extends PhabricatorInlineCommentController { extends PhabricatorInlineCommentController {
protected function newInlineCommentQuery() {
return new DifferentialDiffInlineCommentQuery();
}
private function getRevisionID() { private function getRevisionID() {
return $this->getRequest()->getURIData('id'); return $this->getRequest()->getURIData('id');
} }
@ -58,44 +62,10 @@ final class DifferentialInlineCommentEditController
->setChangesetID($changeset_id); ->setChangesetID($changeset_id);
} }
protected function loadComment($id) {
return id(new DifferentialInlineCommentQuery())
->setViewer($this->getViewer())
->withIDs(array($id))
->withDeletedDrafts(true)
->needHidden(true)
->executeOne();
}
protected function loadCommentByPHID($phid) {
return id(new DifferentialInlineCommentQuery())
->setViewer($this->getViewer())
->withPHIDs(array($phid))
->withDeletedDrafts(true)
->needHidden(true)
->executeOne();
}
protected function loadCommentForEdit($id) {
$viewer = $this->getViewer();
$inline = $this->loadComment($id);
if (!$inline) {
throw new Exception(
pht('Unable to load inline "%s".', $id));
}
if (!$this->canEditInlineComment($viewer, $inline)) {
throw new Exception(pht('That comment is not editable!'));
}
return $inline;
}
protected function loadCommentForDone($id) { protected function loadCommentForDone($id) {
$viewer = $this->getViewer(); $viewer = $this->getViewer();
$inline = $this->loadComment($id); $inline = $this->loadCommentByID($id);
if (!$inline) { if (!$inline) {
throw new Exception(pht('Unable to load inline "%d".', $id)); throw new Exception(pht('Unable to load inline "%d".', $id));
} }
@ -144,7 +114,7 @@ final class DifferentialInlineCommentEditController
return $inline; return $inline;
} }
private function canEditInlineComment( protected function canEditInlineComment(
PhabricatorUser $viewer, PhabricatorUser $viewer,
DifferentialInlineComment $inline) { DifferentialInlineComment $inline) {

View file

@ -3,6 +3,10 @@
final class DiffusionInlineCommentController final class DiffusionInlineCommentController
extends PhabricatorInlineCommentController { extends PhabricatorInlineCommentController {
protected function newInlineCommentQuery() {
return new DiffusionDiffInlineCommentQuery();
}
private function getCommitPHID() { private function getCommitPHID() {
return $this->getRequest()->getURIData('phid'); return $this->getRequest()->getURIData('phid');
} }
@ -41,48 +45,10 @@ final class DiffusionInlineCommentController
->setPathID($path_id); ->setPathID($path_id);
} }
protected function loadComment($id) {
$viewer = $this->getViewer();
$inline = id(new DiffusionDiffInlineCommentQuery())
->setViewer($viewer)
->withIDs(array($id))
->executeOne();
if ($inline) {
$inline = $inline->newInlineCommentObject();
}
return $inline;
}
protected function loadCommentByPHID($phid) {
$viewer = $this->getViewer();
$inline = id(new DiffusionDiffInlineCommentQuery())
->setViewer($viewer)
->withPHIDs(array($phid))
->executeOne();
if ($inline) {
$inline = $inline->newInlineCommentObject();
}
return $inline;
}
protected function loadCommentForEdit($id) {
$viewer = $this->getViewer();
$inline = $this->loadComment($id);
if (!$this->canEditInlineComment($viewer, $inline)) {
throw new Exception(pht('That comment is not editable!'));
}
return $inline;
}
protected function loadCommentForDone($id) { protected function loadCommentForDone($id) {
$viewer = $this->getViewer(); $viewer = $this->getViewer();
$inline = $this->loadComment($id); $inline = $this->loadCommentByID($id);
if (!$inline) { if (!$inline) {
throw new Exception(pht('Failed to load comment "%d".', $id)); throw new Exception(pht('Failed to load comment "%d".', $id));
} }
@ -115,7 +81,7 @@ final class DiffusionInlineCommentController
return $inline; return $inline;
} }
private function canEditInlineComment( protected function canEditInlineComment(
PhabricatorUser $viewer, PhabricatorUser $viewer,
PhabricatorAuditInlineComment $inline) { PhabricatorAuditInlineComment $inline) {

View file

@ -4,10 +4,8 @@ abstract class PhabricatorInlineCommentController
extends PhabricatorController { extends PhabricatorController {
abstract protected function createComment(); abstract protected function createComment();
abstract protected function loadComment($id); abstract protected function newInlineCommentQuery();
abstract protected function loadCommentForEdit($id);
abstract protected function loadCommentForDone($id); abstract protected function loadCommentForDone($id);
abstract protected function loadCommentByPHID($phid);
abstract protected function loadObjectOwnerPHID( abstract protected function loadObjectOwnerPHID(
PhabricatorInlineComment $inline); PhabricatorInlineComment $inline);
abstract protected function deleteComment( abstract protected function deleteComment(
@ -172,7 +170,7 @@ abstract class PhabricatorInlineCommentController
$is_delete = ($op == 'delete' || $op == 'refdelete'); $is_delete = ($op == 'delete' || $op == 'refdelete');
$inline = $this->loadCommentForEdit($this->getCommentID()); $inline = $this->loadCommentByIDForEdit($this->getCommentID());
if ($is_delete) { if ($is_delete) {
$this->deleteComment($inline); $this->deleteComment($inline);
@ -182,7 +180,7 @@ abstract class PhabricatorInlineCommentController
return $this->buildEmptyResponse(); return $this->buildEmptyResponse();
case 'edit': case 'edit':
$inline = $this->loadCommentForEdit($this->getCommentID()); $inline = $this->loadCommentByIDForEdit($this->getCommentID());
$text = $this->getCommentText(); $text = $this->getCommentText();
if ($request->isFormPost()) { if ($request->isFormPost()) {
@ -228,7 +226,7 @@ abstract class PhabricatorInlineCommentController
return $this->newInlineResponse($inline, $view); return $this->newInlineResponse($inline, $view);
case 'cancel': case 'cancel':
$inline = $this->loadCommentForEdit($this->getCommentID()); $inline = $this->loadCommentByIDForEdit($this->getCommentID());
$inline->setIsEditing(false); $inline->setIsEditing(false);
@ -251,7 +249,7 @@ abstract class PhabricatorInlineCommentController
return $this->buildEmptyResponse(); return $this->buildEmptyResponse();
case 'draft': case 'draft':
$inline = $this->loadCommentForEdit($this->getCommentID()); $inline = $this->loadCommentByIDForEdit($this->getCommentID());
$versioned_draft = PhabricatorVersionedDraft::loadOrCreateDraft( $versioned_draft = PhabricatorVersionedDraft::loadOrCreateDraft(
$inline->getPHID(), $inline->getPHID(),
@ -442,5 +440,58 @@ abstract class PhabricatorInlineCommentController
$viewer->getPHID()); $viewer->getPHID());
} }
final protected function loadCommentByID($id) {
$query = $this->newInlineCommentQuery()
->withIDs(array($id));
return $this->loadCommentByQuery($query);
}
final protected function loadCommentByPHID($phid) {
$query = $this->newInlineCommentQuery()
->withPHIDs(array($phid));
return $this->loadCommentByQuery($query);
}
final protected function loadCommentByIDForEdit($id) {
$viewer = $this->getViewer();
$query = $this->newInlineCommentQuery()
->withIDs(array($id));
$inline = $this->loadCommentByQuery($query);
if (!$inline) {
throw new Exception(
pht(
'Unable to load inline "%s".',
$id));
}
if (!$this->canEditInlineComment($viewer, $inline)) {
throw new Exception(
pht(
'Inline comment "%s" is not editable.',
$id));
}
return $inline;
}
private function loadCommentByQuery(
PhabricatorDiffInlineCommentQuery $query) {
$viewer = $this->getViewer();
$inline = $query
->setViewer($viewer)
->executeOne();
if ($inline) {
$inline = $inline->newInlineCommentObject();
}
return $inline;
}
} }