mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-20 19:51:08 +01:00
f7b5955d33
Summary: Ref T11114. See D17114 for some discussion. For review actions: accept, reject, resign. For revision actions, order is basically least-severe to most-severe action pairs: plan changes, request review, close, reopen, abandon, reclaim, commandeer. Test Plan: Viewed revisions as an author and a reviewer, saw sensible action order within action groups. Reviewers: chad Reviewed By: chad Maniphest Tasks: T11114 Differential Revision: https://secure.phabricator.com/D17115
89 lines
2.3 KiB
PHP
89 lines
2.3 KiB
PHP
<?php
|
|
|
|
final class DifferentialRevisionCloseTransaction
|
|
extends DifferentialRevisionActionTransaction {
|
|
|
|
const TRANSACTIONTYPE = 'differential.revision.close';
|
|
const ACTIONKEY = 'close';
|
|
|
|
protected function getRevisionActionLabel() {
|
|
return pht('Close Revision');
|
|
}
|
|
|
|
protected function getRevisionActionDescription() {
|
|
return pht('This revision will be closed.');
|
|
}
|
|
|
|
public function getIcon() {
|
|
return 'fa-check';
|
|
}
|
|
|
|
public function getColor() {
|
|
return 'indigo';
|
|
}
|
|
|
|
protected function getRevisionActionOrder() {
|
|
return 300;
|
|
}
|
|
|
|
public function generateOldValue($object) {
|
|
return $object->isClosed();
|
|
}
|
|
|
|
public function applyInternalEffects($object, $value) {
|
|
$status_closed = ArcanistDifferentialRevisionStatus::CLOSED;
|
|
$status_accepted = ArcanistDifferentialRevisionStatus::ACCEPTED;
|
|
|
|
$old_status = $object->getStatus();
|
|
|
|
$object->setStatus($status_closed);
|
|
|
|
$was_accepted = ($old_status == $status_accepted);
|
|
|
|
$object->setProperty(
|
|
DifferentialRevision::PROPERTY_CLOSED_FROM_ACCEPTED,
|
|
$was_accepted);
|
|
}
|
|
|
|
protected function validateAction($object, PhabricatorUser $viewer) {
|
|
if ($object->isClosed()) {
|
|
throw new Exception(
|
|
pht(
|
|
'You can not close this revision because it has already been '.
|
|
'closed. Only open revisions can be closed.'));
|
|
}
|
|
|
|
if (!$object->isAccepted()) {
|
|
throw new Exception(
|
|
pht(
|
|
'You can not close this revision because it has not been accepted. '.
|
|
'Revisions must be accepted before they can be closed.'));
|
|
}
|
|
|
|
$config_key = 'differential.always-allow-close';
|
|
if (!PhabricatorEnv::getEnvConfig($config_key)) {
|
|
if (!$this->isViewerRevisionAuthor($object, $viewer)) {
|
|
throw new Exception(
|
|
pht(
|
|
'You can not close this revision because you are not the '.
|
|
'author. You can only close revisions you own. You can change '.
|
|
'this behavior by adjusting the "%s" setting in Config.',
|
|
$config_key));
|
|
}
|
|
}
|
|
}
|
|
|
|
public function getTitle() {
|
|
return pht(
|
|
'%s closed this revision.',
|
|
$this->renderAuthor());
|
|
}
|
|
|
|
public function getTitleForFeed() {
|
|
return pht(
|
|
'%s closed %s.',
|
|
$this->renderAuthor(),
|
|
$this->renderObject());
|
|
}
|
|
|
|
}
|